meter_test.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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 BenchmarkMeterParallel(b *testing.B) {
  14. m := NewMeter()
  15. b.ResetTimer()
  16. b.RunParallel(func(pb *testing.PB) {
  17. for pb.Next() {
  18. m.Mark(1)
  19. }
  20. })
  21. }
  22. func TestGetOrRegisterMeter(t *testing.T) {
  23. r := NewRegistry()
  24. NewRegisteredMeter("foo", r).Mark(47)
  25. if m := GetOrRegisterMeter("foo", r); 47 != m.Count() {
  26. t.Fatal(m)
  27. }
  28. }
  29. func TestMeterDecay(t *testing.T) {
  30. ma := meterArbiter{
  31. ticker: time.NewTicker(time.Millisecond),
  32. meters: make(map[*StandardMeter]struct{}),
  33. }
  34. m := newStandardMeter()
  35. ma.meters[m] = struct{}{}
  36. go ma.tick()
  37. m.Mark(1)
  38. rateMean := m.RateMean()
  39. time.Sleep(100 * time.Millisecond)
  40. if m.RateMean() >= rateMean {
  41. t.Error("m.RateMean() didn't decrease")
  42. }
  43. }
  44. func TestMeterNonzero(t *testing.T) {
  45. m := NewMeter()
  46. m.Mark(3)
  47. if count := m.Count(); 3 != count {
  48. t.Errorf("m.Count(): 3 != %v\n", count)
  49. }
  50. }
  51. func TestMeterStop(t *testing.T) {
  52. l := len(arbiter.meters)
  53. m := NewMeter()
  54. if len(arbiter.meters) != l+1 {
  55. t.Errorf("arbiter.meters: %d != %d\n", l+1, len(arbiter.meters))
  56. }
  57. m.Stop()
  58. if len(arbiter.meters) != l {
  59. t.Errorf("arbiter.meters: %d != %d\n", l, len(arbiter.meters))
  60. }
  61. }
  62. func TestMeterSnapshot(t *testing.T) {
  63. m := NewMeter()
  64. m.Mark(1)
  65. if snapshot := m.Snapshot(); m.RateMean() != snapshot.RateMean() {
  66. t.Fatal(snapshot)
  67. }
  68. }
  69. func TestMeterZero(t *testing.T) {
  70. m := NewMeter()
  71. if count := m.Count(); 0 != count {
  72. t.Errorf("m.Count(): 0 != %v\n", count)
  73. }
  74. }