4114 lines
192 KiB
Go
4114 lines
192 KiB
Go
package query_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"math/rand"
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/davecgh/go-spew/spew"
|
|
"github.com/google/go-cmp/cmp"
|
|
"github.com/influxdata/influxdb/query"
|
|
"github.com/influxdata/influxql"
|
|
)
|
|
|
|
// Second represents a helper for type converting durations.
|
|
const Second = int64(time.Second)
|
|
|
|
func TestSelect(t *testing.T) {
|
|
for _, tt := range []struct {
|
|
name string
|
|
q string
|
|
typ influxql.DataType
|
|
expr string
|
|
itrs []query.Iterator
|
|
points [][]query.Point
|
|
err string
|
|
}{
|
|
{
|
|
name: "Min",
|
|
q: `SELECT min(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10, Aggregated: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Distinct_Float",
|
|
q: `SELECT distinct(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: 19},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Distinct_Integer",
|
|
q: `SELECT distinct(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: 19},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Distinct_Unsigned",
|
|
q: `SELECT distinct(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: 19},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Distinct_String",
|
|
q: `SELECT distinct(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: "a"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: "b"},
|
|
}},
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: "c"},
|
|
}},
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: "b"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: "d"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: "d"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: "d"},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: "a"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: "b"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: "d"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: "c"}},
|
|
},
|
|
},
|
|
{
|
|
name: "Distinct_Boolean",
|
|
q: `SELECT distinct(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: false},
|
|
}},
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: false},
|
|
}},
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: true},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: false}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mean_Float",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3.2, Aggregated: 5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mean_Integer",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
expr: `mean(value::integer)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3.2, Aggregated: 5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mean_Unsigned",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `mean(value::Unsigned)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3.2, Aggregated: 5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mean_String",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{&StringIterator{}},
|
|
err: `unsupported mean iterator type: *query_test.StringIterator`,
|
|
},
|
|
{
|
|
name: "Mean_Boolean",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{&BooleanIterator{}},
|
|
err: `unsupported mean iterator type: *query_test.BooleanIterator`,
|
|
},
|
|
{
|
|
name: "Median_Float",
|
|
q: `SELECT median(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Median_Integer",
|
|
q: `SELECT median(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Median_Unsigned",
|
|
q: `SELECT median(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Median_String",
|
|
q: `SELECT median(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{&StringIterator{}},
|
|
err: `unsupported median iterator type: *query_test.StringIterator`,
|
|
},
|
|
{
|
|
name: "Median_Boolean",
|
|
q: `SELECT median(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{&BooleanIterator{}},
|
|
err: `unsupported median iterator type: *query_test.BooleanIterator`,
|
|
},
|
|
{
|
|
name: "Mode_Float",
|
|
q: `SELECT mode(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mode_Integer",
|
|
q: `SELECT mode(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 54 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mode_Unsigned",
|
|
q: `SELECT mode(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 54 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mode_String",
|
|
q: `SELECT mode(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: "a"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: "a"},
|
|
}},
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: "cxxx"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 6 * Second, Value: "zzzz"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 7 * Second, Value: "zzzz"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 8 * Second, Value: "zxxx"},
|
|
}},
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: "b"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: "d"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: "d"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: "d"},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: "a"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: "d"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: "zzzz"}},
|
|
},
|
|
},
|
|
{
|
|
name: "Mode_Boolean",
|
|
q: `SELECT mode(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 2 * Second, Value: false},
|
|
}},
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 6 * Second, Value: false},
|
|
}},
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: true},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_NoTags_Float",
|
|
q: `SELECT top(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 9 * Second, Value: 19}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_NoTags_Integer",
|
|
q: `SELECT top(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 9 * Second, Value: 19}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 5}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_NoTags_Unsigned",
|
|
q: `SELECT top(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 9 * Second, Value: 19}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 5}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 53 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_Tags_Float",
|
|
q: `SELECT top(value::float, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `max(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 53 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_Tags_Integer",
|
|
q: `SELECT top(value::integer, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Integer,
|
|
expr: `max(value::integer)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 53 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_Tags_Unsigned",
|
|
q: `SELECT top(value::Unsigned, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `max(value::Unsigned)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 53 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_GroupByTags_Float",
|
|
q: `SELECT top(value::float, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `max(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: "A"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_GroupByTags_Integer",
|
|
q: `SELECT top(value::integer, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: "A"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Top_GroupByTags_Unsigned",
|
|
q: `SELECT top(value::Unsigned, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 9 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 0 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 31 * Second, Value: "A"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_NoTags_Float",
|
|
q: `SELECT bottom(value::float, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 11 * Second, Value: 3}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 51 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_NoTags_Integer",
|
|
q: `SELECT bottom(value::integer, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 11 * Second, Value: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 51 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_NoTags_Unsigned",
|
|
q: `SELECT bottom(value::Unsigned, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 11 * Second, Value: 3}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 31 * Second, Value: 100}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 5 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 51 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_Tags_Float",
|
|
q: `SELECT bottom(value::float, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_Tags_Integer",
|
|
q: `SELECT bottom(value::integer, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_Tags_Unsigned",
|
|
q: `SELECT bottom(value::Unsigned, host::tag, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(30s) fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 5 * Second, Value: "B"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Time: 31 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_GroupByTags_Float",
|
|
q: `SELECT bottom(value::float, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_GroupByTags_Integer",
|
|
q: `SELECT bottom(value::float, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Integer,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.IntegerPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Bottom_GroupByTags_Unsigned",
|
|
q: `SELECT bottom(value::float, host::tag, 1) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY region, time(30s) fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100, Aux: []interface{}{"A"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4, Aux: []interface{}{"B"}},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5, Aux: []interface{}{"B"}},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19, Aux: []interface{}{"A"}},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: 2, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=east"), Time: 10 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: 3, Aux: []interface{}{"A"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 11 * Second, Value: "A"},
|
|
},
|
|
{
|
|
&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: 1, Aux: []interface{}{"B"}},
|
|
&query.StringPoint{Name: "cpu", Tags: ParseTags("region=west"), Time: 50 * Second, Value: "B"},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Null_Float",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(null)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Number_Float",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(1)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Previous_Float",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(previous)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Float_One",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 3}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Float_Many",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 62 * Second, Value: 7},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 3}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Value: 6}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 60 * Second, Value: 7, Aggregated: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Float_MultipleSeries",
|
|
q: `SELECT mean(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 20 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 40 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Integer_One",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Integer,
|
|
expr: `max(value::integer)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1, Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 2}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Integer_Many",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:20Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Integer,
|
|
expr: `max(value::integer)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 72 * Second, Value: 10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1, Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 2}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Value: 5}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Value: 7}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 60 * Second, Value: 8}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 70 * Second, Value: 10, Aggregated: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Integer_MultipleSeries",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Integer,
|
|
expr: `max(value::integer)`,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 20 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 40 * Second, Nil: true}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Unsigned_One",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `max(value::Unsigned)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1, Aggregated: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 2}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Unsigned_Many",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:20Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `max(value::Unsigned)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 72 * Second, Value: 10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1, Aggregated: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Value: 2}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 4}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Value: 5}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Value: 7}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 60 * Second, Value: 8}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 70 * Second, Value: 10, Aggregated: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "Fill_Linear_Unsigned_MultipleSeries",
|
|
q: `SELECT max(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:01:00Z' GROUP BY host, time(10s) fill(linear)`,
|
|
typ: influxql.Unsigned,
|
|
expr: `max(value::Unsigned)`,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 12 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 32 * Second, Value: 4},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 20 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 40 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 50 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 20 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 30 * Second, Value: 4, Aggregated: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 40 * Second, Nil: true}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
name: "Stddev_Float",
|
|
q: `SELECT stddev(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1.5811388300841898}},
|
|
},
|
|
},
|
|
{
|
|
name: "Stddev_Integer",
|
|
q: `SELECT stddev(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1.5811388300841898}},
|
|
},
|
|
},
|
|
{
|
|
name: "Stddev_Unsigned",
|
|
q: `SELECT stddev(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 0.7071067811865476}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 1.5811388300841898}},
|
|
},
|
|
},
|
|
{
|
|
name: "Spread_Float",
|
|
q: `SELECT spread(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Spread_Integer",
|
|
q: `SELECT spread(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Spread_Unsigned",
|
|
q: `SELECT spread(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 5},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Percentile_Float",
|
|
q: `SELECT percentile(value, 90) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 9},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 8},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 7},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 54 * Second, Value: 6},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 55 * Second, Value: 5},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 56 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 57 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 58 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 59 * Second, Value: 1},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 3}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 9}},
|
|
},
|
|
},
|
|
{
|
|
name: "Percentile_Integer",
|
|
q: `SELECT percentile(value, 90) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 9},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 8},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 7},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 54 * Second, Value: 6},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 55 * Second, Value: 5},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 56 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 57 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 58 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 59 * Second, Value: 1},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 9}},
|
|
},
|
|
},
|
|
{
|
|
name: "Percentile_Unsigned",
|
|
q: `SELECT percentile(value, 90) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 50 * Second, Value: 10},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 51 * Second, Value: 9},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 52 * Second, Value: 8},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 53 * Second, Value: 7},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 54 * Second, Value: 6},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 55 * Second, Value: 5},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 56 * Second, Value: 4},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 57 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 58 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 59 * Second, Value: 1},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 3}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 50 * Second, Value: 9}},
|
|
},
|
|
},
|
|
{
|
|
name: "Sample_Float",
|
|
q: `SELECT sample(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 10 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 15 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Value: 19}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 15 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Sample_Integer",
|
|
q: `SELECT sample(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 10 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 15 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Value: 19}},
|
|
{&query.IntegerPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 15 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Sample_Unsigned",
|
|
q: `SELECT sample(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 10 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 15 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Value: 19}},
|
|
{&query.UnsignedPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 15 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "Sample_String",
|
|
q: `SELECT sample(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: "a"},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 5 * Second, Value: "b"},
|
|
}},
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 10 * Second, Value: "c"},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 15 * Second, Value: "d"},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: "a"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5 * Second, Value: "b"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Value: "c"}},
|
|
{&query.StringPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 15 * Second, Value: "d"}},
|
|
},
|
|
},
|
|
{
|
|
name: "Sample_Boolean",
|
|
q: `SELECT sample(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: true},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 5 * Second, Value: false},
|
|
}},
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 10 * Second, Value: false},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=B"), Time: 15 * Second, Value: true},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 10 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 15 * Second, Value: true}},
|
|
},
|
|
},
|
|
//{
|
|
// name: "Raw",
|
|
// q: `SELECT v1::float, v2::float FROM cpu`,
|
|
// itrs: []query.Iterator{
|
|
// &FloatIterator{Points: []query.FloatPoint{
|
|
// {Time: 0, Aux: []interface{}{float64(1), nil}},
|
|
// {Time: 1, Aux: []interface{}{nil, float64(2)}},
|
|
// {Time: 5, Aux: []interface{}{float64(3), float64(4)}},
|
|
// }},
|
|
// },
|
|
// points: [][]query.Point{
|
|
// {
|
|
// &query.FloatPoint{Time: 0, Value: 1},
|
|
// &query.FloatPoint{Time: 0, Nil: true},
|
|
// },
|
|
// {
|
|
// &query.FloatPoint{Time: 1, Nil: true},
|
|
// &query.FloatPoint{Time: 1, Value: 2},
|
|
// },
|
|
// {
|
|
// &query.FloatPoint{Time: 5, Value: 3},
|
|
// &query.FloatPoint{Time: 5, Value: 4},
|
|
// },
|
|
// },
|
|
//},
|
|
{
|
|
name: "ParenExpr_Min",
|
|
q: `SELECT (min(value)) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
expr: `min(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 11 * Second, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 31 * Second, Value: 100},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 30 * Second, Value: 100, Aggregated: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10, Aggregated: 1}},
|
|
},
|
|
},
|
|
{
|
|
name: "ParenExpr_Distinct",
|
|
q: `SELECT (distinct(value)) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-02T00:00:00Z' GROUP BY time(10s), host fill(none)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=A"), Time: 1 * Second, Value: 19},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=west,host=B"), Time: 5 * Second, Value: 10},
|
|
}},
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 9 * Second, Value: 19},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 10 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 11 * Second, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("region=east,host=A"), Time: 12 * Second, Value: 2},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0 * Second, Value: 19}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 10 * Second, Value: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 0 * Second, Value: 10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Float",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: -4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Integer",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: -4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Unsigned",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: -4}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Desc_Float",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z' ORDER BY desc`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Desc_Integer",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z' ORDER BY desc`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Desc_Unsigned",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z' ORDER BY desc`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Duplicate_Float",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Duplicate_Integer",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Derivative_Duplicate_Unsigned",
|
|
q: `SELECT derivative(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -2.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Float",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: -16}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Integer",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: -10}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 9}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 12 * Second, Value: -16}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Unsigned",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 4 * Second, Value: 18446744073709551606}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 8 * Second, Value: 9}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 12 * Second, Value: 18446744073709551600}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Duplicate_Float",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: -10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Duplicate_Integer",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: -10}},
|
|
},
|
|
},
|
|
{
|
|
name: "Difference_Duplicate_Unsigned",
|
|
q: `SELECT difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 4 * Second, Value: 18446744073709551606}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Float",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 29},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 16 * Second, Value: 39},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 19}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 16 * Second, Value: 36}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Integer",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 21},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 11}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Unsigned",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 21},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 8 * Second, Value: 11}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Duplicate_Float",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 30},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 10},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 16 * Second, Value: 40},
|
|
{Name: "cpu", Time: 16 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 16 * Second, Value: 30}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Duplicate_Integer",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 30},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 10},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 16 * Second, Value: 40},
|
|
{Name: "cpu", Time: 16 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 16 * Second, Value: 30}},
|
|
},
|
|
},
|
|
{
|
|
name: "Non_Negative_Difference_Duplicate_Unsigned",
|
|
q: `SELECT non_negative_difference(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
{Name: "cpu", Time: 8 * Second, Value: 30},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 10},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
{Name: "cpu", Time: 16 * Second, Value: 40},
|
|
{Name: "cpu", Time: 16 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 8 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 16 * Second, Value: 30}},
|
|
},
|
|
},
|
|
{
|
|
name: "Elapsed_Float",
|
|
q: `SELECT elapsed(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 11 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 11 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Elapsed_Integer",
|
|
q: `SELECT elapsed(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 11 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 11 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Elapsed_Unsigned",
|
|
q: `SELECT elapsed(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 11 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 11 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Elapsed_String",
|
|
q: `SELECT elapsed(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.String,
|
|
itrs: []query.Iterator{
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: "a"},
|
|
{Name: "cpu", Time: 4 * Second, Value: "b"},
|
|
{Name: "cpu", Time: 8 * Second, Value: "c"},
|
|
{Name: "cpu", Time: 11 * Second, Value: "d"},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 11 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Elapsed_Boolean",
|
|
q: `SELECT elapsed(value, 1s) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Boolean,
|
|
itrs: []query.Iterator{
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: true},
|
|
{Name: "cpu", Time: 4 * Second, Value: false},
|
|
{Name: "cpu", Time: 8 * Second, Value: false},
|
|
{Name: "cpu", Time: 11 * Second, Value: true},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 4}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 11 * Second, Value: 3}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Float",
|
|
q: `SELECT integral(value) FROM cpu`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 10 * Second, Value: 20},
|
|
{Name: "cpu", Time: 15 * Second, Value: 10},
|
|
{Name: "cpu", Time: 20 * Second, Value: 0},
|
|
{Name: "cpu", Time: 30 * Second, Value: -10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 50}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Duplicate_Float",
|
|
q: `SELECT integral(value) FROM cpu`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Time: 5 * Second, Value: 30},
|
|
{Name: "cpu", Time: 10 * Second, Value: 40},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 250}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Float_GroupByTime",
|
|
q: `SELECT integral(value) FROM cpu WHERE time > 0s AND time < 60s GROUP BY time(20s)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 10 * Second, Value: 20},
|
|
{Name: "cpu", Time: 15 * Second, Value: 10},
|
|
{Name: "cpu", Time: 20 * Second, Value: 0},
|
|
{Name: "cpu", Time: 30 * Second, Value: -10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 20 * Second, Value: -50}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Float_InterpolateGroupByTime",
|
|
q: `SELECT integral(value) FROM cpu WHERE time > 0s AND time < 60s GROUP BY time(20s)`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 10 * Second, Value: 20},
|
|
{Name: "cpu", Time: 15 * Second, Value: 10},
|
|
{Name: "cpu", Time: 25 * Second, Value: 0},
|
|
{Name: "cpu", Time: 30 * Second, Value: -10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 112.5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 20 * Second, Value: -12.5}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Integer",
|
|
q: `SELECT integral(value) FROM cpu`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Time: 10 * Second, Value: 0},
|
|
{Name: "cpu", Time: 20 * Second, Value: -10},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 50}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Duplicate_Integer",
|
|
q: `SELECT integral(value, 2s) FROM cpu`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Time: 5 * Second, Value: 30},
|
|
{Name: "cpu", Time: 10 * Second, Value: 40},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 125}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Unsigned",
|
|
q: `SELECT integral(value) FROM cpu`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Time: 10 * Second, Value: 0},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 100}},
|
|
},
|
|
},
|
|
{
|
|
name: "Integral_Duplicate_Unsigned",
|
|
q: `SELECT integral(value, 2s) FROM cpu`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10},
|
|
{Name: "cpu", Time: 5 * Second, Value: 30},
|
|
{Name: "cpu", Time: 10 * Second, Value: 40},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0, Value: 125}},
|
|
},
|
|
},
|
|
{
|
|
name: "MovingAverage_Float",
|
|
q: `SELECT moving_average(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 15, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 14.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: 11, Aggregated: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "MovingAverage_Integer",
|
|
q: `SELECT moving_average(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 15, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 14.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: 11, Aggregated: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "MovingAverage_Unsigned",
|
|
q: `SELECT moving_average(value, 2) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 15, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 14.5, Aggregated: 2}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: 11, Aggregated: 2}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Float",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 30}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 8 * Second, Value: 49}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 12 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Integer",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 30}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 8 * Second, Value: 49}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 12 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Unsigned",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 8 * Second, Value: 19},
|
|
{Name: "cpu", Time: 12 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 4 * Second, Value: 30}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 8 * Second, Value: 49}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 12 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Duplicate_Float",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Float,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 39}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 49}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 4 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Duplicate_Integer",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Integer,
|
|
itrs: []query.Iterator{
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 39}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 49}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 4 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "CumulativeSum_Duplicate_Unsigned",
|
|
q: `SELECT cumulative_sum(value) FROM cpu WHERE time >= '1970-01-01T00:00:00Z' AND time < '1970-01-01T00:00:16Z'`,
|
|
typ: influxql.Unsigned,
|
|
itrs: []query.Iterator{
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20},
|
|
{Name: "cpu", Time: 0 * Second, Value: 19},
|
|
{Name: "cpu", Time: 4 * Second, Value: 10},
|
|
{Name: "cpu", Time: 4 * Second, Value: 3},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 39}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 4 * Second, Value: 49}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 4 * Second, Value: 52}},
|
|
},
|
|
},
|
|
{
|
|
name: "HoltWinters_GroupBy_Agg",
|
|
q: `SELECT holt_winters(mean(value), 2, 2) FROM cpu WHERE time >= '1970-01-01T00:00:10Z' AND time < '1970-01-01T00:00:20Z' GROUP BY time(2s)`,
|
|
typ: influxql.Float,
|
|
expr: `mean(value::float)`,
|
|
itrs: []query.Iterator{
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 10 * Second, Value: 4},
|
|
{Name: "cpu", Time: 11 * Second, Value: 6},
|
|
|
|
{Name: "cpu", Time: 12 * Second, Value: 9},
|
|
{Name: "cpu", Time: 13 * Second, Value: 11},
|
|
|
|
{Name: "cpu", Time: 14 * Second, Value: 5},
|
|
{Name: "cpu", Time: 15 * Second, Value: 7},
|
|
|
|
{Name: "cpu", Time: 16 * Second, Value: 10},
|
|
{Name: "cpu", Time: 17 * Second, Value: 12},
|
|
|
|
{Name: "cpu", Time: 18 * Second, Value: 6},
|
|
{Name: "cpu", Time: 19 * Second, Value: 8},
|
|
}},
|
|
},
|
|
points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 20 * Second, Value: 11.960623419918432}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 22 * Second, Value: 7.953140268154609}},
|
|
},
|
|
},
|
|
} {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, _ influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"value": tt.typ,
|
|
},
|
|
Dimensions: []string{"host", "region"},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
t.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
if tt.expr != "" && !reflect.DeepEqual(opt.Expr, MustParseExpr(tt.expr)) {
|
|
t.Fatalf("unexpected expr: %s", spew.Sdump(opt.Expr))
|
|
}
|
|
|
|
itrs := tt.itrs
|
|
if _, ok := opt.Expr.(*influxql.Call); ok {
|
|
for i, itr := range itrs {
|
|
itr, err := query.NewCallIterator(itr, opt)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
itrs[i] = itr
|
|
}
|
|
}
|
|
return query.Iterators(itrs).Merge(opt)
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
itrs, _, err := query.Select(context.Background(), MustParseSelectStatement(tt.q), &shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
if tt.err == "" {
|
|
t.Fatal(err)
|
|
} else if have, want := err.Error(), tt.err; have != want {
|
|
t.Fatalf("unexpected error: have=%s want=%s", have, want)
|
|
}
|
|
} else if tt.err != "" {
|
|
t.Fatal("expected error")
|
|
} else if a, err := Iterators(itrs).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected point: %s", err)
|
|
} else if diff := cmp.Diff(a, tt.points); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Ensure a SELECT with raw fields works for all types.
|
|
func TestSelect_Raw(t *testing.T) {
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, _ influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"f": influxql.Float,
|
|
"i": influxql.Integer,
|
|
"u": influxql.Unsigned,
|
|
"s": influxql.String,
|
|
"b": influxql.Boolean,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
t.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
if !reflect.DeepEqual(opt.Aux, []influxql.VarRef{
|
|
{Val: "b", Type: influxql.Boolean},
|
|
{Val: "f", Type: influxql.Float},
|
|
{Val: "i", Type: influxql.Integer},
|
|
{Val: "s", Type: influxql.String},
|
|
{Val: "u", Type: influxql.Unsigned},
|
|
}) {
|
|
t.Fatalf("unexpected auxiliary fields: %v", opt.Aux)
|
|
}
|
|
return &FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Aux: []interface{}{
|
|
true, float64(20), int64(20), "a", uint64(20)}},
|
|
{Name: "cpu", Time: 5 * Second, Aux: []interface{}{
|
|
false, float64(10), int64(10), "b", uint64(10)}},
|
|
{Name: "cpu", Time: 9 * Second, Aux: []interface{}{
|
|
true, float64(19), int64(19), "c", uint64(19)}},
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
stmt := MustParseSelectStatement(`SELECT f, i, u, s, b FROM cpu`)
|
|
itrs, _, err := query.Select(context.Background(), stmt, &shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
t.Errorf("parse error: %s", err)
|
|
} else if a, err := Iterators(itrs).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Value: 20, Time: 0 * Second},
|
|
&query.IntegerPoint{Name: "cpu", Value: 20, Time: 0 * Second},
|
|
&query.UnsignedPoint{Name: "cpu", Value: 20, Time: 0 * Second},
|
|
&query.StringPoint{Name: "cpu", Value: "a", Time: 0 * Second},
|
|
&query.BooleanPoint{Name: "cpu", Value: true, Time: 0 * Second},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Value: 10, Time: 5 * Second},
|
|
&query.IntegerPoint{Name: "cpu", Value: 10, Time: 5 * Second},
|
|
&query.UnsignedPoint{Name: "cpu", Value: 10, Time: 5 * Second},
|
|
&query.StringPoint{Name: "cpu", Value: "b", Time: 5 * Second},
|
|
&query.BooleanPoint{Name: "cpu", Value: false, Time: 5 * Second},
|
|
},
|
|
{
|
|
&query.FloatPoint{Name: "cpu", Value: 19, Time: 9 * Second},
|
|
&query.IntegerPoint{Name: "cpu", Value: 19, Time: 9 * Second},
|
|
&query.UnsignedPoint{Name: "cpu", Value: 19, Time: 9 * Second},
|
|
&query.StringPoint{Name: "cpu", Value: "c", Time: 9 * Second},
|
|
&query.BooleanPoint{Name: "cpu", Value: true, Time: 9 * Second},
|
|
},
|
|
}); diff != "" {
|
|
t.Errorf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure a SELECT binary expr queries can be executed as floats.
|
|
func TestSelect_BinaryExpr(t *testing.T) {
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, _ influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"f": influxql.Float,
|
|
"i": influxql.Integer,
|
|
"u": influxql.Unsigned,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
t.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
makeAuxFields := func(value int) []interface{} {
|
|
aux := make([]interface{}, len(opt.Aux))
|
|
for i := range aux {
|
|
switch opt.Aux[i].Type {
|
|
case influxql.Float:
|
|
aux[i] = float64(value)
|
|
case influxql.Integer:
|
|
aux[i] = int64(value)
|
|
case influxql.Unsigned:
|
|
aux[i] = uint64(value)
|
|
}
|
|
}
|
|
return aux
|
|
}
|
|
return &FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Aux: makeAuxFields(20)},
|
|
{Name: "cpu", Time: 5 * Second, Aux: makeAuxFields(10)},
|
|
{Name: "cpu", Time: 9 * Second, Aux: makeAuxFields(19)},
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
for _, test := range []struct {
|
|
Name string
|
|
Statement string
|
|
Points [][]query.Point
|
|
Err string
|
|
}{
|
|
{
|
|
Name: "Float_AdditionRHS_Number",
|
|
Statement: `SELECT f + 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionRHS_Number",
|
|
Statement: `SELECT i + 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionRHS_Number",
|
|
Statement: `SELECT u + 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_AdditionRHS_Integer",
|
|
Statement: `SELECT f + 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionRHS_Integer",
|
|
Statement: `SELECT i + 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionRHS_Integer",
|
|
Statement: `SELECT u + 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_AdditionRHS_Unsigned",
|
|
Statement: `SELECT f + 9223372036854775808 FROM cpu`,
|
|
Points: [][]query.Point{ // adding small floats to this does not change the value, this is expected
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(9223372036854775808)}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionRHS_Unsigned",
|
|
Statement: `SELECT i + 9223372036854775808 FROM cpu`,
|
|
Err: `cannot use + with an integer and unsigned`,
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionRHS_Unsigned",
|
|
Statement: `SELECT u + 9223372036854775808 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 9223372036854775828}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 9223372036854775818}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 9223372036854775827}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_AdditionLHS_Number",
|
|
Statement: `SELECT 2.0 + f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionLHS_Number",
|
|
Statement: `SELECT 2.0 + i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionLHS_Number",
|
|
Statement: `SELECT 2.0 + u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_AdditionLHS_Integer",
|
|
Statement: `SELECT 2 + f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionLHS_Integer",
|
|
Statement: `SELECT 2 + i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionLHS_Integer",
|
|
Statement: `SELECT 2 + u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 22}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 12}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 21}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_AdditionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 + f FROM cpu`,
|
|
Points: [][]query.Point{ // adding small floats to this does not change the value, this is expected
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(9223372036854775808)}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_AdditionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 + i FROM cpu`,
|
|
Err: `cannot use + with unsigned and an integer`,
|
|
},
|
|
{
|
|
Name: "Unsigned_AdditionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 + u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 9223372036854775828}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 9223372036854775818}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 9223372036854775827}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Add_Float",
|
|
Statement: `SELECT f + f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Add_Integer",
|
|
Statement: `SELECT i + i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_Add_Unsigned",
|
|
Statement: `SELECT u + u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Add_Integer",
|
|
Statement: `SELECT f + i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Add_Unsigned",
|
|
Statement: `SELECT f + u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Add_Unsigned",
|
|
Statement: `SELECT i + u FROM cpu`,
|
|
Err: `cannot use + between an integer and unsigned, an explicit cast is required`,
|
|
},
|
|
{
|
|
Name: "Float_MultiplicationRHS_Number",
|
|
Statement: `SELECT f * 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_MultiplicationRHS_Number",
|
|
Statement: `SELECT i * 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_MultiplicationRHS_Number",
|
|
Statement: `SELECT u * 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_MultiplicationRHS_Integer",
|
|
Statement: `SELECT f * 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_MultiplicationRHS_Integer",
|
|
Statement: `SELECT i * 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_MultiplicationRHS_Integer",
|
|
Statement: `SELECT u * 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
// Skip unsigned literals for multiplication because there is inevitable
|
|
// overflow. While it is possible to do, the behavior is considered unsigned
|
|
// and it's not a very good test because it would result in just plugging
|
|
// the values into the computer anyway to figure out what the correct answer
|
|
// is rather than calculating it myself and testing that I get the correct
|
|
// value.
|
|
{
|
|
Name: "Float_MultiplicationLHS_Number",
|
|
Statement: `SELECT 2.0 * f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_MultiplicationLHS_Number",
|
|
Statement: `SELECT 2.0 * i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_MultiplicationLHS_Number",
|
|
Statement: `SELECT 2.0 * u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_MultiplicationLHS_Integer",
|
|
Statement: `SELECT 2 * f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_MultiplicationLHS_Integer",
|
|
Statement: `SELECT 2 * i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_MultiplicationLHS_Integer",
|
|
Statement: `SELECT 2 * u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 40}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 38}},
|
|
},
|
|
},
|
|
// Skip unsigned literals for multiplication. See above.
|
|
{
|
|
Name: "Float_Multiply_Float",
|
|
Statement: `SELECT f * f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 400}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 361}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Multiply_Integer",
|
|
Statement: `SELECT i * i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 400}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 100}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 361}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_Multiply_Unsigned",
|
|
Statement: `SELECT u * u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 400}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 100}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 361}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Multiply_Integer",
|
|
Statement: `SELECT f * i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 400}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 361}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Multiply_Unsigned",
|
|
Statement: `SELECT f * u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 400}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 100}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 361}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Multiply_Unsigned",
|
|
Statement: `SELECT i * u FROM cpu`,
|
|
Err: `cannot use * between an integer and unsigned, an explicit cast is required`,
|
|
},
|
|
{
|
|
Name: "Float_SubtractionRHS_Number",
|
|
Statement: `SELECT f - 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionRHS_Number",
|
|
Statement: `SELECT i - 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_SubtractionRHS_Number",
|
|
Statement: `SELECT u - 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_SubtractionRHS_Integer",
|
|
Statement: `SELECT f - 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionRHS_Integer",
|
|
Statement: `SELECT i - 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_SubtractionRHS_Integer",
|
|
Statement: `SELECT u - 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_SubtractionRHS_Unsigned",
|
|
Statement: `SELECT f - 9223372036854775808 FROM cpu`,
|
|
Points: [][]query.Point{ // adding small floats to this does not change the value, this is expected
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: float64(-9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(-9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(-9223372036854775808)}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionRHS_Unsigned",
|
|
Statement: `SELECT i - 9223372036854775808 FROM cpu`,
|
|
Err: `cannot use - with an integer and unsigned`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 18}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 8}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 17}},
|
|
},
|
|
},
|
|
// Skip Unsigned_SubtractionRHS_Integer because it would result in underflow.
|
|
{
|
|
Name: "Float_SubtractionLHS_Number",
|
|
Statement: `SELECT 2.0 - f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: -18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: -8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: -17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionLHS_Number",
|
|
Statement: `SELECT 2.0 - i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: -18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: -8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: -17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_SubtractionLHS_Number",
|
|
Statement: `SELECT 2.0 - u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: -18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: -8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: -17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_SubtractionLHS_Integer",
|
|
Statement: `SELECT 2 - f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: -18}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: -8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: -17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionLHS_Integer",
|
|
Statement: `SELECT 2 - i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: -18}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: -8}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: -17}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_SubtractionLHS_Integer",
|
|
Statement: `SELECT 30 - u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 11}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_SubtractionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 - f FROM cpu`, // subtracting small floats to this does not change the value, this is expected
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: float64(9223372036854775828)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(9223372036854775828)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(9223372036854775828)}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_SubtractionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 - i FROM cpu`,
|
|
Err: `cannot use - with unsigned and an integer`,
|
|
},
|
|
{
|
|
Name: "Unsigned_SubtractionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 - u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 9223372036854775788}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 9223372036854775798}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 9223372036854775789}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Subtract_Float",
|
|
Statement: `SELECT f - f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Subtract_Integer",
|
|
Statement: `SELECT i - i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_Subtract_Unsigned",
|
|
Statement: `SELECT u - u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Subtract_Integer",
|
|
Statement: `SELECT f - i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Subtract_Unsigned",
|
|
Statement: `SELECT f - u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Subtract_Unsigned",
|
|
Statement: `SELECT i - u FROM cpu`,
|
|
Err: `cannot use - between an integer and unsigned, an explicit cast is required`,
|
|
},
|
|
{
|
|
Name: "Float_DivisionRHS_Number",
|
|
Statement: `SELECT f / 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(19) / 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionRHS_Number",
|
|
Statement: `SELECT i / 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 9.5}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionRHS_Number",
|
|
Statement: `SELECT u / 2.0 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 9.5}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_DivisionRHS_Integer",
|
|
Statement: `SELECT f / 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(19) / 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionRHS_Integer",
|
|
Statement: `SELECT i / 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(19) / 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionRHS_Integer",
|
|
Statement: `SELECT u / 2 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 5}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 9}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_DivisionRHS_Unsigned",
|
|
Statement: `SELECT f / 9223372036854775808 FROM cpu`,
|
|
Points: [][]query.Point{ // dividing small floats does not result in a meaningful result, this is expected
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: float64(20) / float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(10) / float64(9223372036854775808)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: float64(19) / float64(9223372036854775808)}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionRHS_Unsigned",
|
|
Statement: `SELECT i / 9223372036854775808 FROM cpu`,
|
|
Err: `cannot use / with an integer and unsigned`,
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionRHS_Unsigned",
|
|
Statement: `SELECT u / 9223372036854775808 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_DivisionLHS_Number",
|
|
Statement: `SELECT 38.0 / f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1.9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 3.8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionLHS_Number",
|
|
Statement: `SELECT 38.0 / i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1.9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 3.8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 2.0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionLHS_Number",
|
|
Statement: `SELECT 38.0 / u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1.9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 3.8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 2.0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_DivisionLHS_Integer",
|
|
Statement: `SELECT 38 / f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1.9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 3.8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionLHS_Integer",
|
|
Statement: `SELECT 38 / i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1.9}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 3.8}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionLHS_Integer",
|
|
Statement: `SELECT 38 / u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 3}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 2}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_DivisionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 / f FROM cpu`,
|
|
Points: [][]query.Point{ // dividing large floats results in inaccurate outputs so these may not be correct, but that is considered normal for floating point
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 461168601842738816}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 922337203685477632}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 485440633518672384}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_DivisionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 / i FROM cpu`,
|
|
Err: `cannot use / with unsigned and an integer`,
|
|
},
|
|
{
|
|
Name: "Unsigned_DivisionLHS_Unsigned",
|
|
Statement: `SELECT 9223372036854775808 / u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 461168601842738790}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 922337203685477580}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 485440633518672410}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Divide_Float",
|
|
Statement: `SELECT f / f FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Divide_Integer",
|
|
Statement: `SELECT i / i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_Divide_Unsigned",
|
|
Statement: `SELECT u / u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 1}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Divide_Integer",
|
|
Statement: `SELECT f / i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Float_Divide_Unsigned",
|
|
Statement: `SELECT f / u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 1}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Value: 1}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_Divide_Unsigned",
|
|
Statement: `SELECT i / u FROM cpu`,
|
|
Err: `cannot use / between an integer and unsigned, an explicit cast is required`,
|
|
},
|
|
{
|
|
Name: "Integer_BitwiseAndRHS",
|
|
Statement: `SELECT i & 254 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 10}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 18}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_BitwiseAndRHS",
|
|
Statement: `SELECT u & 254 FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 10}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 18}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_BitwiseOrLHS",
|
|
Statement: `SELECT 4 | i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 14}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 23}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_BitwiseOrLHS",
|
|
Statement: `SELECT 4 | u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 20}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 14}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 23}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Integer_BitwiseXOr_Integer",
|
|
Statement: `SELECT i ^ i FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Unsigned_BitwiseXOr_Integer",
|
|
Statement: `SELECT u ^ u FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 0 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 5 * Second, Value: 0}},
|
|
{&query.UnsignedPoint{Name: "cpu", Time: 9 * Second, Value: 0}},
|
|
},
|
|
},
|
|
} {
|
|
t.Run(test.Name, func(t *testing.T) {
|
|
stmt := MustParseSelectStatement(test.Statement)
|
|
itrs, _, err := query.Select(context.Background(), stmt, &shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
if have, want := err.Error(), test.Err; want != "" {
|
|
if have != want {
|
|
t.Errorf("%s: unexpected parse error: %s != %s", test.Name, have, want)
|
|
}
|
|
} else {
|
|
t.Errorf("%s: unexpected parse error: %s", test.Name, have)
|
|
}
|
|
} else if test.Err != "" {
|
|
t.Fatalf("%s: expected error", test.Name)
|
|
} else if a, err := Iterators(itrs).ReadAll(); err != nil {
|
|
t.Fatalf("%s: unexpected error: %s", test.Name, err)
|
|
} else if diff := cmp.Diff(a, test.Points); diff != "" {
|
|
t.Errorf("%s: unexpected points:\n%s", test.Name, diff)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Ensure a SELECT binary expr queries can be executed as booleans.
|
|
func TestSelect_BinaryExpr_Boolean(t *testing.T) {
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, _ influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"one": influxql.Boolean,
|
|
"two": influxql.Boolean,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
t.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
makeAuxFields := func(value bool) []interface{} {
|
|
aux := make([]interface{}, len(opt.Aux))
|
|
for i := range aux {
|
|
aux[i] = value
|
|
}
|
|
return aux
|
|
}
|
|
return &FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Aux: makeAuxFields(true)},
|
|
{Name: "cpu", Time: 5 * Second, Aux: makeAuxFields(false)},
|
|
{Name: "cpu", Time: 9 * Second, Aux: makeAuxFields(true)},
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
for _, test := range []struct {
|
|
Name string
|
|
Statement string
|
|
Points [][]query.Point
|
|
}{
|
|
{
|
|
Name: "BinaryXOrRHS",
|
|
Statement: `SELECT one ^ true FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Time: 0 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 5 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 9 * Second, Value: false}},
|
|
},
|
|
},
|
|
{
|
|
Name: "BinaryOrLHS",
|
|
Statement: `SELECT true | two FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Time: 0 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 5 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 9 * Second, Value: true}},
|
|
},
|
|
},
|
|
{
|
|
Name: "TwoSeriesBitwiseAnd",
|
|
Statement: `SELECT one & two FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.BooleanPoint{Name: "cpu", Time: 0 * Second, Value: true}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 5 * Second, Value: false}},
|
|
{&query.BooleanPoint{Name: "cpu", Time: 9 * Second, Value: true}},
|
|
},
|
|
},
|
|
} {
|
|
t.Run(test.Name, func(t *testing.T) {
|
|
stmt := MustParseSelectStatement(test.Statement)
|
|
itrs, _, err := query.Select(context.Background(), stmt, &shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
t.Errorf("%s: parse error: %s", test.Name, err)
|
|
} else if a, err := Iterators(itrs).ReadAll(); err != nil {
|
|
t.Fatalf("%s: unexpected error: %s", test.Name, err)
|
|
} else if diff := cmp.Diff(a, test.Points); diff != "" {
|
|
t.Errorf("%s: unexpected points:\n%s", test.Name, diff)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Ensure a SELECT binary expr with nil values can be executed.
|
|
// Nil values may be present when a field is missing from one iterator,
|
|
// but not the other.
|
|
func TestSelect_BinaryExpr_NilValues(t *testing.T) {
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, _ influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"total": influxql.Float,
|
|
"value": influxql.Float,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
t.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
return &FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0 * Second, Value: 20, Aux: []interface{}{float64(20), nil}},
|
|
{Name: "cpu", Time: 5 * Second, Value: 10, Aux: []interface{}{float64(10), float64(15)}},
|
|
{Name: "cpu", Time: 9 * Second, Value: 19, Aux: []interface{}{nil, float64(5)}},
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
for _, test := range []struct {
|
|
Name string
|
|
Statement string
|
|
Points [][]query.Point
|
|
}{
|
|
{
|
|
Name: "Addition",
|
|
Statement: `SELECT total + value FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 25}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Subtraction",
|
|
Statement: `SELECT total - value FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: -5}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Multiplication",
|
|
Statement: `SELECT total * value FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: 150}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Nil: true}},
|
|
},
|
|
},
|
|
{
|
|
Name: "Division",
|
|
Statement: `SELECT total / value FROM cpu`,
|
|
Points: [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Time: 0 * Second, Nil: true}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 5 * Second, Value: float64(10) / float64(15)}},
|
|
{&query.FloatPoint{Name: "cpu", Time: 9 * Second, Nil: true}},
|
|
},
|
|
},
|
|
} {
|
|
t.Run(test.Name, func(t *testing.T) {
|
|
stmt := MustParseSelectStatement(test.Statement)
|
|
itrs, _, err := query.Select(context.Background(), stmt, &shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
t.Errorf("%s: parse error: %s", test.Name, err)
|
|
} else if a, err := Iterators(itrs).ReadAll(); err != nil {
|
|
t.Fatalf("%s: unexpected error: %s", test.Name, err)
|
|
} else if diff := cmp.Diff(a, test.Points); diff != "" {
|
|
t.Errorf("%s: unexpected points:\n%s", test.Name, diff)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
type ShardMapper struct {
|
|
MapShardsFn func(sources influxql.Sources, t influxql.TimeRange) query.ShardGroup
|
|
}
|
|
|
|
func (m *ShardMapper) MapShards(sources influxql.Sources, t influxql.TimeRange, opt query.SelectOptions) (query.ShardGroup, error) {
|
|
shards := m.MapShardsFn(sources, t)
|
|
return shards, nil
|
|
}
|
|
|
|
type ShardGroup struct {
|
|
CreateIteratorFn func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error)
|
|
Fields map[string]influxql.DataType
|
|
Dimensions []string
|
|
}
|
|
|
|
func (sh *ShardGroup) CreateIterator(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
return sh.CreateIteratorFn(ctx, m, opt)
|
|
}
|
|
|
|
func (sh *ShardGroup) IteratorCost(m *influxql.Measurement, opt query.IteratorOptions) (query.IteratorCost, error) {
|
|
return query.IteratorCost{}, nil
|
|
}
|
|
|
|
func (sh *ShardGroup) FieldDimensions(m *influxql.Measurement) (fields map[string]influxql.DataType, dimensions map[string]struct{}, err error) {
|
|
fields = make(map[string]influxql.DataType)
|
|
dimensions = make(map[string]struct{})
|
|
|
|
for f, typ := range sh.Fields {
|
|
fields[f] = typ
|
|
}
|
|
for _, d := range sh.Dimensions {
|
|
dimensions[d] = struct{}{}
|
|
}
|
|
return fields, dimensions, nil
|
|
}
|
|
|
|
func (sh *ShardGroup) MapType(m *influxql.Measurement, field string) influxql.DataType {
|
|
if typ, ok := sh.Fields[field]; ok {
|
|
return typ
|
|
}
|
|
for _, d := range sh.Dimensions {
|
|
if d == field {
|
|
return influxql.Tag
|
|
}
|
|
}
|
|
return influxql.Unknown
|
|
}
|
|
|
|
func (*ShardGroup) Close() error {
|
|
return nil
|
|
}
|
|
|
|
func BenchmarkSelect_Raw_1K(b *testing.B) { benchmarkSelectRaw(b, 1000) }
|
|
func BenchmarkSelect_Raw_100K(b *testing.B) { benchmarkSelectRaw(b, 1000000) }
|
|
|
|
func benchmarkSelectRaw(b *testing.B, pointN int) {
|
|
benchmarkSelect(b, MustParseSelectStatement(`SELECT fval FROM cpu`), NewRawBenchmarkIteratorCreator(pointN))
|
|
}
|
|
|
|
func benchmarkSelect(b *testing.B, stmt *influxql.SelectStatement, shardMapper query.ShardMapper) {
|
|
b.ReportAllocs()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
itrs, _, err := query.Select(context.Background(), stmt, shardMapper, query.SelectOptions{})
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
query.DrainIterators(itrs)
|
|
}
|
|
}
|
|
|
|
// NewRawBenchmarkIteratorCreator returns a new mock iterator creator with generated fields.
|
|
func NewRawBenchmarkIteratorCreator(pointN int) query.ShardMapper {
|
|
return &ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, t influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"fval": influxql.Float,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if opt.Expr != nil {
|
|
panic("unexpected expression")
|
|
}
|
|
|
|
p := query.FloatPoint{
|
|
Name: "cpu",
|
|
Aux: make([]interface{}, len(opt.Aux)),
|
|
}
|
|
|
|
for i := range opt.Aux {
|
|
switch opt.Aux[i].Val {
|
|
case "fval":
|
|
p.Aux[i] = float64(100)
|
|
default:
|
|
panic("unknown iterator expr: " + opt.Expr.String())
|
|
}
|
|
}
|
|
|
|
return &FloatPointGenerator{N: pointN, Fn: func(i int) *query.FloatPoint {
|
|
p.Time = int64(time.Duration(i) * (10 * time.Second))
|
|
return &p
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
}
|
|
|
|
func benchmarkSelectDedupe(b *testing.B, seriesN, pointsPerSeries int) {
|
|
stmt := MustParseSelectStatement(`SELECT sval::string FROM cpu`)
|
|
stmt.Dedupe = true
|
|
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, t influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"sval": influxql.String,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if opt.Expr != nil {
|
|
panic("unexpected expression")
|
|
}
|
|
|
|
p := query.FloatPoint{
|
|
Name: "tags",
|
|
Aux: []interface{}{nil},
|
|
}
|
|
|
|
return &FloatPointGenerator{N: seriesN * pointsPerSeries, Fn: func(i int) *query.FloatPoint {
|
|
p.Aux[0] = fmt.Sprintf("server%d", i%seriesN)
|
|
return &p
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
b.ResetTimer()
|
|
benchmarkSelect(b, stmt, &shardMapper)
|
|
}
|
|
|
|
func BenchmarkSelect_Dedupe_1K(b *testing.B) { benchmarkSelectDedupe(b, 1000, 100) }
|
|
|
|
func benchmarkSelectTop(b *testing.B, seriesN, pointsPerSeries int) {
|
|
stmt := MustParseSelectStatement(`SELECT top(sval, 10) FROM cpu`)
|
|
|
|
shardMapper := ShardMapper{
|
|
MapShardsFn: func(sources influxql.Sources, t influxql.TimeRange) query.ShardGroup {
|
|
return &ShardGroup{
|
|
Fields: map[string]influxql.DataType{
|
|
"sval": influxql.Float,
|
|
},
|
|
CreateIteratorFn: func(ctx context.Context, m *influxql.Measurement, opt query.IteratorOptions) (query.Iterator, error) {
|
|
if m.Name != "cpu" {
|
|
b.Fatalf("unexpected source: %s", m.Name)
|
|
}
|
|
if !reflect.DeepEqual(opt.Expr, MustParseExpr(`sval`)) {
|
|
b.Fatalf("unexpected expr: %s", spew.Sdump(opt.Expr))
|
|
}
|
|
|
|
p := query.FloatPoint{
|
|
Name: "cpu",
|
|
}
|
|
|
|
return &FloatPointGenerator{N: seriesN * pointsPerSeries, Fn: func(i int) *query.FloatPoint {
|
|
p.Value = float64(rand.Int63())
|
|
p.Time = int64(time.Duration(i) * (10 * time.Second))
|
|
return &p
|
|
}}, nil
|
|
},
|
|
}
|
|
},
|
|
}
|
|
|
|
b.ResetTimer()
|
|
benchmarkSelect(b, stmt, &shardMapper)
|
|
}
|
|
|
|
func BenchmarkSelect_Top_1K(b *testing.B) { benchmarkSelectTop(b, 1000, 1000) }
|