query_builder_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package influxdb
  2. import (
  3. "testing"
  4. "strings"
  5. "github.com/grafana/grafana/pkg/tsdb"
  6. . "github.com/smartystreets/goconvey/convey"
  7. )
  8. func TestInfluxdbQueryBuilder(t *testing.T) {
  9. Convey("Influxdb query builder", t, func() {
  10. builder := QueryBuilder{}
  11. qp1, _ := NewQueryPart("field", []string{"value"})
  12. qp2, _ := NewQueryPart("mean", []string{})
  13. groupBy1, _ := NewQueryPart("time", []string{"$interval"})
  14. groupBy2, _ := NewQueryPart("tag", []string{"datacenter"})
  15. groupBy3, _ := NewQueryPart("fill", []string{"null"})
  16. tag1 := &Tag{Key: "hostname", Value: "server1", Operator: "="}
  17. tag2 := &Tag{Key: "hostname", Value: "server2", Operator: "=", Condition: "OR"}
  18. queryContext := &tsdb.QueryContext{
  19. TimeRange: tsdb.NewTimeRange("5m", "now"),
  20. }
  21. Convey("can build simple query", func() {
  22. query := &Query{
  23. Selects: []*Select{{*qp1, *qp2}},
  24. Measurement: "cpu",
  25. Policy: "policy",
  26. GroupBy: []*QueryPart{groupBy1, groupBy3},
  27. Interval: "10s",
  28. }
  29. rawQuery, err := builder.Build(query, queryContext)
  30. So(err, ShouldBeNil)
  31. So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "policy"."cpu" WHERE time > now() - 5m GROUP BY time(10s) fill(null)`)
  32. })
  33. Convey("can build query with group bys", func() {
  34. query := &Query{
  35. Selects: []*Select{{*qp1, *qp2}},
  36. Measurement: "cpu",
  37. GroupBy: []*QueryPart{groupBy1, groupBy2, groupBy3},
  38. Tags: []*Tag{tag1, tag2},
  39. Interval: "5s",
  40. }
  41. rawQuery, err := builder.Build(query, queryContext)
  42. So(err, ShouldBeNil)
  43. So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "cpu" WHERE "hostname" = 'server1' OR "hostname" = 'server2' AND time > now() - 5m GROUP BY time(5s), "datacenter" fill(null)`)
  44. })
  45. Convey("can render time range", func() {
  46. query := Query{}
  47. builder := &QueryBuilder{}
  48. Convey("render from: 2h to now-1h", func() {
  49. query := Query{}
  50. queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("2h", "now-1h")}
  51. So(builder.renderTimeFilter(&query, queryContext), ShouldEqual, "time > now() - 2h and time < now() - 1h")
  52. })
  53. Convey("render from: 10m", func() {
  54. queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("10m", "now")}
  55. So(builder.renderTimeFilter(&query, queryContext), ShouldEqual, "time > now() - 10m")
  56. })
  57. })
  58. Convey("can build query from raw query", func() {
  59. query := &Query{
  60. Selects: []*Select{{*qp1, *qp2}},
  61. Measurement: "cpu",
  62. Policy: "policy",
  63. GroupBy: []*QueryPart{groupBy1, groupBy3},
  64. Interval: "10s",
  65. RawQuery: "Raw query",
  66. }
  67. rawQuery, err := builder.Build(query, queryContext)
  68. So(err, ShouldBeNil)
  69. So(rawQuery, ShouldEqual, `Raw query`)
  70. })
  71. Convey("can render regex tags", func() {
  72. query := &Query{Tags: []*Tag{&Tag{Operator: "=~", Value: "value", Key: "key"}}}
  73. So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" =~ value`)
  74. })
  75. Convey("can render number tags", func() {
  76. query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "1", Key: "key"}}}
  77. So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 1`)
  78. })
  79. Convey("can render string tags", func() {
  80. query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "value", Key: "key"}}}
  81. So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 'value'`)
  82. })
  83. })
  84. }