executor_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package alerting
  2. import (
  3. "testing"
  4. "github.com/grafana/grafana/pkg/services/alerting/alertstates"
  5. "github.com/grafana/grafana/pkg/tsdb"
  6. . "github.com/smartystreets/goconvey/convey"
  7. )
  8. func TestAlertingExecutor(t *testing.T) {
  9. Convey("Test alert execution", t, func() {
  10. executor := &ExecutorImpl{}
  11. Convey("single time serie", func() {
  12. Convey("Show return ok since avg is above 2", func() {
  13. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "sum"}
  14. timeSeries := []*tsdb.TimeSeries{
  15. tsdb.NewTimeSeries("test1", [][2]float64{{2, 0}}),
  16. }
  17. result := executor.evaluateRule(rule, timeSeries)
  18. So(result.State, ShouldEqual, alertstates.Ok)
  19. })
  20. Convey("Show return critical since below 2", func() {
  21. rule := &AlertRule{CritLevel: 10, CritOperator: "<", Aggregator: "sum"}
  22. timeSeries := []*tsdb.TimeSeries{
  23. tsdb.NewTimeSeries("test1", [][2]float64{{2, 0}}),
  24. }
  25. result := executor.evaluateRule(rule, timeSeries)
  26. So(result.State, ShouldEqual, alertstates.Critical)
  27. })
  28. Convey("Show return critical since sum is above 10", func() {
  29. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "sum"}
  30. timeSeries := []*tsdb.TimeSeries{
  31. tsdb.NewTimeSeries("test1", [][2]float64{{9, 0}, {9, 0}}),
  32. }
  33. result := executor.evaluateRule(rule, timeSeries)
  34. So(result.State, ShouldEqual, alertstates.Critical)
  35. })
  36. Convey("Show return ok since avg is below 10", func() {
  37. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "avg"}
  38. timeSeries := []*tsdb.TimeSeries{
  39. tsdb.NewTimeSeries("test1", [][2]float64{{9, 0}, {9, 0}}),
  40. }
  41. result := executor.evaluateRule(rule, timeSeries)
  42. So(result.State, ShouldEqual, alertstates.Ok)
  43. })
  44. Convey("Show return ok since min is below 10", func() {
  45. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "min"}
  46. timeSeries := []*tsdb.TimeSeries{
  47. tsdb.NewTimeSeries("test1", [][2]float64{{11, 0}, {9, 0}}),
  48. }
  49. result := executor.evaluateRule(rule, timeSeries)
  50. So(result.State, ShouldEqual, alertstates.Ok)
  51. })
  52. Convey("Show return ok since max is above 10", func() {
  53. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "max"}
  54. timeSeries := []*tsdb.TimeSeries{
  55. tsdb.NewTimeSeries("test1", [][2]float64{{1, 0}, {11, 0}}),
  56. }
  57. result := executor.evaluateRule(rule, timeSeries)
  58. So(result.State, ShouldEqual, alertstates.Critical)
  59. })
  60. })
  61. Convey("muliple time series", func() {
  62. Convey("both are ok", func() {
  63. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "sum"}
  64. timeSeries := []*tsdb.TimeSeries{
  65. tsdb.NewTimeSeries("test1", [][2]float64{{2, 0}}),
  66. tsdb.NewTimeSeries("test1", [][2]float64{{2, 0}}),
  67. }
  68. result := executor.evaluateRule(rule, timeSeries)
  69. So(result.State, ShouldEqual, alertstates.Ok)
  70. })
  71. Convey("first serie is good, second is critical", func() {
  72. rule := &AlertRule{CritLevel: 10, CritOperator: ">", Aggregator: "sum"}
  73. timeSeries := []*tsdb.TimeSeries{
  74. tsdb.NewTimeSeries("test1", [][2]float64{{2, 0}}),
  75. tsdb.NewTimeSeries("test1", [][2]float64{{11, 0}}),
  76. }
  77. result := executor.evaluateRule(rule, timeSeries)
  78. So(result.State, ShouldEqual, alertstates.Critical)
  79. })
  80. })
  81. })
  82. }