meter_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package metrics
  2. import (
  3. "testing"
  4. "time"
  5. )
  6. func BenchmarkMeter(b *testing.B) {
  7. m := NewMeter()
  8. b.ResetTimer()
  9. for i := 0; i < b.N; i++ {
  10. m.Mark(1)
  11. }
  12. }
  13. func TestGetOrRegisterMeter(t *testing.T) {
  14. r := NewRegistry()
  15. NewRegisteredMeter("foo", r).Mark(47)
  16. if m := GetOrRegisterMeter("foo", r); 47 != m.Count() {
  17. t.Fatal(m)
  18. }
  19. }
  20. func TestMeterDecay(t *testing.T) {
  21. ma := meterArbiter{
  22. ticker: time.NewTicker(time.Millisecond),
  23. }
  24. m := newStandardMeter()
  25. ma.meters = append(ma.meters, m)
  26. go ma.tick()
  27. m.Mark(1)
  28. rateMean := m.RateMean()
  29. time.Sleep(100 * time.Millisecond)
  30. if m.RateMean() >= rateMean {
  31. t.Error("m.RateMean() didn't decrease")
  32. }
  33. }
  34. func TestMeterNonzero(t *testing.T) {
  35. m := NewMeter()
  36. m.Mark(3)
  37. if count := m.Count(); 3 != count {
  38. t.Errorf("m.Count(): 3 != %v\n", count)
  39. }
  40. }
  41. func TestMeterSnapshot(t *testing.T) {
  42. m := NewMeter()
  43. m.Mark(1)
  44. if snapshot := m.Snapshot(); m.RateMean() != snapshot.RateMean() {
  45. t.Fatal(snapshot)
  46. }
  47. }
  48. func TestMeterZero(t *testing.T) {
  49. m := NewMeter()
  50. if count := m.Count(); 0 != count {
  51. t.Errorf("m.Count(): 0 != %v\n", count)
  52. }
  53. }