2016-06-13 22:39:00 +08:00
|
|
|
package sqlstore
|
|
|
|
|
|
|
|
|
|
import (
|
2018-06-16 17:27:04 +08:00
|
|
|
"context"
|
2016-06-13 22:39:00 +08:00
|
|
|
"testing"
|
2018-08-25 01:09:19 +08:00
|
|
|
"time"
|
2016-06-13 22:39:00 +08:00
|
|
|
|
2016-06-14 22:56:14 +08:00
|
|
|
"github.com/grafana/grafana/pkg/components/simplejson"
|
2018-09-27 17:14:44 +08:00
|
|
|
"github.com/grafana/grafana/pkg/models"
|
2016-06-13 22:39:00 +08:00
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestAlertNotificationSQLAccess(t *testing.T) {
|
|
|
|
|
Convey("Testing Alert notification sql access", t, func() {
|
|
|
|
|
InitTestDB(t)
|
|
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
Convey("Alert notification state", func() {
|
2018-09-24 22:16:10 +08:00
|
|
|
var alertId int64 = 7
|
2018-06-16 17:27:04 +08:00
|
|
|
var orgId int64 = 5
|
2018-09-24 22:16:10 +08:00
|
|
|
var notifierId int64 = 10
|
2018-06-16 17:27:04 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
Convey("Getting no existant state returns error", func() {
|
|
|
|
|
query := &models.GetNotificationStateQuery{AlertId: alertId, OrgId: orgId, NotifierId: notifierId}
|
|
|
|
|
err := GetAlertNotificationState(context.Background(), query)
|
|
|
|
|
So(err, ShouldEqual, models.ErrAlertNotificationStateNotFound)
|
|
|
|
|
})
|
2018-06-16 17:27:04 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
Convey("Can insert new state for alert notifier", func() {
|
|
|
|
|
createCmd := &models.InsertAlertNotificationCommand{
|
|
|
|
|
AlertId: alertId,
|
|
|
|
|
NotifierId: notifierId,
|
|
|
|
|
OrgId: orgId,
|
|
|
|
|
SentAt: 1,
|
|
|
|
|
State: models.AlertNotificationStateCompleted,
|
|
|
|
|
}
|
2018-09-24 22:16:10 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
err := InsertAlertNotificationState(context.Background(), createCmd)
|
|
|
|
|
So(err, ShouldBeNil)
|
2018-06-16 17:27:04 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
err = InsertAlertNotificationState(context.Background(), createCmd)
|
2018-09-27 17:33:13 +08:00
|
|
|
So(err, ShouldEqual, models.ErrAlertNotificationStateAlreadyExist)
|
2018-06-16 17:27:04 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
Convey("should be able to update alert notifier state", func() {
|
2018-09-27 17:33:13 +08:00
|
|
|
updateCmd := &models.SetAlertNotificationStateToPendingCommand{
|
2018-09-27 17:14:44 +08:00
|
|
|
Id: 1,
|
|
|
|
|
SentAt: 1,
|
|
|
|
|
Version: 0,
|
|
|
|
|
}
|
2018-06-16 17:27:04 +08:00
|
|
|
|
2018-09-27 17:33:13 +08:00
|
|
|
err := SetAlertNotificationStateToPendingCommand(context.Background(), updateCmd)
|
2018-06-16 17:27:04 +08:00
|
|
|
So(err, ShouldBeNil)
|
2018-09-27 17:14:44 +08:00
|
|
|
|
2018-09-27 17:33:13 +08:00
|
|
|
Convey("should not be able to set pending on old version", func() {
|
|
|
|
|
err = SetAlertNotificationStateToPendingCommand(context.Background(), updateCmd)
|
2018-09-27 17:14:44 +08:00
|
|
|
So(err, ShouldEqual, models.ErrAlertNotificationStateVersionConflict)
|
|
|
|
|
})
|
2018-09-27 17:33:13 +08:00
|
|
|
|
|
|
|
|
Convey("should be able to set state to completed", func() {
|
|
|
|
|
cmd := &models.SetAlertNotificationStateToCompleteCommand{Id: 1}
|
|
|
|
|
err = SetAlertNotificationStateToCompleteCommand(context.Background(), cmd)
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
})
|
2018-06-16 17:27:04 +08:00
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
|
2016-06-13 22:39:00 +08:00
|
|
|
Convey("Alert notifications should be empty", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
cmd := &models.GetAlertNotificationsQuery{
|
2016-08-01 20:34:58 +08:00
|
|
|
OrgId: 2,
|
2016-06-13 22:39:00 +08:00
|
|
|
Name: "email",
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-01 20:34:58 +08:00
|
|
|
err := GetAlertNotifications(cmd)
|
2016-06-13 22:39:00 +08:00
|
|
|
So(err, ShouldBeNil)
|
2016-09-06 14:42:35 +08:00
|
|
|
So(cmd.Result, ShouldBeNil)
|
2016-06-13 22:39:00 +08:00
|
|
|
})
|
|
|
|
|
|
2018-06-05 16:27:29 +08:00
|
|
|
Convey("Cannot save alert notifier with send reminder = true", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
cmd := &models.CreateAlertNotificationCommand{
|
2018-06-05 16:27:29 +08:00
|
|
|
Name: "ops",
|
|
|
|
|
Type: "email",
|
|
|
|
|
OrgId: 1,
|
|
|
|
|
SendReminder: true,
|
|
|
|
|
Settings: simplejson.New(),
|
2018-06-05 04:19:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Convey("and missing frequency", func() {
|
|
|
|
|
err := CreateAlertNotificationCommand(cmd)
|
2018-09-27 17:14:44 +08:00
|
|
|
So(err, ShouldEqual, models.ErrNotificationFrequencyNotFound)
|
2018-06-05 04:19:27 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
Convey("invalid frequency", func() {
|
|
|
|
|
cmd.Frequency = "invalid duration"
|
|
|
|
|
|
|
|
|
|
err := CreateAlertNotificationCommand(cmd)
|
|
|
|
|
So(err.Error(), ShouldEqual, "time: invalid duration invalid duration")
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
|
2018-08-25 01:09:19 +08:00
|
|
|
Convey("Cannot update alert notifier with send reminder = false", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
cmd := &models.CreateAlertNotificationCommand{
|
2018-06-05 16:27:29 +08:00
|
|
|
Name: "ops update",
|
|
|
|
|
Type: "email",
|
|
|
|
|
OrgId: 1,
|
|
|
|
|
SendReminder: false,
|
|
|
|
|
Settings: simplejson.New(),
|
2018-06-05 04:19:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := CreateAlertNotificationCommand(cmd)
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
updateCmd := &models.UpdateAlertNotificationCommand{
|
2018-06-05 16:27:29 +08:00
|
|
|
Id: cmd.Result.Id,
|
|
|
|
|
SendReminder: true,
|
2018-06-05 04:19:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Convey("and missing frequency", func() {
|
|
|
|
|
err := UpdateAlertNotification(updateCmd)
|
2018-09-27 17:14:44 +08:00
|
|
|
So(err, ShouldEqual, models.ErrNotificationFrequencyNotFound)
|
2018-06-05 04:19:27 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
Convey("invalid frequency", func() {
|
|
|
|
|
updateCmd.Frequency = "invalid duration"
|
|
|
|
|
|
|
|
|
|
err := UpdateAlertNotification(updateCmd)
|
2018-06-05 16:27:29 +08:00
|
|
|
So(err, ShouldNotBeNil)
|
2018-06-05 04:19:27 +08:00
|
|
|
So(err.Error(), ShouldEqual, "time: invalid duration invalid duration")
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
|
2016-06-14 14:33:50 +08:00
|
|
|
Convey("Can save Alert Notification", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
cmd := &models.CreateAlertNotificationCommand{
|
2018-06-05 16:27:29 +08:00
|
|
|
Name: "ops",
|
|
|
|
|
Type: "email",
|
|
|
|
|
OrgId: 1,
|
|
|
|
|
SendReminder: true,
|
|
|
|
|
Frequency: "10s",
|
|
|
|
|
Settings: simplejson.New(),
|
2016-06-14 14:33:50 +08:00
|
|
|
}
|
|
|
|
|
|
2018-06-05 04:19:27 +08:00
|
|
|
err := CreateAlertNotificationCommand(cmd)
|
2016-06-14 14:33:50 +08:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
So(cmd.Result.Id, ShouldNotEqual, 0)
|
2016-06-14 22:56:14 +08:00
|
|
|
So(cmd.Result.OrgId, ShouldNotEqual, 0)
|
|
|
|
|
So(cmd.Result.Type, ShouldEqual, "email")
|
2018-08-25 01:09:19 +08:00
|
|
|
So(cmd.Result.Frequency, ShouldEqual, 10*time.Second)
|
2016-06-13 22:39:00 +08:00
|
|
|
|
2016-06-14 14:33:50 +08:00
|
|
|
Convey("Cannot save Alert Notification with the same name", func() {
|
|
|
|
|
err = CreateAlertNotificationCommand(cmd)
|
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
})
|
|
|
|
|
|
2016-06-14 22:56:14 +08:00
|
|
|
Convey("Can update alert notification", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
newCmd := &models.UpdateAlertNotificationCommand{
|
2018-06-05 16:27:29 +08:00
|
|
|
Name: "NewName",
|
|
|
|
|
Type: "webhook",
|
|
|
|
|
OrgId: cmd.Result.OrgId,
|
|
|
|
|
SendReminder: true,
|
2018-08-25 01:09:19 +08:00
|
|
|
Frequency: "60s",
|
2018-06-05 16:27:29 +08:00
|
|
|
Settings: simplejson.New(),
|
|
|
|
|
Id: cmd.Result.Id,
|
2016-06-14 14:33:50 +08:00
|
|
|
}
|
2016-06-14 22:56:14 +08:00
|
|
|
err := UpdateAlertNotification(newCmd)
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
So(newCmd.Result.Name, ShouldEqual, "NewName")
|
2018-08-25 01:09:19 +08:00
|
|
|
So(newCmd.Result.Frequency, ShouldEqual, 60*time.Second)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
Convey("Can update alert notification to disable sending of reminders", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
newCmd := &models.UpdateAlertNotificationCommand{
|
2018-08-25 01:09:19 +08:00
|
|
|
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)
|
2016-06-14 14:33:50 +08:00
|
|
|
})
|
2016-06-14 22:56:14 +08:00
|
|
|
})
|
2016-06-14 14:33:50 +08:00
|
|
|
|
2016-06-14 22:56:14 +08:00
|
|
|
Convey("Can search using an array of ids", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
cmd1 := models.CreateAlertNotificationCommand{Name: "nagios", Type: "webhook", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
|
|
|
|
|
cmd2 := models.CreateAlertNotificationCommand{Name: "slack", Type: "webhook", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
|
|
|
|
|
cmd3 := models.CreateAlertNotificationCommand{Name: "ops2", Type: "email", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
|
|
|
|
|
cmd4 := models.CreateAlertNotificationCommand{IsDefault: true, Name: "default", Type: "email", OrgId: 1, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
|
2016-06-20 21:24:48 +08:00
|
|
|
|
2018-09-27 17:14:44 +08:00
|
|
|
otherOrg := models.CreateAlertNotificationCommand{Name: "default", Type: "email", OrgId: 2, SendReminder: true, Frequency: "10s", Settings: simplejson.New()}
|
2016-09-06 14:42:35 +08:00
|
|
|
|
2016-08-01 20:34:58 +08:00
|
|
|
So(CreateAlertNotificationCommand(&cmd1), ShouldBeNil)
|
|
|
|
|
So(CreateAlertNotificationCommand(&cmd2), ShouldBeNil)
|
|
|
|
|
So(CreateAlertNotificationCommand(&cmd3), ShouldBeNil)
|
2016-09-06 03:33:05 +08:00
|
|
|
So(CreateAlertNotificationCommand(&cmd4), ShouldBeNil)
|
2016-09-06 14:42:35 +08:00
|
|
|
So(CreateAlertNotificationCommand(&otherOrg), ShouldBeNil)
|
2016-06-14 22:56:14 +08:00
|
|
|
|
|
|
|
|
Convey("search", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
query := &models.GetAlertNotificationsToSendQuery{
|
2016-08-01 20:34:58 +08:00
|
|
|
Ids: []int64{cmd1.Result.Id, cmd2.Result.Id, 112341231},
|
|
|
|
|
OrgId: 1,
|
2016-06-14 14:33:50 +08:00
|
|
|
}
|
2016-06-14 22:56:14 +08:00
|
|
|
|
2016-09-06 14:42:35 +08:00
|
|
|
err := GetAlertNotificationsToSend(query)
|
2016-06-13 22:39:00 +08:00
|
|
|
So(err, ShouldBeNil)
|
2016-09-06 03:33:05 +08:00
|
|
|
So(len(query.Result), ShouldEqual, 3)
|
2016-06-14 14:33:50 +08:00
|
|
|
})
|
2016-09-06 14:42:35 +08:00
|
|
|
|
|
|
|
|
Convey("all", func() {
|
2018-09-27 17:14:44 +08:00
|
|
|
query := &models.GetAllAlertNotificationsQuery{
|
2016-09-06 14:42:35 +08:00
|
|
|
OrgId: 1,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := GetAllAlertNotifications(query)
|
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
So(len(query.Result), ShouldEqual, 4)
|
|
|
|
|
})
|
2016-06-14 14:33:50 +08:00
|
|
|
})
|
2016-06-13 22:39:00 +08:00
|
|
|
})
|
|
|
|
|
}
|