meter_test.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package metrics
  2. import (
  3. "math/rand"
  4. "sync"
  5. "testing"
  6. "time"
  7. )
  8. func BenchmarkMeter(b *testing.B) {
  9. m := NewMeter()
  10. b.ResetTimer()
  11. for i := 0; i < b.N; i++ {
  12. m.Mark(1)
  13. }
  14. }
  15. func BenchmarkMeterParallel(b *testing.B) {
  16. m := NewMeter()
  17. b.ResetTimer()
  18. b.RunParallel(func(pb *testing.PB) {
  19. for pb.Next() {
  20. m.Mark(1)
  21. }
  22. })
  23. }
  24. // exercise race detector
  25. func TestMeterConcurrency(t *testing.T) {
  26. rand.Seed(time.Now().Unix())
  27. ma := meterArbiter{
  28. ticker: time.NewTicker(time.Millisecond),
  29. meters: make(map[*StandardMeter]struct{}),
  30. }
  31. m := newStandardMeter()
  32. ma.meters[m] = struct{}{}
  33. go ma.tick()
  34. wg := &sync.WaitGroup{}
  35. reps := 100
  36. for i := 0; i < reps; i++ {
  37. wg.Add(1)
  38. go func(m Meter, wg *sync.WaitGroup) {
  39. m.Mark(1)
  40. wg.Done()
  41. }(m, wg)
  42. wg.Add(1)
  43. go func(m Meter, wg *sync.WaitGroup) {
  44. m.Stop()
  45. wg.Done()
  46. }(m, wg)
  47. }
  48. wg.Wait()
  49. }
  50. func TestGetOrRegisterMeter(t *testing.T) {
  51. r := NewRegistry()
  52. NewRegisteredMeter("foo", r).Mark(47)
  53. if m := GetOrRegisterMeter("foo", r); 47 != m.Count() {
  54. t.Fatal(m)
  55. }
  56. }
  57. func TestMeterDecay(t *testing.T) {
  58. ma := meterArbiter{
  59. ticker: time.NewTicker(time.Millisecond),
  60. meters: make(map[*StandardMeter]struct{}),
  61. }
  62. m := newStandardMeter()
  63. ma.meters[m] = struct{}{}
  64. go ma.tick()
  65. m.Mark(1)
  66. rateMean := m.RateMean()
  67. time.Sleep(100 * time.Millisecond)
  68. if m.RateMean() >= rateMean {
  69. t.Error("m.RateMean() didn't decrease")
  70. }
  71. }
  72. func TestMeterNonzero(t *testing.T) {
  73. m := NewMeter()
  74. m.Mark(3)
  75. if count := m.Count(); 3 != count {
  76. t.Errorf("m.Count(): 3 != %v\n", count)
  77. }
  78. }
  79. func TestMeterStop(t *testing.T) {
  80. l := len(arbiter.meters)
  81. m := NewMeter()
  82. if len(arbiter.meters) != l+1 {
  83. t.Errorf("arbiter.meters: %d != %d\n", l+1, len(arbiter.meters))
  84. }
  85. m.Stop()
  86. if len(arbiter.meters) != l {
  87. t.Errorf("arbiter.meters: %d != %d\n", l, len(arbiter.meters))
  88. }
  89. }
  90. func TestMeterSnapshot(t *testing.T) {
  91. m := NewMeter()
  92. m.Mark(1)
  93. if snapshot := m.Snapshot(); m.RateMean() != snapshot.RateMean() {
  94. t.Fatal(snapshot)
  95. }
  96. }
  97. func TestMeterZero(t *testing.T) {
  98. m := NewMeter()
  99. if count := m.Count(); 0 != count {
  100. t.Errorf("m.Count(): 0 != %v\n", count)
  101. }
  102. }