query_builder_test.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package influxdb
  2. import (
  3. "testing"
  4. "github.com/grafana/grafana/pkg/tsdb"
  5. . "github.com/smartystreets/goconvey/convey"
  6. )
  7. func TestInfluxdbQueryBuilder(t *testing.T) {
  8. Convey("Influxdb query builder", t, func() {
  9. builder := QueryBuild{}
  10. qp1, _ := NewQueryPart("field", []string{"value"})
  11. qp2, _ := NewQueryPart("mean", []string{})
  12. groupBy1, _ := NewQueryPart("time", []string{"$interval"})
  13. groupBy2, _ := NewQueryPart("fill", []string{"null"})
  14. tag1 := &Tag{Key: "hostname", Value: "server1", Operator: "="}
  15. tag2 := &Tag{Key: "hostname", Value: "server2", Operator: "=", Condition: "OR"}
  16. queryContext := &tsdb.QueryContext{
  17. TimeRange: tsdb.NewTimeRange("now-5h", "now"),
  18. }
  19. Convey("can build query", func() {
  20. query := &Query{
  21. Selects: []*Select{{*qp1, *qp2}},
  22. Measurement: "cpu",
  23. Policy: "policy",
  24. GroupBy: []*QueryPart{groupBy1, groupBy2},
  25. Interval: "10s",
  26. }
  27. rawQuery, err := builder.Build(query, queryContext)
  28. So(err, ShouldBeNil)
  29. So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "policy"."cpu" WHERE time > now()-5h GROUP BY time(10s) fill(null)`)
  30. })
  31. Convey("can asd query", func() {
  32. query := &Query{
  33. Selects: []*Select{{*qp1, *qp2}},
  34. Measurement: "cpu",
  35. GroupBy: []*QueryPart{groupBy1},
  36. Tags: []*Tag{tag1, tag2},
  37. Interval: "5s",
  38. }
  39. rawQuery, err := builder.Build(query, queryContext)
  40. So(err, ShouldBeNil)
  41. So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "cpu" WHERE "hostname" = 'server1' OR "hostname" = 'server2' AND time > now()-5h GROUP BY time(10s)`)
  42. })
  43. })
  44. }