package ccache import ( . "github.com/karlseguin/expect" "strconv" "testing" "time" ) type CacheTests struct{} func Test_Cache(t *testing.T) { Expectify(new(CacheTests), t) } func (_ CacheTests) DeletesAValue() { cache := New(Configure()) cache.Set("spice", "flow", time.Minute) cache.Set("worm", "sand", time.Minute) cache.Delete("spice") Expect(cache.Get("spice")).To.Equal(nil) Expect(cache.Get("worm").Value()).To.Equal("sand") } func (_ CacheTests) GCsTheOldestItems() { cache := New(Configure().ItemsToPrune(10)) for i := 0; i < 500; i++ { cache.Set(strconv.Itoa(i), i, time.Minute) } //let the items get promoted (and added to our list) time.Sleep(time.Millisecond * 10) cache.gc() Expect(cache.Get("9")).To.Equal(nil) Expect(cache.Get("10").Value()).To.Equal(10) } func (_ CacheTests) PromotedItemsDontGetPruned() { cache := New(Configure().ItemsToPrune(10).GetsPerPromote(1)) for i := 0; i < 500; i++ { cache.Set(strconv.Itoa(i), i, time.Minute) } time.Sleep(time.Millisecond * 10) //run the worker once to init the list cache.Get("9") time.Sleep(time.Millisecond * 10) cache.gc() Expect(cache.Get("9").Value()).To.Equal(9) Expect(cache.Get("10")).To.Equal(nil) Expect(cache.Get("11").Value()).To.Equal(11) } func (_ CacheTests) TrackerDoesNotCleanupHeldInstance() { cache := New(Configure().ItemsToPrune(10).Track()) for i := 0; i < 10; i++ { cache.Set(strconv.Itoa(i), i, time.Minute) } item := cache.TrackingGet("0") time.Sleep(time.Millisecond * 10) cache.gc() Expect(cache.Get("0").Value()).To.Equal(0) Expect(cache.Get("1")).To.Equal(nil) item.Release() cache.gc() Expect(cache.Get("0")).To.Equal(nil) } func (_ CacheTests) RemovesOldestItemWhenFull() { cache := New(Configure().MaxItems(5).ItemsToPrune(1)) for i := 0; i < 7; i++ { cache.Set(strconv.Itoa(i), i, time.Minute) } time.Sleep(time.Millisecond * 10) Expect(cache.Get("0")).To.Equal(nil) Expect(cache.Get("1")).To.Equal(nil) Expect(cache.Get("2").Value()).To.Equal(2) } func (_ CacheTests) RemovesOldestItemWhenFullBySizer() { cache := New(Configure().MaxItems(9).ItemsToPrune(2)) for i := 0; i < 7; i++ { cache.Set(strconv.Itoa(i), &SizedItem{i, 2}, time.Minute) } time.Sleep(time.Millisecond * 10) Expect(cache.Get("0")).To.Equal(nil) Expect(cache.Get("1")).To.Equal(nil) Expect(cache.Get("2")).To.Equal(nil) Expect(cache.Get("3").Value().(*SizedItem).id).To.Equal(3) } func (_ CacheTests) SetUpdatesSizeOnDelta() { cache := New(Configure()) cache.Set("a", &SizedItem{0, 2}, time.Minute) cache.Set("b", &SizedItem{0, 3}, time.Minute) Expect(cache.size).To.Equal(int64(5)) cache.Set("b", &SizedItem{0, 3}, time.Minute) Expect(cache.size).To.Equal(int64(5)) cache.Set("b", &SizedItem{0, 4}, time.Minute) Expect(cache.size).To.Equal(int64(6)) cache.Set("b", &SizedItem{0, 2}, time.Minute) Expect(cache.size).To.Equal(int64(4)) cache.Delete("b") time.Sleep(time.Millisecond * 10) Expect(cache.size).To.Equal(int64(2)) } type SizedItem struct { id int s int64 } func (s *SizedItem) Size() int64 { return s.s }