Commit 063f863a by Arve Knudsen Committed by GitHub

WebhookNotifier: Convert tests away from goconvey (#29291)

Signed-off-by: Arve Knudsen <arve.knudsen@gmail.com>
parent 81859880
......@@ -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 := `{ }`
settingsJSON, _ := simplejson.NewJson([]byte(json))
model := &models.AlertNotification{
Name: "ops",
Type: "webhook",
Settings: settingsJSON,
}
_, err := NewWebHookNotifier(model)
So(err, ShouldNotBeNil)
})
Convey("from settings", func() {
json := `
{
"url": "http://google.com"
}`
settingsJSON, _ := simplejson.NewJson([]byte(json))
model := &models.AlertNotification{
Name: "ops",
Type: "webhook",
Settings: settingsJSON,
}
not, err := NewWebHookNotifier(model)
webhookNotifier := not.(*WebhookNotifier)
So(err, ShouldBeNil)
So(webhookNotifier.Name, ShouldEqual, "ops")
So(webhookNotifier.Type, ShouldEqual, "webhook")
So(webhookNotifier.URL, ShouldEqual, "http://google.com")
})
})
func TestWebhookNotifier_parsingFromSettings(t *testing.T) {
t.Run("Empty settings should cause error", func(t *testing.T) {
const json = `{}`
settingsJSON, err := simplejson.NewJson([]byte(json))
require.NoError(t, err)
model := &models.AlertNotification{
Name: "ops",
Type: "webhook",
Settings: settingsJSON,
}
_, err = NewWebHookNotifier(model)
require.Error(t, err)
})
t.Run("Valid settings should result in a valid notifier", func(t *testing.T) {
const json = `{"url": "http://google.com"}`
settingsJSON, err := simplejson.NewJson([]byte(json))
require.NoError(t, err)
model := &models.AlertNotification{
Name: "ops",
Type: "webhook",
Settings: settingsJSON,
}
not, err := NewWebHookNotifier(model)
require.NoError(t, err)
webhookNotifier := not.(*WebhookNotifier)
assert.Equal(t, "ops", webhookNotifier.Name)
assert.Equal(t, "webhook", webhookNotifier.Type)
assert.Equal(t, "http://google.com", webhookNotifier.URL)
})
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment