| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- package sqlstore
- import (
- "context"
- "testing"
- "time"
- "github.com/grafana/grafana/pkg/components/simplejson"
- m "github.com/grafana/grafana/pkg/models"
- . "github.com/smartystreets/goconvey/convey"
- )
- func TestAlertNotificationSQLAccess(t *testing.T) {
- Convey("Testing Alert notification sql access", t, func() {
- InitTestDB(t)
- Convey("Alert notification journal", func() {
- var alertId int64 = 7
- var orgId int64 = 5
- var notifierId int64 = 10
- Convey("Getting last journal should raise error if no one exists", func() {
- query := &m.GetLatestNotificationQuery{AlertId: alertId, OrgId: orgId, NotifierId: notifierId}
- GetLatestNotification(context.Background(), query)
- So(len(query.Result), ShouldEqual, 0)
- // recording an journal entry in another org to make sure org filter works as expected.
- journalInOtherOrg := &m.RecordNotificationJournalCommand{AlertId: alertId, NotifierId: notifierId, OrgId: 10, Success: true, SentAt: 1}
- err := RecordNotificationJournal(context.Background(), journalInOtherOrg)
- So(err, ShouldBeNil)
- Convey("should be able to record two journaling events", func() {
- createCmd := &m.RecordNotificationJournalCommand{AlertId: alertId, NotifierId: notifierId, OrgId: orgId, Success: true, SentAt: 1}
- err := RecordNotificationJournal(context.Background(), createCmd)
- So(err, ShouldBeNil)
- createCmd.SentAt += 1000 //increase epoch
- err = RecordNotificationJournal(context.Background(), createCmd)
- So(err, ShouldBeNil)
- Convey("get last journaling event", func() {
- err := GetLatestNotification(context.Background(), query)
- So(err, ShouldBeNil)
- So(len(query.Result), ShouldEqual, 2)
- last := query.Result[0]
- So(last.SentAt, ShouldEqual, 1001)
- Convey("be able to clear all journaling for an notifier", func() {
- cmd := &m.CleanNotificationJournalCommand{AlertId: alertId, NotifierId: notifierId, OrgId: orgId}
- err := CleanNotificationJournal(context.Background(), cmd)
- So(err, ShouldBeNil)
- Convey("querying for last journaling should return no journal entries", func() {
- query := &m.GetLatestNotificationQuery{AlertId: alertId, OrgId: orgId, NotifierId: notifierId}
- err := GetLatestNotification(context.Background(), query)
- So(err, ShouldBeNil)
- So(len(query.Result), ShouldEqual, 0)
- })
- })
- })
- })
- })
- })
- Convey("Alert notifications should be empty", func() {
- cmd := &m.GetAlertNotificationsQuery{
- OrgId: 2,
- Name: "email",
- }
- err := GetAlertNotifications(cmd)
- So(err, ShouldBeNil)
- So(cmd.Result, ShouldBeNil)
- })
- Convey("Cannot save alert notifier with send reminder = true", func() {
- cmd := &m.CreateAlertNotificationCommand{
- Name: "ops",
- Type: "email",
- OrgId: 1,
- SendReminder: true,
- Settings: simplejson.New(),
- }
- Convey("and missing frequency", func() {
- err := CreateAlertNotificationCommand(cmd)
- So(err, ShouldEqual, m.ErrNotificationFrequencyNotFound)
- })
- Convey("invalid frequency", func() {
- cmd.Frequency = "invalid duration"
- err := CreateAlertNotificationCommand(cmd)
- So(err.Error(), ShouldEqual, "time: invalid duration invalid duration")
- })
- })
- Convey("Cannot update alert notifier with send reminder = false", func() {
- cmd := &m.CreateAlertNotificationCommand{
- Name: "ops update",
- Type: "email",
- OrgId: 1,
- SendReminder: false,
- Settings: simplejson.New(),
- }
- err := CreateAlertNotificationCommand(cmd)
- So(err, ShouldBeNil)
- updateCmd := &m.UpdateAlertNotificationCommand{
- Id: cmd.Result.Id,
- SendReminder: true,
- }
- Convey("and missing frequency", func() {
- err := UpdateAlertNotification(updateCmd)
- So(err, ShouldEqual, m.ErrNotificationFrequencyNotFound)
- })
- Convey("invalid frequency", func() {
- updateCmd.Frequency = "invalid duration"
- err := UpdateAlertNotification(updateCmd)
- So(err, ShouldNotBeNil)
- So(err.Error(), ShouldEqual, "time: invalid duration invalid duration")
- })
- })
- Convey("Can save Alert Notification", func() {
- cmd := &m.CreateAlertNotificationCommand{
- Name: "ops",
- Type: "email",
- OrgId: 1,
- SendReminder: true,
- Frequency: "10s",
- Settings: simplejson.New(),
- }
- err := CreateAlertNotificationCommand(cmd)
- So(err, ShouldBeNil)
- So(cmd.Result.Id, ShouldNotEqual, 0)
- So(cmd.Result.OrgId, ShouldNotEqual, 0)
- So(cmd.Result.Type, ShouldEqual, "email")
- So(cmd.Result.Frequency, ShouldEqual, 10*time.Second)
- Convey("Cannot save Alert Notification with the same name", func() {
- err = CreateAlertNotificationCommand(cmd)
- So(err, ShouldNotBeNil)
- })
- Convey("Can update alert notification", func() {
- newCmd := &m.UpdateAlertNotificationCommand{
- Name: "NewName",
- Type: "webhook",
- OrgId: cmd.Result.OrgId,
- SendReminder: true,
- Frequency: "60s",
- Settings: simplejson.New(),
- Id: cmd.Result.Id,
- }
- err := UpdateAlertNotification(newCmd)
- So(err, ShouldBeNil)
- So(newCmd.Result.Name, ShouldEqual, "NewName")
- So(newCmd.Result.Frequency, ShouldEqual, 60*time.Second)
- })
- Convey("Can update alert notification to disable sending of reminders", func() {
- newCmd := &m.UpdateAlertNotificationCommand{
- Name: "NewName",
- Type: "webhook",
- OrgId: cmd.Result.OrgId,
- SendReminder: false,
- Settings: simplejson.New(),
- Id: cmd.Result.Id,
- }
- err := UpdateAlertNotification(newCmd)
- So(err, ShouldBeNil)
- So(newCmd.Result.SendReminder, ShouldBeFalse)
- })
- })
- Convey("Can search using an array of ids", func() {
- cmd1 := m.CreateAlertNotificationCommand{Name: "nagios", Type: "webhook", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
- cmd2 := m.CreateAlertNotificationCommand{Name: "slack", Type: "webhook", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
- cmd3 := m.CreateAlertNotificationCommand{Name: "ops2", Type: "email", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
- cmd4 := m.CreateAlertNotificationCommand{IsDefault: true, Name: "default", Type: "email", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
- otherOrg := m.CreateAlertNotificationCommand{Name: "default", Type: "email", OrgId: 2, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
- So(CreateAlertNotificationCommand(&cmd1), ShouldBeNil)
- So(CreateAlertNotificationCommand(&cmd2), ShouldBeNil)
- So(CreateAlertNotificationCommand(&cmd3), ShouldBeNil)
- So(CreateAlertNotificationCommand(&cmd4), ShouldBeNil)
- So(CreateAlertNotificationCommand(&otherOrg), ShouldBeNil)
- Convey("search", func() {
- query := &m.GetAlertNotificationsToSendQuery{
- Ids: []int64{cmd1.Result.Id, cmd2.Result.Id, 112341231},
- OrgId: 1,
- }
- err := GetAlertNotificationsToSend(query)
- So(err, ShouldBeNil)
- So(len(query.Result), ShouldEqual, 3)
- })
- Convey("all", func() {
- query := &m.GetAllAlertNotificationsQuery{
- OrgId: 1,
- }
- err := GetAllAlertNotifications(query)
- So(err, ShouldBeNil)
- So(len(query.Result), ShouldEqual, 4)
- })
- })
- })
- }
|