iratemax_test.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. package aggregator
  2. import (
  3. "reflect"
  4. "testing"
  5. "time"
  6. )
  7. func TestIRateMaxAggregator_Value(t *testing.T) {
  8. time1 := time.Date(1, 1, 1, 0, 0, 0, 0, time.UTC)
  9. time2 := time.Date(1, 1, 1, 0, 0, 1, 0, time.UTC)
  10. time3 := time.Date(1, 1, 1, 0, 0, 2, 0, time.UTC)
  11. time4 := time.Date(1, 1, 1, 0, 0, 4, 0, time.UTC)
  12. type update struct {
  13. value float64
  14. timestamp time.Time
  15. additionalInformation map[string]string
  16. }
  17. tests := map[string]struct {
  18. updates []update
  19. want []MetricValue
  20. }{
  21. "no update": {
  22. updates: []update{},
  23. want: []MetricValue{
  24. {
  25. Value: 0,
  26. },
  27. },
  28. },
  29. "single update": {
  30. updates: []update{
  31. {
  32. value: 1,
  33. timestamp: time1,
  34. },
  35. },
  36. want: []MetricValue{
  37. {
  38. Value: 0,
  39. },
  40. },
  41. },
  42. "normal increase": {
  43. updates: []update{
  44. {
  45. value: 1,
  46. timestamp: time1,
  47. },
  48. {
  49. value: 2,
  50. timestamp: time2,
  51. },
  52. },
  53. want: []MetricValue{
  54. {
  55. Value: 1,
  56. },
  57. },
  58. },
  59. "multi increase": {
  60. updates: []update{
  61. {
  62. value: 1,
  63. timestamp: time1,
  64. },
  65. {
  66. value: 2,
  67. timestamp: time2,
  68. },
  69. {
  70. value: 4,
  71. timestamp: time3,
  72. },
  73. },
  74. want: []MetricValue{
  75. {
  76. Value: 2,
  77. },
  78. },
  79. },
  80. "aggregated increase": {
  81. updates: []update{
  82. {
  83. value: 1,
  84. timestamp: time1,
  85. },
  86. {
  87. value: 2,
  88. timestamp: time1,
  89. },
  90. {
  91. value: 3,
  92. timestamp: time2,
  93. },
  94. {
  95. value: 4,
  96. timestamp: time2,
  97. },
  98. },
  99. want: []MetricValue{
  100. {
  101. Value: 4,
  102. },
  103. },
  104. },
  105. "missing sample": {
  106. updates: []update{
  107. {
  108. value: 1,
  109. timestamp: time1,
  110. },
  111. {
  112. value: 3,
  113. timestamp: time2,
  114. },
  115. {
  116. value: 6,
  117. timestamp: time4,
  118. },
  119. },
  120. want: []MetricValue{
  121. {
  122. Value: 2,
  123. },
  124. },
  125. },
  126. "set restart": {
  127. updates: []update{
  128. {
  129. value: 3,
  130. timestamp: time1,
  131. },
  132. {
  133. value: 4,
  134. timestamp: time2,
  135. },
  136. {
  137. value: 1,
  138. timestamp: time3,
  139. },
  140. {
  141. value: 2,
  142. timestamp: time4,
  143. },
  144. },
  145. want: []MetricValue{
  146. {
  147. Value: 1,
  148. },
  149. },
  150. },
  151. }
  152. for name, tt := range tests {
  153. t.Run(name, func(t *testing.T) {
  154. agg := iRateMaxAggregator{}
  155. for _, u := range tt.updates {
  156. agg.Update(u.value, u.timestamp, u.additionalInformation)
  157. }
  158. got := agg.Value()
  159. if !reflect.DeepEqual(got, tt.want) {
  160. t.Errorf("got = %v, want %v", got, tt.want)
  161. }
  162. })
  163. }
  164. }