2016-08-10 06:48:44 -05:00
|
|
|
package conditions
|
|
|
|
|
|
|
|
import (
|
2020-02-10 18:28:07 -06:00
|
|
|
"math"
|
2016-08-10 06:48:44 -05:00
|
|
|
"testing"
|
|
|
|
|
2017-01-13 05:32:30 -06:00
|
|
|
"github.com/grafana/grafana/pkg/components/null"
|
2021-11-10 04:52:16 -06:00
|
|
|
"github.com/grafana/grafana/pkg/tsdb/legacydata"
|
2021-10-26 16:24:58 -05:00
|
|
|
"github.com/stretchr/testify/require"
|
2016-08-10 06:48:44 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSimpleReducer(t *testing.T) {
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("sum", func(t *testing.T) {
|
|
|
|
result := testReducer("sum", 1, 2, 3)
|
|
|
|
require.Equal(t, float64(6), result)
|
|
|
|
})
|
2016-08-10 07:06:17 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("min", func(t *testing.T) {
|
|
|
|
result := testReducer("min", 3, 2, 1)
|
|
|
|
require.Equal(t, float64(1), result)
|
|
|
|
})
|
2016-08-10 07:06:17 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("max", func(t *testing.T) {
|
|
|
|
result := testReducer("max", 1, 2, 3)
|
|
|
|
require.Equal(t, float64(3), result)
|
|
|
|
})
|
2016-08-10 07:06:17 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("count", func(t *testing.T) {
|
|
|
|
result := testReducer("count", 1, 2, 3000)
|
|
|
|
require.Equal(t, float64(3), result)
|
|
|
|
})
|
2016-11-07 19:28:30 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("last", func(t *testing.T) {
|
|
|
|
result := testReducer("last", 1, 2, 3000)
|
|
|
|
require.Equal(t, float64(3000), result)
|
|
|
|
})
|
2016-11-07 19:28:30 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("median odd amount of numbers", func(t *testing.T) {
|
|
|
|
result := testReducer("median", 1, 2, 3000)
|
|
|
|
require.Equal(t, float64(2), result)
|
|
|
|
})
|
2016-11-22 07:09:19 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("median even amount of numbers", func(t *testing.T) {
|
|
|
|
result := testReducer("median", 1, 2, 4, 3000)
|
|
|
|
require.Equal(t, float64(3), result)
|
|
|
|
})
|
2016-11-22 07:09:19 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("median with one values", func(t *testing.T) {
|
|
|
|
result := testReducer("median", 1)
|
|
|
|
require.Equal(t, float64(1), result)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("median should ignore null values", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("median")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(3)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(float64(1)), null.FloatFrom(4)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(float64(2)), null.FloatFrom(5)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(float64(3)), null.FloatFrom(6)})
|
2021-10-26 16:24:58 -05:00
|
|
|
|
|
|
|
result := reducer.Reduce(series)
|
|
|
|
require.Equal(t, true, result.Valid)
|
|
|
|
require.Equal(t, float64(2), result.Float64)
|
|
|
|
})
|
2016-12-07 08:19:58 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("avg", func(t *testing.T) {
|
|
|
|
result := testReducer("avg", 1, 2, 3)
|
|
|
|
require.Equal(t, float64(2), result)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("avg with only nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("avg")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("count_non_null", func(t *testing.T) {
|
|
|
|
t.Run("with null values and real values", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("count_non_null")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2020-02-27 13:25:03 -06:00
|
|
|
Name: "test time series",
|
2018-11-05 02:03:35 -06:00
|
|
|
}
|
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(3), null.FloatFrom(3)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(3), null.FloatFrom(4)})
|
2018-11-05 02:03:35 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, true, reducer.Reduce(series).Valid)
|
|
|
|
require.Equal(t, 2.0, reducer.Reduce(series).Float64)
|
2016-12-07 08:19:58 -06:00
|
|
|
})
|
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("with null values", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("count_non_null")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2020-02-27 13:25:03 -06:00
|
|
|
Name: "test time series",
|
2017-01-13 05:32:30 -06:00
|
|
|
}
|
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
2017-01-13 05:32:30 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
2017-10-13 02:46:18 -05:00
|
|
|
})
|
2021-10-26 16:24:58 -05:00
|
|
|
})
|
2017-10-13 02:46:18 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("avg of number values and null values should ignore nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("avg")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
2016-12-07 08:19:58 -06:00
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(3), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(3)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(3), null.FloatFrom(4)})
|
2016-12-07 08:19:58 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, float64(3), reducer.Reduce(series).Float64)
|
|
|
|
})
|
2017-09-29 04:20:02 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
// diff function Test Suite
|
|
|
|
t.Run("diff of one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", 30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2018-07-08 23:58:34 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", -30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of two positive points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", 30, 40)
|
|
|
|
require.Equal(t, float64(10), result)
|
|
|
|
})
|
2017-09-29 04:20:02 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of two positive points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", 30, 20)
|
|
|
|
require.Equal(t, float64(-10), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of two negative points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", -30, -40)
|
|
|
|
require.Equal(t, float64(-10), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of two negative points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", -30, -10)
|
|
|
|
require.Equal(t, float64(20), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of one positive and one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", 30, -40)
|
|
|
|
require.Equal(t, float64(-70), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of one negative and one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", -30, 40)
|
|
|
|
require.Equal(t, float64(70), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of three positive points", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", 30, 40, 50)
|
|
|
|
require.Equal(t, float64(20), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff of three negative points", func(t *testing.T) {
|
|
|
|
result := testReducer("diff", -30, -40, -50)
|
|
|
|
require.Equal(t, float64(-20), result)
|
|
|
|
})
|
2018-07-08 23:58:34 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff with only nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("diff")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
// diff_abs function Test Suite
|
|
|
|
t.Run("diff_abs of one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", 30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", -30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of two positive points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", 30, 40)
|
|
|
|
require.Equal(t, float64(10), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of two positive points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", 30, 20)
|
|
|
|
require.Equal(t, float64(10), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of two negative points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", -30, -40)
|
|
|
|
require.Equal(t, float64(10), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of two negative points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", -30, -10)
|
|
|
|
require.Equal(t, float64(20), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of one positive and one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", 30, -40)
|
|
|
|
require.Equal(t, float64(70), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of one negative and one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", -30, 40)
|
|
|
|
require.Equal(t, float64(70), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of three positive points", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", 30, 40, 50)
|
|
|
|
require.Equal(t, float64(20), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs of three negative points", func(t *testing.T) {
|
|
|
|
result := testReducer("diff_abs", -30, -40, -50)
|
|
|
|
require.Equal(t, float64(20), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("diff_abs with only nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("diff_abs")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
2019-02-14 14:52:59 -06:00
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
2019-02-14 14:52:59 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
|
|
|
})
|
2019-02-14 14:52:59 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
// percent_diff function Test Suite
|
|
|
|
t.Run("percent_diff of one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", 30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2018-07-08 23:58:34 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", -30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of two positive points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", 30, 40)
|
|
|
|
require.Equal(t, float64(33.33333333333333), result)
|
|
|
|
})
|
2017-09-29 04:20:02 -05:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of two positive points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", 30, 20)
|
|
|
|
require.Equal(t, float64(-33.33333333333333), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of two negative points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", -30, -40)
|
|
|
|
require.Equal(t, float64(-33.33333333333333), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of two negative points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", -30, -10)
|
|
|
|
require.Equal(t, float64(66.66666666666666), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of one positive and one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", 30, -40)
|
|
|
|
require.Equal(t, float64(-233.33333333333334), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of one negative and one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", -30, 40)
|
|
|
|
require.Equal(t, float64(233.33333333333334), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of three positive points", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", 30, 40, 50)
|
|
|
|
require.Equal(t, float64(66.66666666666666), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff of three negative points", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff", -30, -40, -50)
|
|
|
|
require.Equal(t, float64(-66.66666666666666), result)
|
|
|
|
})
|
2019-02-14 09:31:15 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff with only nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("percent_diff")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
// percent_diff_abs function Test Suite
|
|
|
|
t.Run("percent_diff_abs_abs of one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", 30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", -30)
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of two positive points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", 30, 40)
|
|
|
|
require.Equal(t, float64(33.33333333333333), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of two positive points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", 30, 20)
|
|
|
|
require.Equal(t, float64(33.33333333333333), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of two negative points[1]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", -30, -40)
|
|
|
|
require.Equal(t, float64(33.33333333333333), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of two negative points[2]", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", -30, -10)
|
|
|
|
require.Equal(t, float64(66.66666666666666), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of one positive and one negative point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", 30, -40)
|
|
|
|
require.Equal(t, float64(233.33333333333334), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of one negative and one positive point", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", -30, 40)
|
|
|
|
require.Equal(t, float64(233.33333333333334), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of three positive points", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", 30, 40, 50)
|
|
|
|
require.Equal(t, float64(66.66666666666666), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs of three negative points", func(t *testing.T) {
|
|
|
|
result := testReducer("percent_diff_abs", -30, -40, -50)
|
|
|
|
require.Equal(t, float64(66.66666666666666), result)
|
|
|
|
})
|
2020-02-27 13:25:03 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("percent_diff_abs with only nulls", func(t *testing.T) {
|
|
|
|
reducer := newSimpleReducer("percent_diff_abs")
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2021-10-26 16:24:58 -05:00
|
|
|
Name: "test time series",
|
|
|
|
}
|
2019-02-14 09:31:15 -06:00
|
|
|
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(1)})
|
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFromPtr(nil), null.FloatFrom(2)})
|
2019-02-14 09:31:15 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
require.Equal(t, false, reducer.Reduce(series).Valid)
|
|
|
|
})
|
2020-02-10 18:28:07 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("min should work with NaNs", func(t *testing.T) {
|
|
|
|
result := testReducer("min", math.NaN(), math.NaN(), math.NaN())
|
|
|
|
require.Equal(t, float64(0), result)
|
|
|
|
})
|
2020-02-10 18:28:07 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("isValid should treat NaN as invalid", func(t *testing.T) {
|
|
|
|
result := isValid(null.FloatFrom(math.NaN()))
|
|
|
|
require.False(t, result)
|
|
|
|
})
|
2020-02-10 18:28:07 -06:00
|
|
|
|
2021-10-26 16:24:58 -05:00
|
|
|
t.Run("isValid should treat invalid null.Float as invalid", func(t *testing.T) {
|
|
|
|
result := isValid(null.FloatFromPtr(nil))
|
|
|
|
require.False(t, result)
|
2016-08-10 06:48:44 -05:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-06-03 03:25:58 -05:00
|
|
|
func testReducer(reducerType string, datapoints ...float64) float64 {
|
|
|
|
reducer := newSimpleReducer(reducerType)
|
2021-11-10 04:52:16 -06:00
|
|
|
series := legacydata.DataTimeSeries{
|
2020-02-27 13:25:03 -06:00
|
|
|
Name: "test time series",
|
2016-09-28 02:15:48 -05:00
|
|
|
}
|
2016-08-10 06:48:44 -05:00
|
|
|
|
2016-09-07 10:05:41 -05:00
|
|
|
for idx := range datapoints {
|
2021-11-10 04:52:16 -06:00
|
|
|
series.Points = append(series.Points, legacydata.DataTimePoint{null.FloatFrom(datapoints[idx]), null.FloatFrom(1234134)})
|
2016-08-10 06:48:44 -05:00
|
|
|
}
|
|
|
|
|
2016-09-28 02:15:48 -05:00
|
|
|
return reducer.Reduce(series).Float64
|
2016-08-10 06:48:44 -05:00
|
|
|
}
|