alert_rule_changes_test.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package sqlstore
  2. import (
  3. "testing"
  4. m "github.com/grafana/grafana/pkg/models"
  5. . "github.com/smartystreets/goconvey/convey"
  6. )
  7. var (
  8. FakeOrgId int64 = 2
  9. )
  10. func TestAlertRuleChangesDataAccess(t *testing.T) {
  11. Convey("Testing Alert rule changes data access", t, func() {
  12. InitTestDB(t)
  13. testDash := insertTestDashboard("dashboard with alerts", 2, "alert")
  14. var err error
  15. Convey("When dashboard is removed", func() {
  16. items := []*m.AlertRule{
  17. {
  18. PanelId: 1,
  19. DashboardId: testDash.Id,
  20. Query: "Query",
  21. QueryRefId: "A",
  22. WarnLevel: 30,
  23. CritLevel: 50,
  24. WarnOperator: ">",
  25. CritOperator: ">",
  26. Frequency: 10,
  27. Name: "Alerting title",
  28. Description: "Alerting description",
  29. QueryRange: 3600,
  30. Aggregator: "avg",
  31. OrgId: FakeOrgId,
  32. },
  33. }
  34. cmd := m.SaveAlertsCommand{
  35. Alerts: items,
  36. DashboardId: testDash.Id,
  37. OrgId: FakeOrgId,
  38. UserId: 2,
  39. }
  40. SaveAlerts(&cmd)
  41. er := GetAlertRuleChanges(query)
  42. So(er, ShouldBeNil)
  43. So(len(query.Result), ShouldEqual, 1)
  44. err = DeleteDashboard(&m.DeleteDashboardCommand{
  45. OrgId: FakeOrgId,
  46. Slug: testDash.Slug,
  47. })
  48. So(err, ShouldBeNil)
  49. Convey("Alerts should be removed", func() {
  50. query := m.GetAlertsQuery{DashboardId: testDash.Id, OrgId: 1}
  51. err2 := HandleAlertsQuery(&query)
  52. So(testDash.Id, ShouldEqual, 1)
  53. So(err2, ShouldBeNil)
  54. So(len(query.Result), ShouldEqual, 0)
  55. })
  56. Convey("should add one more alert_rule_change", func() {
  57. query := &m.GetAlertChangesQuery{OrgId: FakeOrgId}
  58. er := GetAlertRuleChanges(query)
  59. So(er, ShouldBeNil)
  60. So(len(query.Result), ShouldEqual, 2)
  61. })
  62. Convey("add 4 updates", func() {
  63. sess := x.NewSession()
  64. SaveAlertChange("UPDATED", items[0], sess)
  65. SaveAlertChange("UPDATED", items[0], sess)
  66. SaveAlertChange("UPDATED", items[0], sess)
  67. SaveAlertChange("UPDATED", items[0], sess)
  68. sess.Commit()
  69. Convey("query for max one change", func() {
  70. query := &m.GetAlertChangesQuery{OrgId: FakeOrgId, Limit: 1}
  71. er := GetAlertRuleChanges(query)
  72. So(er, ShouldBeNil)
  73. So(len(query.Result), ShouldEqual, 1)
  74. })
  75. Convey("query for all since id 5", func() {
  76. query := &m.GetAlertChangesQuery{OrgId: FakeOrgId, SinceId: 5}
  77. er := GetAlertRuleChanges(query)
  78. So(er, ShouldBeNil)
  79. So(len(query.Result), ShouldEqual, 2)
  80. })
  81. })
  82. })
  83. })
  84. }