histogram_test.go 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package metrics
  2. import "testing"
  3. func BenchmarkHistogram(b *testing.B) {
  4. h := NewHistogram(NewUniformSample(100))
  5. for i := 0; i < b.N; i++ {
  6. h.Update(1)
  7. }
  8. }
  9. func TestEmptyHistogram(t *testing.T) {
  10. h := NewHistogram(NewUniformSample(100))
  11. if count := h.Count(); 0 != count {
  12. t.Errorf("h.Count(): 0 != %v\n", count)
  13. }
  14. if min := h.Min(); 0 != min {
  15. t.Errorf("h.Min(): 0 != %v\n", min)
  16. }
  17. if max := h.Max(); 0 != max {
  18. t.Errorf("h.Max(): 0 != %v\n", max)
  19. }
  20. if mean := h.Mean(); 0.0 != mean {
  21. t.Errorf("h.Mean(): 0.0 != %v\n", mean)
  22. }
  23. if stdDev := h.StdDev(); 0.0 != stdDev {
  24. t.Errorf("h.StdDev(): 0.0 != %v\n", stdDev)
  25. }
  26. ps := h.Percentiles([]float64{0.5, 0.75, 0.99})
  27. if 0.0 != ps[0] {
  28. t.Errorf("median: 0.0 != %v\n", ps[0])
  29. }
  30. if 0.0 != ps[1] {
  31. t.Errorf("75th percentile: 0.0 != %v\n", ps[1])
  32. }
  33. if 0.0 != ps[2] {
  34. t.Errorf("99th percentile: 0.0 != %v\n", ps[2])
  35. }
  36. }
  37. func TestHistogram10000(t *testing.T) {
  38. h := NewHistogram(NewUniformSample(100000))
  39. for i := 1; i <= 10000; i++ {
  40. h.Update(int64(i))
  41. }
  42. if count := h.Count(); 10000 != count {
  43. t.Errorf("h.Count(): 10000 != %v\n", count)
  44. }
  45. if min := h.Min(); 1 != min {
  46. t.Errorf("h.Min(): 1 != %v\n", min)
  47. }
  48. if max := h.Max(); 10000 != max {
  49. t.Errorf("h.Max(): 10000 != %v\n", max)
  50. }
  51. if mean := h.Mean(); 5000.5 != mean {
  52. t.Errorf("h.Mean(): 5000.5 != %v\n", mean)
  53. }
  54. if stdDev := h.StdDev(); 2886.8956799071675 != stdDev {
  55. t.Errorf("h.StdDev(): 2886.8956799071675 != %v\n", stdDev)
  56. }
  57. ps := h.Percentiles([]float64{0.5, 0.75, 0.99})
  58. if 5000.5 != ps[0] {
  59. t.Errorf("median: 5000.5 != %v\n", ps[0])
  60. }
  61. if 7500.75 != ps[1] {
  62. t.Errorf("75th percentile: 7500.75 != %v\n", ps[1])
  63. }
  64. if 9900.99 != ps[2] {
  65. t.Errorf("99th percentile: 9900.99 != %v\n", ps[2])
  66. }
  67. }