1222 lines
52 KiB
Go
1222 lines
52 KiB
Go
package query_test
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/google/go-cmp/cmp"
|
|
"github.com/influxdata/influxdb/query"
|
|
"github.com/influxdata/influxql"
|
|
)
|
|
|
|
// Ensure that a float iterator can be created for a count() call.
|
|
func TestCallIterator_Count_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Name: "cpu", Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Name: "cpu", Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "cpu", Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "mem", Time: 23, Value: 10, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`count("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 3, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5, Value: 1, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "mem", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an integer iterator can be created for a count() call.
|
|
func TestCallIterator_Count_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Name: "cpu", Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Name: "cpu", Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Name: "cpu", Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "cpu", Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "mem", Time: 23, Value: 10, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`count("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 3, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5, Value: 1, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "mem", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an unsigned iterator can be created for a count() call.
|
|
func TestCallIterator_Count_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Name: "cpu", Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Name: "cpu", Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Name: "cpu", Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "cpu", Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "mem", Time: 23, Value: 10, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`count("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 3, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5, Value: 1, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "mem", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a string iterator can be created for a count() call.
|
|
func TestCallIterator_Count_String(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Time: 0, Value: "d", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 2, Value: "b", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 1, Value: "b", Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Name: "cpu", Time: 5, Value: "e", Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Name: "cpu", Time: 1, Value: "c", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "cpu", Time: 23, Value: "a", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "mem", Time: 23, Value: "b", Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`count("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 3, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5, Value: 1, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "mem", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a count() call.
|
|
func TestCallIterator_Count_Boolean(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Name: "cpu", Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 2, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Name: "cpu", Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Name: "cpu", Time: 5, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Name: "cpu", Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "cpu", Time: 23, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Name: "mem", Time: 23, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`count("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 3, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 5, Value: 1, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 0, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "cpu", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Name: "mem", Time: 20, Value: 1, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a min() call.
|
|
func TestCallIterator_Min_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 12, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`min("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 1, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 4}},
|
|
{&query.FloatPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a integer iterator can be created for a min() call.
|
|
func TestCallIterator_Min_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 12, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`min("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 1, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 4}},
|
|
{&query.IntegerPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a unsigned iterator can be created for a min() call.
|
|
func TestCallIterator_Min_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 12, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`min("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 1, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 4}},
|
|
{&query.UnsignedPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a min() call.
|
|
func TestCallIterator_Min_Boolean(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`min("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.BooleanPoint{Time: 2, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.BooleanPoint{Time: 5, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 1, Value: false, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 23, Value: true, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a max() call.
|
|
func TestCallIterator_Max_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`max("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.FloatPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a integer iterator can be created for a max() call.
|
|
func TestCallIterator_Max_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`max("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a unsigned iterator can be created for a max() call.
|
|
func TestCallIterator_Max_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`max("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.UnsignedPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a max() call.
|
|
func TestCallIterator_Max_Boolean(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`max("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.BooleanPoint{Time: 0, Value: true, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.BooleanPoint{Time: 5, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 1, Value: false, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 23, Value: true, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a sum() call.
|
|
func TestCallIterator_Sum_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`sum("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 0, Value: 35, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.FloatPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 0, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an integer iterator can be created for a sum() call.
|
|
func TestCallIterator_Sum_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`sum("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 0, Value: 35, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 0, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an unsigned iterator can be created for a sum() call.
|
|
func TestCallIterator_Sum_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 5, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`sum("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 0, Value: 35, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.UnsignedPoint{Time: 5, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 0, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a first() call.
|
|
func TestCallIterator_First_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`first("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.FloatPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an integer iterator can be created for a first() call.
|
|
func TestCallIterator_First_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`first("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an unsigned iterator can be created for a first() call.
|
|
func TestCallIterator_First_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`first("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 0, Value: 15, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.UnsignedPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a string iterator can be created for a first() call.
|
|
func TestCallIterator_First_String(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Time: 2, Value: "b", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: "d", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: "b", Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: "e", Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: "c", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: "a", Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`first("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.StringPoint{Time: 0, Value: "d", Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.StringPoint{Time: 6, Value: "e", Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.StringPoint{Time: 1, Value: "c", Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.StringPoint{Time: 23, Value: "a", Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a first() call.
|
|
func TestCallIterator_First_Boolean(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Time: 2, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: false, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`first("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.BooleanPoint{Time: 0, Value: true, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.BooleanPoint{Time: 6, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 1, Value: true, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 23, Value: false, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a last() call.
|
|
func TestCallIterator_Last_Float(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`last("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 2, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.FloatPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.FloatPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an integer iterator can be created for a last() call.
|
|
func TestCallIterator_Last_Integer(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`last("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 2, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.IntegerPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.IntegerPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that an unsigned iterator can be created for a last() call.
|
|
func TestCallIterator_Last_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`last("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 2, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.UnsignedPoint{Time: 6, Value: 20, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.UnsignedPoint{Time: 23, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a string iterator can be created for a last() call.
|
|
func TestCallIterator_Last_String(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&StringIterator{Points: []query.StringPoint{
|
|
{Time: 2, Value: "b", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: "d", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: "b", Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: "e", Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: "c", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: "a", Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`last("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.StringPoint{Time: 2, Value: "b", Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.StringPoint{Time: 6, Value: "e", Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.StringPoint{Time: 1, Value: "c", Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.StringPoint{Time: 23, Value: "a", Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a last() call.
|
|
func TestCallIterator_Last_Boolean(t *testing.T) {
|
|
itr, _ := query.NewCallIterator(
|
|
&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Time: 2, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: false, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 6, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`last("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.BooleanPoint{Time: 2, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 3}},
|
|
{&query.BooleanPoint{Time: 6, Value: false, Tags: ParseTags("host=hostA"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 1, Value: true, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
{&query.BooleanPoint{Time: 23, Value: false, Tags: ParseTags("host=hostB"), Aggregated: 1}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a float iterator can be created for a mode() call.
|
|
func TestCallIterator_Mode_Float(t *testing.T) {
|
|
itr, _ := query.NewModeIterator(&FloatIterator{Points: []query.FloatPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 3, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 8, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 22, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 24, Value: 25, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`mode("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.FloatPoint{Time: 0, Value: 10, Tags: ParseTags("host=hostA"), Aggregated: 0}},
|
|
{&query.FloatPoint{Time: 5, Value: 21, Tags: ParseTags("host=hostA"), Aggregated: 0}},
|
|
{&query.FloatPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB"), Aggregated: 0}},
|
|
{&query.FloatPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB"), Aggregated: 0}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a integer iterator can be created for a mode() call.
|
|
func TestCallIterator_Mode_Integer(t *testing.T) {
|
|
itr, _ := query.NewModeIterator(&IntegerIterator{Points: []query.IntegerPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 3, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 8, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 22, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 24, Value: 25, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`mode("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.IntegerPoint{Time: 0, Value: 10, Tags: ParseTags("host=hostA")}},
|
|
{&query.IntegerPoint{Time: 5, Value: 21, Tags: ParseTags("host=hostA")}},
|
|
{&query.IntegerPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB")}},
|
|
{&query.IntegerPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB")}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a unsigned iterator can be created for a mode() call.
|
|
func TestCallIterator_Mode_Unsigned(t *testing.T) {
|
|
itr, _ := query.NewModeIterator(&UnsignedIterator{Points: []query.UnsignedPoint{
|
|
{Time: 0, Value: 15, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 10, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 2, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 3, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: 10, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 6, Value: 20, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 8, Value: 21, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: 11, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 22, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: 8, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 24, Value: 25, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`mode("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.UnsignedPoint{Time: 0, Value: 10, Tags: ParseTags("host=hostA")}},
|
|
{&query.UnsignedPoint{Time: 5, Value: 21, Tags: ParseTags("host=hostA")}},
|
|
{&query.UnsignedPoint{Time: 1, Value: 11, Tags: ParseTags("host=hostB")}},
|
|
{&query.UnsignedPoint{Time: 20, Value: 8, Tags: ParseTags("host=hostB")}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a string iterator can be created for a mode() call.
|
|
func TestCallIterator_Mode_String(t *testing.T) {
|
|
itr, _ := query.NewModeIterator(&StringIterator{Points: []query.StringPoint{
|
|
{Time: 0, Value: "15", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: "10", Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 2, Value: "10", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 3, Value: "10", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: "10", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 6, Value: "20", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: "21", Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: "21", Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: "11", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 22, Value: "8", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: "8", Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 24, Value: "25", Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`mode("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.StringPoint{Time: 0, Value: "10", Tags: ParseTags("host=hostA")}},
|
|
{&query.StringPoint{Time: 5, Value: "21", Tags: ParseTags("host=hostA")}},
|
|
{&query.StringPoint{Time: 1, Value: "11", Tags: ParseTags("host=hostB")}},
|
|
{&query.StringPoint{Time: 20, Value: "8", Tags: ParseTags("host=hostB")}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
// Ensure that a boolean iterator can be created for a modBooleanl.
|
|
func TestCallIterator_Mode_Boolean(t *testing.T) {
|
|
itr, _ := query.NewModeIterator(&BooleanIterator{Points: []query.BooleanPoint{
|
|
{Time: 0, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 1, Value: true, Tags: ParseTags("region=us-west,host=hostA")},
|
|
{Time: 2, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 3, Value: true, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 4, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 6, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 7, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
{Time: 8, Value: false, Tags: ParseTags("region=us-east,host=hostA")},
|
|
|
|
{Time: 1, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 22, Value: false, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 23, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
{Time: 24, Value: true, Tags: ParseTags("region=us-west,host=hostB")},
|
|
}},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`mode("value")`),
|
|
Dimensions: []string{"host"},
|
|
Interval: query.Interval{Duration: 5 * time.Nanosecond},
|
|
Ordered: true,
|
|
Ascending: true,
|
|
},
|
|
)
|
|
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if diff := cmp.Diff(a, [][]query.Point{
|
|
{&query.BooleanPoint{Time: 0, Value: true, Tags: ParseTags("host=hostA")}},
|
|
{&query.BooleanPoint{Time: 5, Value: false, Tags: ParseTags("host=hostA")}},
|
|
{&query.BooleanPoint{Time: 1, Value: false, Tags: ParseTags("host=hostB")}},
|
|
{&query.BooleanPoint{Time: 20, Value: true, Tags: ParseTags("host=hostB")}},
|
|
}); diff != "" {
|
|
t.Fatalf("unexpected points:\n%s", diff)
|
|
}
|
|
}
|
|
|
|
func TestNewCallIterator_UnsupportedExprName(t *testing.T) {
|
|
_, err := query.NewCallIterator(
|
|
&FloatIterator{},
|
|
query.IteratorOptions{
|
|
Expr: MustParseExpr(`foobar("value")`),
|
|
},
|
|
)
|
|
|
|
if err == nil || err.Error() != "unsupported function call: foobar" {
|
|
t.Errorf("unexpected error: %s", err)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCountIterator_1K(b *testing.B) { benchmarkCountIterator(b, 1000) }
|
|
func BenchmarkCountIterator_100K(b *testing.B) { benchmarkCountIterator(b, 100000) }
|
|
func BenchmarkCountIterator_1M(b *testing.B) { benchmarkCountIterator(b, 1000000) }
|
|
|
|
func benchmarkCountIterator(b *testing.B, pointN int) {
|
|
benchmarkCallIterator(b, query.IteratorOptions{
|
|
Expr: MustParseExpr("count(value)"),
|
|
StartTime: influxql.MinTime,
|
|
EndTime: influxql.MaxTime,
|
|
}, pointN)
|
|
}
|
|
|
|
func benchmarkCallIterator(b *testing.B, opt query.IteratorOptions, pointN int) {
|
|
b.ReportAllocs()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
// Create a lightweight point generator.
|
|
p := query.FloatPoint{Name: "cpu", Value: 100}
|
|
input := FloatPointGenerator{
|
|
N: pointN,
|
|
Fn: func(i int) *query.FloatPoint { return &p },
|
|
}
|
|
|
|
// Execute call against input.
|
|
itr, err := query.NewCallIterator(&input, opt)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
query.DrainIterator(itr)
|
|
}
|
|
}
|
|
|
|
func BenchmarkSampleIterator_1k(b *testing.B) { benchmarkSampleIterator(b, 1000) }
|
|
func BenchmarkSampleIterator_100k(b *testing.B) { benchmarkSampleIterator(b, 100000) }
|
|
func BenchmarkSampleIterator_1M(b *testing.B) { benchmarkSampleIterator(b, 1000000) }
|
|
|
|
func benchmarkSampleIterator(b *testing.B, pointN int) {
|
|
b.ReportAllocs()
|
|
|
|
// Create a lightweight point generator.
|
|
p := query.FloatPoint{Name: "cpu"}
|
|
input := FloatPointGenerator{
|
|
N: pointN,
|
|
Fn: func(i int) *query.FloatPoint {
|
|
p.Value = float64(i)
|
|
return &p
|
|
},
|
|
}
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
// Execute call against input.
|
|
itr, err := query.NewSampleIterator(&input, query.IteratorOptions{}, 100)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
query.DrainIterator(itr)
|
|
}
|
|
}
|
|
|
|
func BenchmarkDistinctIterator_1K(b *testing.B) { benchmarkDistinctIterator(b, 1000) }
|
|
func BenchmarkDistinctIterator_100K(b *testing.B) { benchmarkDistinctIterator(b, 100000) }
|
|
func BenchmarkDistinctIterator_1M(b *testing.B) { benchmarkDistinctIterator(b, 1000000) }
|
|
|
|
func benchmarkDistinctIterator(b *testing.B, pointN int) {
|
|
b.ReportAllocs()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
// Create a lightweight point generator.
|
|
p := query.FloatPoint{Name: "cpu"}
|
|
input := FloatPointGenerator{
|
|
N: pointN,
|
|
Fn: func(i int) *query.FloatPoint {
|
|
p.Value = float64(i % 10)
|
|
return &p
|
|
},
|
|
}
|
|
|
|
// Execute call against input.
|
|
itr, err := query.NewDistinctIterator(&input, query.IteratorOptions{})
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
query.DrainIterator(itr)
|
|
}
|
|
}
|
|
|
|
func BenchmarkModeIterator_1K(b *testing.B) { benchmarkModeIterator(b, 1000) }
|
|
func BenchmarkModeIterator_100K(b *testing.B) { benchmarkModeIterator(b, 100000) }
|
|
func BenchmarkModeIterator_1M(b *testing.B) { benchmarkModeIterator(b, 1000000) }
|
|
|
|
func benchmarkModeIterator(b *testing.B, pointN int) {
|
|
b.ReportAllocs()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
// Create a lightweight point generator.
|
|
p := query.FloatPoint{Name: "cpu"}
|
|
input := FloatPointGenerator{
|
|
N: pointN,
|
|
Fn: func(i int) *query.FloatPoint {
|
|
p.Value = float64(10)
|
|
return &p
|
|
},
|
|
}
|
|
|
|
// Execute call against input.
|
|
itr, err := query.NewModeIterator(&input, query.IteratorOptions{})
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
query.DrainIterator(itr)
|
|
}
|
|
}
|
|
|
|
type FloatPointGenerator struct {
|
|
i int
|
|
N int
|
|
Fn func(i int) *query.FloatPoint
|
|
}
|
|
|
|
func (g *FloatPointGenerator) Close() error { return nil }
|
|
func (g *FloatPointGenerator) Stats() query.IteratorStats { return query.IteratorStats{} }
|
|
|
|
func (g *FloatPointGenerator) Next() (*query.FloatPoint, error) {
|
|
if g.i == g.N {
|
|
return nil, nil
|
|
}
|
|
p := g.Fn(g.i)
|
|
g.i++
|
|
return p, nil
|
|
}
|
|
|
|
func MustCallIterator(input query.Iterator, opt query.IteratorOptions) query.Iterator {
|
|
itr, err := query.NewCallIterator(input, opt)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return itr
|
|
}
|