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())
}
Domain
Subdomains
Defined In
Calls
Source
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