2017-11-07 05:25:41 +00:00
|
|
|
package kapacitor
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/sergi/go-diff/diffmatchpatch"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestPipelineJSON(t *testing.T) {
|
|
|
|
script := `var db = 'telegraf'
|
|
|
|
|
|
|
|
var rp = 'autogen'
|
|
|
|
|
|
|
|
var measurement = 'cpu'
|
|
|
|
|
|
|
|
var groupBy = ['host', 'cluster_id']
|
|
|
|
|
|
|
|
var whereFilter = lambda: ("cpu" == 'cpu_total') AND ("host" == 'acc-0eabc309-eu-west-1-data-3' OR "host" == 'prod')
|
|
|
|
|
|
|
|
var period = 10m
|
|
|
|
|
|
|
|
var every = 30s
|
|
|
|
|
|
|
|
var name = 'name'
|
|
|
|
|
|
|
|
var idVar = name + ':{{.Group}}'
|
|
|
|
|
|
|
|
var message = 'message'
|
|
|
|
|
|
|
|
var idTag = 'alertID'
|
|
|
|
|
|
|
|
var levelTag = 'level'
|
|
|
|
|
|
|
|
var messageField = 'message'
|
|
|
|
|
|
|
|
var durationField = 'duration'
|
|
|
|
|
|
|
|
var outputDB = 'chronograf'
|
|
|
|
|
|
|
|
var outputRP = 'autogen'
|
|
|
|
|
|
|
|
var outputMeasurement = 'alerts'
|
|
|
|
|
|
|
|
var triggerType = 'threshold'
|
|
|
|
|
|
|
|
var crit = 90
|
|
|
|
|
|
|
|
var data = stream
|
|
|
|
|from()
|
|
|
|
.database(db)
|
|
|
|
.retentionPolicy(rp)
|
|
|
|
.measurement(measurement)
|
|
|
|
.groupBy(groupBy)
|
|
|
|
.where(whereFilter)
|
|
|
|
|window()
|
|
|
|
.period(period)
|
|
|
|
.every(every)
|
|
|
|
.align()
|
|
|
|
|mean('usage_user')
|
|
|
|
.as('value')
|
|
|
|
|
|
|
|
var trigger = data
|
|
|
|
|alert()
|
|
|
|
.crit(lambda: "value" > crit)
|
|
|
|
.stateChangesOnly()
|
|
|
|
.message(message)
|
|
|
|
.id(idVar)
|
|
|
|
.idTag(idTag)
|
|
|
|
.levelTag(levelTag)
|
|
|
|
.messageField(messageField)
|
|
|
|
.durationField(durationField)
|
|
|
|
.slack()
|
|
|
|
.victorOps()
|
|
|
|
.email()
|
|
|
|
|
|
|
|
trigger
|
|
|
|
|influxDBOut()
|
|
|
|
.create()
|
|
|
|
.database(outputDB)
|
|
|
|
.retentionPolicy(outputRP)
|
|
|
|
.measurement(outputMeasurement)
|
|
|
|
.tag('alertName', name)
|
|
|
|
.tag('triggerType', triggerType)
|
|
|
|
|
|
|
|
trigger
|
|
|
|
|httpOut('output')
|
|
|
|
`
|
|
|
|
|
|
|
|
want := `var alert4 = stream
|
|
|
|
|from()
|
|
|
|
.database('telegraf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('cpu')
|
|
|
|
.where(lambda: "cpu" == 'cpu_total' AND "host" == 'acc-0eabc309-eu-west-1-data-3' OR "host" == 'prod')
|
|
|
|
.groupBy('host', 'cluster_id')
|
|
|
|
|window()
|
|
|
|
.period(10m)
|
|
|
|
.every(30s)
|
|
|
|
.align()
|
|
|
|
|mean('usage_user')
|
|
|
|
.as('value')
|
|
|
|
|alert()
|
|
|
|
.id('name:{{.Group}}')
|
|
|
|
.message('message')
|
|
|
|
.details('{{ json . }}')
|
|
|
|
.crit(lambda: "value" > 90)
|
|
|
|
.history(21)
|
|
|
|
.levelTag('level')
|
|
|
|
.messageField('message')
|
|
|
|
.durationField('duration')
|
|
|
|
.idTag('alertID')
|
|
|
|
.stateChangesOnly()
|
|
|
|
.email()
|
|
|
|
.victorOps()
|
|
|
|
.slack()
|
|
|
|
|
|
|
|
alert4
|
|
|
|
|httpOut('output')
|
|
|
|
|
|
|
|
alert4
|
|
|
|
|influxDBOut()
|
|
|
|
.database('chronograf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('alerts')
|
|
|
|
.buffer(1000)
|
|
|
|
.flushInterval(10s)
|
|
|
|
.create()
|
|
|
|
.tag('alertName', 'name')
|
|
|
|
.tag('triggerType', 'threshold')
|
|
|
|
`
|
|
|
|
|
|
|
|
octets, err := MarshalTICK(script)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("MarshalTICK unexpected error %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
got, err := UnmarshalTICK(octets)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("UnmarshalTICK unexpected error %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if got != want {
|
|
|
|
fmt.Println(got)
|
|
|
|
diff := diffmatchpatch.New()
|
|
|
|
delta := diff.DiffMain(want, got, true)
|
|
|
|
t.Errorf("%s", diff.DiffPrettyText(delta))
|
|
|
|
}
|
|
|
|
}
|
2017-11-17 21:56:32 +00:00
|
|
|
func TestPipelineJSONDeadman(t *testing.T) {
|
|
|
|
script := `var db = 'telegraf'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var rp = 'autogen'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var measurement = 'cpu'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var groupBy = ['host', 'cluster_id']
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var whereFilter = lambda: ("cpu" == 'cpu_total') AND ("host" == 'acc-0eabc309-eu-west-1-data-3' OR "host" == 'prod')
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var period = 10m
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var name = 'name'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var idVar = name + ':{{.Group}}'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var message = 'message'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var idTag = 'alertID'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var levelTag = 'level'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var messageField = 'message'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var durationField = 'duration'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var outputDB = 'chronograf'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var outputRP = 'autogen'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var outputMeasurement = 'alerts'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var triggerType = 'deadman'
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var threshold = 0.0
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var data = stream
|
|
|
|
|from()
|
|
|
|
.database(db)
|
|
|
|
.retentionPolicy(rp)
|
|
|
|
.measurement(measurement)
|
|
|
|
.groupBy(groupBy)
|
|
|
|
.where(whereFilter)
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
var trigger = data
|
|
|
|
|deadman(threshold, period)
|
|
|
|
.stateChangesOnly()
|
|
|
|
.message(message)
|
|
|
|
.id(idVar)
|
|
|
|
.idTag(idTag)
|
|
|
|
.levelTag(levelTag)
|
|
|
|
.messageField(messageField)
|
|
|
|
.durationField(durationField)
|
|
|
|
.slack()
|
|
|
|
.victorOps()
|
|
|
|
.email()
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
trigger
|
|
|
|
|eval(lambda: "emitted")
|
|
|
|
.as('value')
|
|
|
|
.keep('value', messageField, durationField)
|
|
|
|
|influxDBOut()
|
|
|
|
.create()
|
|
|
|
.database(outputDB)
|
|
|
|
.retentionPolicy(outputRP)
|
|
|
|
.measurement(outputMeasurement)
|
|
|
|
.tag('alertName', name)
|
|
|
|
.tag('triggerType', triggerType)
|
2017-12-06 00:33:44 +00:00
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
trigger
|
|
|
|
|httpOut('output')
|
|
|
|
`
|
|
|
|
|
2018-01-08 19:08:08 +00:00
|
|
|
wantA := `var from1 = stream
|
2017-11-17 21:56:32 +00:00
|
|
|
|from()
|
|
|
|
.database('telegraf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('cpu')
|
|
|
|
.where(lambda: "cpu" == 'cpu_total' AND "host" == 'acc-0eabc309-eu-west-1-data-3' OR "host" == 'prod')
|
|
|
|
.groupBy('host', 'cluster_id')
|
|
|
|
|
|
|
|
var alert5 = from1
|
|
|
|
|stats(10m)
|
|
|
|
.align()
|
|
|
|
|derivative('emitted')
|
|
|
|
.as('emitted')
|
|
|
|
.unit(10m)
|
|
|
|
.nonNegative()
|
|
|
|
|alert()
|
|
|
|
.id('name:{{.Group}}')
|
|
|
|
.message('message')
|
|
|
|
.details('{{ json . }}')
|
|
|
|
.crit(lambda: "emitted" <= 0.0)
|
|
|
|
.history(21)
|
|
|
|
.levelTag('level')
|
|
|
|
.messageField('message')
|
|
|
|
.durationField('duration')
|
|
|
|
.idTag('alertID')
|
|
|
|
.stateChangesOnly()
|
|
|
|
.email()
|
|
|
|
.victorOps()
|
|
|
|
.slack()
|
|
|
|
|
2017-12-06 00:45:53 +00:00
|
|
|
alert5
|
|
|
|
|httpOut('output')
|
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
alert5
|
|
|
|
|eval(lambda: "emitted")
|
|
|
|
.as('value')
|
|
|
|
.tags()
|
|
|
|
.keep('value', 'message', 'duration')
|
|
|
|
|influxDBOut()
|
|
|
|
.database('chronograf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('alerts')
|
|
|
|
.buffer(1000)
|
|
|
|
.flushInterval(10s)
|
|
|
|
.create()
|
|
|
|
.tag('alertName', 'name')
|
|
|
|
.tag('triggerType', 'deadman')
|
|
|
|
`
|
|
|
|
|
2018-01-08 19:08:08 +00:00
|
|
|
wantB := `var from1 = stream
|
|
|
|
|from()
|
|
|
|
.database('telegraf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('cpu')
|
|
|
|
.where(lambda: "cpu" == 'cpu_total' AND "host" == 'acc-0eabc309-eu-west-1-data-3' OR "host" == 'prod')
|
|
|
|
.groupBy('host', 'cluster_id')
|
|
|
|
|
|
|
|
var alert5 = from1
|
|
|
|
|stats(10m)
|
|
|
|
.align()
|
|
|
|
|derivative('emitted')
|
|
|
|
.as('emitted')
|
|
|
|
.unit(10m)
|
|
|
|
.nonNegative()
|
|
|
|
|alert()
|
|
|
|
.id('name:{{.Group}}')
|
|
|
|
.message('message')
|
|
|
|
.details('{{ json . }}')
|
|
|
|
.crit(lambda: "emitted" <= 0.0)
|
|
|
|
.history(21)
|
|
|
|
.levelTag('level')
|
|
|
|
.messageField('message')
|
|
|
|
.durationField('duration')
|
|
|
|
.idTag('alertID')
|
|
|
|
.stateChangesOnly()
|
|
|
|
.email()
|
|
|
|
.victorOps()
|
|
|
|
.slack()
|
|
|
|
|
|
|
|
alert5
|
|
|
|
|eval(lambda: "emitted")
|
|
|
|
.as('value')
|
|
|
|
.tags()
|
|
|
|
.keep('value', 'message', 'duration')
|
|
|
|
|influxDBOut()
|
|
|
|
.database('chronograf')
|
|
|
|
.retentionPolicy('autogen')
|
|
|
|
.measurement('alerts')
|
|
|
|
.buffer(1000)
|
|
|
|
.flushInterval(10s)
|
|
|
|
.create()
|
|
|
|
.tag('alertName', 'name')
|
|
|
|
.tag('triggerType', 'deadman')
|
|
|
|
|
|
|
|
alert5
|
|
|
|
|httpOut('output')
|
|
|
|
`
|
|
|
|
|
2017-11-17 21:56:32 +00:00
|
|
|
octets, err := MarshalTICK(script)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("MarshalTICK unexpected error %v", err)
|
|
|
|
}
|
|
|
|
got, err := UnmarshalTICK(octets)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("UnmarshalTICK unexpected error %v", err)
|
|
|
|
}
|
|
|
|
|
2018-01-08 19:08:08 +00:00
|
|
|
if got != wantA && got != wantB {
|
|
|
|
want := wantA
|
2017-12-06 00:45:53 +00:00
|
|
|
fmt.Println("got")
|
2017-11-17 21:56:32 +00:00
|
|
|
fmt.Println(got)
|
2017-12-06 00:45:53 +00:00
|
|
|
fmt.Println("want")
|
|
|
|
fmt.Println(want)
|
2017-11-17 21:56:32 +00:00
|
|
|
diff := diffmatchpatch.New()
|
|
|
|
delta := diff.DiffMain(want, got, true)
|
|
|
|
t.Errorf("%s", diff.DiffPrettyText(delta))
|
|
|
|
}
|
|
|
|
}
|