grafana/pkg/tsdb/influxdb/query_builder_test.go

56 lines
1.6 KiB
Go
Raw Normal View History

2016-10-05 03:56:34 -05:00
package influxdb
import (
"testing"
"github.com/grafana/grafana/pkg/tsdb"
2016-10-05 03:56:34 -05:00
. "github.com/smartystreets/goconvey/convey"
)
func TestInfluxdbQueryBuilder(t *testing.T) {
Convey("Influxdb query builder", t, func() {
2016-10-06 07:16:26 -05:00
builder := QueryBuilder{}
2016-10-05 03:56:34 -05:00
qp1, _ := NewQueryPart("field", []string{"value"})
qp2, _ := NewQueryPart("mean", []string{})
groupBy1, _ := NewQueryPart("time", []string{"$interval"})
groupBy2, _ := NewQueryPart("fill", []string{"null"})
tag1 := &Tag{Key: "hostname", Value: "server1", Operator: "="}
tag2 := &Tag{Key: "hostname", Value: "server2", Operator: "=", Condition: "OR"}
2016-10-05 03:56:34 -05:00
queryContext := &tsdb.QueryContext{
2016-10-06 07:16:26 -05:00
TimeRange: tsdb.NewTimeRange("now-5m", "now"),
}
2016-10-06 07:16:26 -05:00
Convey("can build simple query", func() {
query := &Query{
Selects: []*Select{{*qp1, *qp2}},
Measurement: "cpu",
Policy: "policy",
GroupBy: []*QueryPart{groupBy1, groupBy2},
Interval: "10s",
}
rawQuery, err := builder.Build(query, queryContext)
So(err, ShouldBeNil)
2016-10-06 07:16:26 -05:00
So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "policy"."cpu" WHERE time > now() - 5m GROUP BY time(10s) fill(null)`)
2016-10-05 03:56:34 -05:00
})
2016-10-06 07:16:26 -05:00
Convey("can build query with group bys", func() {
query := &Query{
Selects: []*Select{{*qp1, *qp2}},
Measurement: "cpu",
GroupBy: []*QueryPart{groupBy1},
Tags: []*Tag{tag1, tag2},
Interval: "5s",
}
rawQuery, err := builder.Build(query, queryContext)
So(err, ShouldBeNil)
2016-10-06 07:16:26 -05:00
So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "cpu" WHERE "hostname" = 'server1' OR "hostname" = 'server2' AND time > now() - 5m GROUP BY time(10s)`)
2016-10-05 03:56:34 -05:00
})
})
}