| package sinbin |
| |
| import ( |
| "testing" |
| "time" |
| ) |
| |
| // TestSinbinBasics performs some basic tests on the Sinbin. |
| func TestSinbinBasics(t *testing.T) { |
| var s Sinbin[string] |
| |
| if s.Penalized("foo") { |
| t.Errorf("'foo' should not be penalized as it hasn't yet been added") |
| } |
| s.Add("foo", time.Now().Add(-1*time.Second)) |
| if s.Penalized("foo") { |
| t.Errorf("'foo' should not be penalized as it has been added with an expired time") |
| } |
| s.Add("bar", time.Now().Add(time.Hour)) |
| if !s.Penalized("bar") { |
| t.Errorf("'bar' should be penalized as it has been added with an hour long penalty") |
| } |
| |
| // Force sweep. |
| s.lastSweep = time.Now().Add(-1 * time.Hour) |
| s.sweepUnlocked() |
| |
| if len(s.bench) != 1 { |
| t.Errorf("there should only be one element on the bench") |
| } |
| if _, ok := s.bench["bar"]; !ok { |
| t.Errorf("the bench should contain 'bar'") |
| } |
| } |