Add test for deadman json pipeline conversion
parent
5eae7fb6dd
commit
6b6f725070
|
@ -147,3 +147,142 @@ alert4
|
||||||
t.Errorf("%s", diff.DiffPrettyText(delta))
|
t.Errorf("%s", diff.DiffPrettyText(delta))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
func TestPipelineJSONDeadman(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 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 = 'deadman'
|
||||||
|
|
||||||
|
var threshold = 0.0
|
||||||
|
|
||||||
|
var data = stream
|
||||||
|
|from()
|
||||||
|
.database(db)
|
||||||
|
.retentionPolicy(rp)
|
||||||
|
.measurement(measurement)
|
||||||
|
.groupBy(groupBy)
|
||||||
|
.where(whereFilter)
|
||||||
|
|
||||||
|
var trigger = data
|
||||||
|
|deadman(threshold, period)
|
||||||
|
.stateChangesOnly()
|
||||||
|
.message(message)
|
||||||
|
.id(idVar)
|
||||||
|
.idTag(idTag)
|
||||||
|
.levelTag(levelTag)
|
||||||
|
.messageField(messageField)
|
||||||
|
.durationField(durationField)
|
||||||
|
.slack()
|
||||||
|
.victorOps()
|
||||||
|
.email()
|
||||||
|
|
||||||
|
trigger
|
||||||
|
|eval(lambda: "emitted")
|
||||||
|
.as('value')
|
||||||
|
.keep('value', messageField, durationField)
|
||||||
|
|influxDBOut()
|
||||||
|
.create()
|
||||||
|
.database(outputDB)
|
||||||
|
.retentionPolicy(outputRP)
|
||||||
|
.measurement(outputMeasurement)
|
||||||
|
.tag('alertName', name)
|
||||||
|
.tag('triggerType', triggerType)
|
||||||
|
|
||||||
|
trigger
|
||||||
|
|httpOut('output')
|
||||||
|
`
|
||||||
|
|
||||||
|
want := `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
|
||||||
|
|httpOut('output')
|
||||||
|
|
||||||
|
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')
|
||||||
|
`
|
||||||
|
|
||||||
|
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))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue