meter_test.go 1.5 KB

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