// This files was copied/modified from https://github.com/hashicorp/golang-lru // which was (see below) // This package provides a simple LRU cache. It is based on the // LRU implementation in groupcache: // https://github.com/golang/groupcache/tree/master/lru package utils import "testing" import "time" func TestLRU(t *testing.T) { l := NewLru(128) for i := 0; i < 256; i++ { l.Add(i, i) } if l.Len() != 128 { t.Fatalf("bad len: %v", l.Len()) } for i, k := range l.Keys() { if v, ok := l.Get(k); !ok || v != k || v != i+128 { t.Fatalf("bad key: %v", k) } } for i := 0; i < 128; i++ { _, ok := l.Get(i) if ok { t.Fatalf("should be evicted") } } for i := 128; i < 256; i++ { _, ok := l.Get(i) if !ok { t.Fatalf("should not be evicted") } } for i := 128; i < 192; i++ { l.Remove(i) _, ok := l.Get(i) if ok { t.Fatalf("should be deleted") } } l.Get(192) // expect 192 to be last key in l.Keys() for i, k := range l.Keys() { if (i < 63 && k != i+193) || (i == 63 && k != 192) { t.Fatalf("out of order key: %v", k) } } l.Purge() if l.Len() != 0 { t.Fatalf("bad len: %v", l.Len()) } if _, ok := l.Get(200); ok { t.Fatalf("should contain nothing") } } func TestLRUExpire(t *testing.T) { l := NewLru(128) l.AddWithExpiresInSecs(1, 1, 1) l.AddWithExpiresInSecs(2, 2, 1) l.AddWithExpiresInSecs(3, 3, 0) time.Sleep(time.Millisecond * 2100) if r1, ok := l.Get(1); ok { t.Fatal(r1) } if _, ok2 := l.Get(3); !ok2 { t.Fatal("should exist") } }