query_builder_test.go 1.4 KB

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