http, cache: Track evictions

This commit is contained in:
Martin Polden
2020-09-11 21:55:09 +02:00
parent b7ed233452
commit 832f3655e8
4 changed files with 34 additions and 16 deletions

View File

@ -9,11 +9,13 @@ import (
func TestCacheCapacity(t *testing.T) {
var tests = []struct {
addCount, capacity, size int
evictions uint64
}{
{1, 0, 0},
{1, 2, 1},
{2, 2, 2},
{3, 2, 2},
{1, 0, 0, 0},
{1, 2, 1, 0},
{2, 2, 2, 0},
{3, 2, 2, 1},
{10, 5, 5, 5},
}
for i, tt := range tests {
c := NewCache(tt.capacity)
@ -27,6 +29,9 @@ func TestCacheCapacity(t *testing.T) {
if got := len(c.entries); got != tt.size {
t.Errorf("#%d: len(entries) = %d, want %d", i, got, tt.size)
}
if got := c.evictions; got != tt.evictions {
t.Errorf("#%d: evictions = %d, want %d", i, got, tt.evictions)
}
if tt.capacity > 0 && tt.addCount > tt.capacity && tt.capacity == tt.size {
lastAdded := responses[tt.addCount-1]
if _, ok := c.Get(lastAdded.IP); !ok {
@ -57,7 +62,7 @@ func TestCacheDuplicate(t *testing.T) {
func TestCacheResize(t *testing.T) {
c := NewCache(10)
for i := 1; i <= 10; i++ {
for i := 1; i <= 20; i++ {
ip := net.ParseIP(fmt.Sprintf("192.0.2.%d", i))
r := Response{IP: ip}
c.Set(ip, r)
@ -65,9 +70,15 @@ func TestCacheResize(t *testing.T) {
if got, want := len(c.entries), 10; got != want {
t.Errorf("want %d entries, got %d", want, got)
}
if got, want := c.evictions, uint64(10); got != want {
t.Errorf("want %d evictions, got %d", want, got)
}
if err := c.Resize(5); err != nil {
t.Fatal(err)
}
if got, want := c.evictions, uint64(0); got != want {
t.Errorf("want %d evictions, got %d", want, got)
}
r := Response{IP: net.ParseIP("192.0.2.42")}
c.Set(r.IP, r)
if got, want := len(c.entries), 5; got != want {