Home / Function/ Test_Cache_MaxBytes_DeletionFailureRestoresTracking() — fiber Function Reference

Test_Cache_MaxBytes_DeletionFailureRestoresTracking() — fiber Function Reference

Architecture documentation for the Test_Cache_MaxBytes_DeletionFailureRestoresTracking() function in cache_test.go from the fiber codebase.

Entity Profile

Dependency Diagram

graph TD
  67de0060_9f5d_b67b_5553_0299206a6680["Test_Cache_MaxBytes_DeletionFailureRestoresTracking()"]
  8453a087_9678_fe96_1b20_2d125b6f8656["cache_test.go"]
  67de0060_9f5d_b67b_5553_0299206a6680 -->|defined in| 8453a087_9678_fe96_1b20_2d125b6f8656
  764bea14_4c8a_81bd_ccd6_a1952b5d95d1["newFailingCacheStorage()"]
  67de0060_9f5d_b67b_5553_0299206a6680 -->|calls| 764bea14_4c8a_81bd_ccd6_a1952b5d95d1
  style 67de0060_9f5d_b67b_5553_0299206a6680 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

middleware/cache/cache_test.go lines 3856–3912

func Test_Cache_MaxBytes_DeletionFailureRestoresTracking(t *testing.T) {
	t.Parallel()

	storage := newFailingCacheStorage()

	app := fiber.New()
	app.Use(New(Config{
		MaxBytes:   4,
		Expiration: 1 * time.Hour,
		Storage:    storage,
	}))

	app.Get("/:name", func(c fiber.Ctx) error {
		return c.SendString("data")
	})

	// Seed the cache with a single entry
	rsp, err := app.Test(httptest.NewRequest(fiber.MethodGet, "/first", http.NoBody))
	require.NoError(t, err)
	require.Equal(t, cacheMiss, rsp.Header.Get("X-Cache"))

	var storedKeys []string
	storage.mu.Lock()
	for key := range storage.data {
		storedKeys = append(storedKeys, key)
		if strings.Contains(key, "/first") {
			storage.errs["del|"+key] = errors.New("delete failed")
		}
	}
	storage.mu.Unlock()
	t.Logf("stored keys after first cache: %v", storedKeys)

	// Next request triggers eviction; deletion failure should surface an error
	rsp, err = app.Test(httptest.NewRequest(fiber.MethodGet, "/second", http.NoBody))
	require.NoError(t, err)
	body, err := io.ReadAll(rsp.Body)
	require.NoError(t, err)
	require.Equal(t, fiber.StatusInternalServerError, rsp.StatusCode)
	require.Contains(t, string(body), "failed to delete key")
	require.NoError(t, rsp.Body.Close())
	var remainingKeys []string
	storage.mu.RLock()
	for key := range storage.data {
		remainingKeys = append(remainingKeys, key)
	}
	storage.mu.RUnlock()
	t.Logf("stored keys after deletion failure: %v", remainingKeys)
	storage.mu.Lock()
	storage.errs = make(map[string]error)
	storage.mu.Unlock()

	// Another request should succeed and be cacheable after restoring heap tracking
	rsp, err = app.Test(httptest.NewRequest(fiber.MethodGet, "/third", http.NoBody))
	require.NoError(t, err)
	require.Equal(t, cacheMiss, rsp.Header.Get("X-Cache"))
	require.NoError(t, rsp.Body.Close())
}

Subdomains

Frequently Asked Questions

What does Test_Cache_MaxBytes_DeletionFailureRestoresTracking() do?
Test_Cache_MaxBytes_DeletionFailureRestoresTracking() is a function in the fiber codebase, defined in middleware/cache/cache_test.go.
Where is Test_Cache_MaxBytes_DeletionFailureRestoresTracking() defined?
Test_Cache_MaxBytes_DeletionFailureRestoresTracking() is defined in middleware/cache/cache_test.go at line 3856.
What does Test_Cache_MaxBytes_DeletionFailureRestoresTracking() call?
Test_Cache_MaxBytes_DeletionFailureRestoresTracking() calls 1 function(s): newFailingCacheStorage.

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free