| 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'") | 
 | 	} | 
 | } |