64 lines
2.1 KiB
Go
64 lines
2.1 KiB
Go
package query_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/davecgh/go-spew/spew"
|
|
"github.com/influxdata/influxdb/influxql"
|
|
"github.com/influxdata/influxdb/pkg/deep"
|
|
"github.com/influxdata/influxdb/query"
|
|
)
|
|
|
|
func TestIteratorMapper(t *testing.T) {
|
|
val1itr := &FloatIterator{Points: []query.FloatPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 0, Value: 1},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 5, Value: 3},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 2, Value: 2},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 8, Value: 8},
|
|
}}
|
|
|
|
val2itr := &StringIterator{Points: []query.StringPoint{
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 0, Value: "a"},
|
|
{Name: "cpu", Tags: ParseTags("host=A"), Time: 5, Value: "c"},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 2, Value: "b"},
|
|
{Name: "cpu", Tags: ParseTags("host=B"), Time: 8, Value: "h"},
|
|
}}
|
|
inputs := []query.Iterator{val1itr, val2itr}
|
|
|
|
opt := query.IteratorOptions{
|
|
Ascending: true,
|
|
Aux: []influxql.VarRef{
|
|
{Val: "val1", Type: influxql.Float},
|
|
{Val: "val2", Type: influxql.String},
|
|
},
|
|
}
|
|
itr := query.NewIteratorMapper(inputs, nil, []query.IteratorMap{
|
|
query.FieldMap(0),
|
|
query.FieldMap(1),
|
|
query.TagMap("host"),
|
|
}, opt)
|
|
if a, err := Iterators([]query.Iterator{itr}).ReadAll(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
} else if !deep.Equal(a, [][]query.Point{
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 0, Aux: []interface{}{float64(1), "a", "A"}}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=A"), Time: 5, Aux: []interface{}{float64(3), "c", "A"}}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 2, Aux: []interface{}{float64(2), "b", "B"}}},
|
|
{&query.FloatPoint{Name: "cpu", Tags: ParseTags("host=B"), Time: 8, Aux: []interface{}{float64(8), "h", "B"}}},
|
|
}) {
|
|
t.Errorf("unexpected points: %s", spew.Sdump(a))
|
|
}
|
|
|
|
for i, input := range inputs {
|
|
switch input := input.(type) {
|
|
case *FloatIterator:
|
|
if !input.Closed {
|
|
t.Errorf("iterator %d not closed", i)
|
|
}
|
|
case *StringIterator:
|
|
if !input.Closed {
|
|
t.Errorf("iterator %d not closed", i)
|
|
}
|
|
}
|
|
}
|
|
}
|