Commit 7c3dcb37 by bergquist

alerting: adds tests for the median reducer

adds a test that verify that null values are not used
when calculating the median value in alerting

closes #10056
parent 65ace003
...@@ -52,6 +52,24 @@ func TestSimpleReducer(t *testing.T) { ...@@ -52,6 +52,24 @@ func TestSimpleReducer(t *testing.T) {
So(result, ShouldEqual, float64(1)) So(result, ShouldEqual, float64(1))
}) })
Convey("median should ignore null values", func() {
reducer := NewSimpleReducer("median")
series := &tsdb.TimeSeries{
Name: "test time serie",
}
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFromPtr(nil), 1))
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFromPtr(nil), 2))
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFromPtr(nil), 3))
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFrom(float64(1)), 4))
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFrom(float64(2)), 5))
series.Points = append(series.Points, tsdb.NewTimePoint(null.FloatFrom(float64(3)), 6))
result := reducer.Reduce(series)
So(result.Valid, ShouldEqual, true)
So(result.Float64, ShouldEqual, float64(2))
})
Convey("avg", func() { Convey("avg", func() {
result := testReducer("avg", 1, 2, 3) result := testReducer("avg", 1, 2, 3)
So(result, ShouldEqual, float64(2)) So(result, ShouldEqual, float64(2))
......
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