mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
WebhookNotifier: Convert tests away from goconvey (#29291)
Signed-off-by: Arve Knudsen <arve.knudsen@gmail.com>
This commit is contained in:
parent
81859880d3
commit
063f863abc
@ -5,47 +5,43 @@ import (
|
||||
|
||||
"github.com/grafana/grafana/pkg/components/simplejson"
|
||||
"github.com/grafana/grafana/pkg/models"
|
||||
. "github.com/smartystreets/goconvey/convey"
|
||||
"github.com/stretchr/testify/assert"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestWebhookNotifier(t *testing.T) {
|
||||
Convey("Webhook notifier tests", t, func() {
|
||||
Convey("Parsing alert notification from settings", func() {
|
||||
Convey("empty settings should return error", func() {
|
||||
json := `{ }`
|
||||
func TestWebhookNotifier_parsingFromSettings(t *testing.T) {
|
||||
t.Run("Empty settings should cause error", func(t *testing.T) {
|
||||
const json = `{}`
|
||||
|
||||
settingsJSON, _ := simplejson.NewJson([]byte(json))
|
||||
model := &models.AlertNotification{
|
||||
Name: "ops",
|
||||
Type: "webhook",
|
||||
Settings: settingsJSON,
|
||||
}
|
||||
settingsJSON, err := simplejson.NewJson([]byte(json))
|
||||
require.NoError(t, err)
|
||||
model := &models.AlertNotification{
|
||||
Name: "ops",
|
||||
Type: "webhook",
|
||||
Settings: settingsJSON,
|
||||
}
|
||||
|
||||
_, err := NewWebHookNotifier(model)
|
||||
So(err, ShouldNotBeNil)
|
||||
})
|
||||
_, err = NewWebHookNotifier(model)
|
||||
require.Error(t, err)
|
||||
})
|
||||
|
||||
Convey("from settings", func() {
|
||||
json := `
|
||||
{
|
||||
"url": "http://google.com"
|
||||
}`
|
||||
t.Run("Valid settings should result in a valid notifier", func(t *testing.T) {
|
||||
const json = `{"url": "http://google.com"}`
|
||||
|
||||
settingsJSON, _ := simplejson.NewJson([]byte(json))
|
||||
model := &models.AlertNotification{
|
||||
Name: "ops",
|
||||
Type: "webhook",
|
||||
Settings: settingsJSON,
|
||||
}
|
||||
settingsJSON, err := simplejson.NewJson([]byte(json))
|
||||
require.NoError(t, err)
|
||||
model := &models.AlertNotification{
|
||||
Name: "ops",
|
||||
Type: "webhook",
|
||||
Settings: settingsJSON,
|
||||
}
|
||||
|
||||
not, err := NewWebHookNotifier(model)
|
||||
webhookNotifier := not.(*WebhookNotifier)
|
||||
not, err := NewWebHookNotifier(model)
|
||||
require.NoError(t, err)
|
||||
webhookNotifier := not.(*WebhookNotifier)
|
||||
|
||||
So(err, ShouldBeNil)
|
||||
So(webhookNotifier.Name, ShouldEqual, "ops")
|
||||
So(webhookNotifier.Type, ShouldEqual, "webhook")
|
||||
So(webhookNotifier.URL, ShouldEqual, "http://google.com")
|
||||
})
|
||||
})
|
||||
assert.Equal(t, "ops", webhookNotifier.Name)
|
||||
assert.Equal(t, "webhook", webhookNotifier.Type)
|
||||
assert.Equal(t, "http://google.com", webhookNotifier.URL)
|
||||
})
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user