Update kapacitor rule response to have empty arrays

Signed-off-by: Deniz Kusefoglu <denizk@gmail.com>
pull/10616/head
Chris Goller 2017-11-30 16:26:58 -06:00
parent 8821dd1c56
commit f728c24764
2 changed files with 119 additions and 18 deletions

View File

@ -358,26 +358,111 @@ func newAlertResponse(task *kapa.Task, srcID, kapaID int) *alertResponse {
},
}
if res.Alerts == nil {
res.Alerts = make([]string, 0)
if res.AlertHandlers.Alerta == nil {
res.AlertHandlers.Alerta = []*chronograf.Alerta{}
}
if res.AlertNodes == nil {
res.AlertNodes = make([]chronograf.KapacitorNode, 0)
for i, a := range res.AlertHandlers.Alerta {
if a.Service == nil {
a.Service = []string{}
res.AlertHandlers.Alerta[i] = a
}
}
for _, n := range res.AlertNodes {
if n.Args == nil {
n.Args = make([]string, 0)
if res.AlertHandlers.Email == nil {
res.AlertHandlers.Email = []*chronograf.Email{}
}
if n.Properties == nil {
n.Properties = make([]chronograf.KapacitorProperty, 0)
}
for _, p := range n.Properties {
if p.Args == nil {
p.Args = make([]string, 0)
for i, a := range res.AlertHandlers.Email {
if a.To == nil {
a.To = []string{}
res.AlertHandlers.Email[i] = a
}
}
if res.AlertHandlers.Exec == nil {
res.AlertHandlers.Exec = []*chronograf.Exec{}
}
for i, a := range res.AlertHandlers.Exec {
if a.Command == nil {
a.Command = []string{}
res.AlertHandlers.Exec[i] = a
}
}
if res.AlertHandlers.HipChat == nil {
res.AlertHandlers.HipChat = []*chronograf.HipChat{}
}
if res.AlertHandlers.Log == nil {
res.AlertHandlers.Log = []*chronograf.Log{}
}
if res.AlertHandlers.OpsGenie == nil {
res.AlertHandlers.OpsGenie = []*chronograf.OpsGenie{}
}
for i, a := range res.AlertHandlers.OpsGenie {
if a.Teams == nil {
a.Teams = []string{}
res.AlertHandlers.OpsGenie[i] = a
}
if a.Recipients == nil {
a.Recipients = []string{}
res.AlertHandlers.OpsGenie[i] = a
}
}
if res.AlertHandlers.PagerDuty == nil {
res.AlertHandlers.PagerDuty = []*chronograf.PagerDuty{}
}
if res.AlertHandlers.Posts == nil {
res.AlertHandlers.Posts = []*chronograf.Post{}
}
for i, a := range res.AlertHandlers.Posts {
if a.Headers == nil {
a.Headers = map[string]string{}
res.AlertHandlers.Posts[i] = a
}
}
if res.AlertHandlers.Pushover == nil {
res.AlertHandlers.Pushover = []*chronograf.Pushover{}
}
if res.AlertHandlers.Sensu == nil {
res.AlertHandlers.Sensu = []*chronograf.Sensu{}
}
for i, a := range res.AlertHandlers.Sensu {
if a.Handlers == nil {
a.Handlers = []string{}
res.AlertHandlers.Sensu[i] = a
}
}
if res.AlertHandlers.Slack == nil {
res.AlertHandlers.Slack = []*chronograf.Slack{}
}
if res.AlertHandlers.Talk == nil {
res.AlertHandlers.Talk = []*chronograf.Talk{}
}
if res.AlertHandlers.TCPs == nil {
res.AlertHandlers.TCPs = []*chronograf.TCP{}
}
if res.AlertHandlers.Telegram == nil {
res.AlertHandlers.Telegram = []*chronograf.Telegram{}
}
if res.AlertHandlers.VictorOps == nil {
res.AlertHandlers.VictorOps = []*chronograf.VictorOps{}
}
if res.Query != nil {

View File

@ -94,9 +94,9 @@ func Test_KapacitorRulesGet(t *testing.T) {
expected []chronograf.AlertRule
}{
{
"basic",
"/chronograf/v1/sources/1/kapacitors/1/rules",
[]chronograf.AlertRule{
name: "basic",
requestPath: "/chronograf/v1/sources/1/kapacitors/1/rules",
mockAlerts: []chronograf.AlertRule{
{
ID: "cpu_alert",
Name: "cpu_alert",
@ -106,15 +106,31 @@ func Test_KapacitorRulesGet(t *testing.T) {
TICKScript: tickScript,
},
},
[]chronograf.AlertRule{
expected: []chronograf.AlertRule{
{
ID: "cpu_alert",
Name: "cpu_alert",
Status: "enabled",
Type: "stream",
DBRPs: []chronograf.DBRP{{DB: "telegraf", RP: "autogen"}},
Alerts: []string{},
TICKScript: tickScript,
AlertHandlers: chronograf.AlertHandlers{
Posts: []*chronograf.Post{},
TCPs: []*chronograf.TCP{},
Email: []*chronograf.Email{},
Exec: []*chronograf.Exec{},
Log: []*chronograf.Log{},
VictorOps: []*chronograf.VictorOps{},
PagerDuty: []*chronograf.PagerDuty{},
Pushover: []*chronograf.Pushover{},
Sensu: []*chronograf.Sensu{},
Slack: []*chronograf.Slack{},
Telegram: []*chronograf.Telegram{},
HipChat: []*chronograf.HipChat{},
Alerta: []*chronograf.Alerta{},
OpsGenie: []*chronograf.OpsGenie{},
Talk: []*chronograf.Talk{},
},
},
},
},