query_test.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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. qp1, _ := NewQueryPart("field", []string{"value"})
  11. qp2, _ := NewQueryPart("mean", []string{})
  12. groupBy1, _ := NewQueryPart("time", []string{"$interval"})
  13. groupBy2, _ := NewQueryPart("tag", []string{"datacenter"})
  14. groupBy3, _ := NewQueryPart("fill", []string{"null"})
  15. tag1 := &Tag{Key: "hostname", Value: "server1", Operator: "="}
  16. tag2 := &Tag{Key: "hostname", Value: "server2", Operator: "=", Condition: "OR"}
  17. queryContext := &tsdb.QueryContext{
  18. TimeRange: tsdb.NewTimeRange("5m", "now"),
  19. }
  20. Convey("can build simple query", func() {
  21. query := &Query{
  22. Selects: []*Select{{*qp1, *qp2}},
  23. Measurement: "cpu",
  24. Policy: "policy",
  25. GroupBy: []*QueryPart{groupBy1, groupBy3},
  26. Interval: "10s",
  27. }
  28. rawQuery, err := query.Build(queryContext)
  29. So(err, ShouldBeNil)
  30. So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "policy"."cpu" WHERE time > now() - 5m GROUP BY time(10s) fill(null)`)
  31. })
  32. Convey("can build query with group bys", func() {
  33. query := &Query{
  34. Selects: []*Select{{*qp1, *qp2}},
  35. Measurement: "cpu",
  36. GroupBy: []*QueryPart{groupBy1, groupBy2, groupBy3},
  37. Tags: []*Tag{tag1, tag2},
  38. Interval: "5s",
  39. }
  40. rawQuery, err := query.Build(queryContext)
  41. So(err, ShouldBeNil)
  42. 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)`)
  43. })
  44. Convey("can render time range", func() {
  45. query := Query{}
  46. Convey("render from: 2h to now-1h", func() {
  47. query := Query{}
  48. queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("2h", "now-1h")}
  49. So(query.renderTimeFilter(queryContext), ShouldEqual, "time > now() - 2h and time < now() - 1h")
  50. })
  51. Convey("render from: 10m", func() {
  52. queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("10m", "now")}
  53. So(query.renderTimeFilter(queryContext), ShouldEqual, "time > now() - 10m")
  54. })
  55. })
  56. Convey("can build query from raw query", func() {
  57. query := &Query{
  58. Selects: []*Select{{*qp1, *qp2}},
  59. Measurement: "cpu",
  60. Policy: "policy",
  61. GroupBy: []*QueryPart{groupBy1, groupBy3},
  62. Interval: "10s",
  63. RawQuery: "Raw query",
  64. UseRawQuery: true,
  65. }
  66. rawQuery, err := query.Build(queryContext)
  67. So(err, ShouldBeNil)
  68. So(rawQuery, ShouldEqual, `Raw query`)
  69. })
  70. Convey("can render normal tags without operator", func() {
  71. query := &Query{Tags: []*Tag{&Tag{Operator: "", Value: `value`, Key: "key"}}}
  72. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 'value'`)
  73. })
  74. Convey("can render regex tags without operator", func() {
  75. query := &Query{Tags: []*Tag{&Tag{Operator: "", Value: `/value/`, Key: "key"}}}
  76. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" =~ /value/`)
  77. })
  78. Convey("can render regex tags", func() {
  79. query := &Query{Tags: []*Tag{&Tag{Operator: "=~", Value: `/value/`, Key: "key"}}}
  80. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" =~ /value/`)
  81. })
  82. Convey("can render number tags", func() {
  83. query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "10001", Key: "key"}}}
  84. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 10001`)
  85. })
  86. Convey("can render number tags with decimals", func() {
  87. query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "10001.1", Key: "key"}}}
  88. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 10001.1`)
  89. })
  90. Convey("can render string tags", func() {
  91. query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "value", Key: "key"}}}
  92. So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 'value'`)
  93. })
  94. Convey("can render regular measurement", func() {
  95. query := &Query{Measurement: `apa`, Policy: "policy"}
  96. So(query.renderMeasurement(), ShouldEqual, ` FROM "policy"."apa"`)
  97. })
  98. Convey("can render regexp measurement", func() {
  99. query := &Query{Measurement: `/apa/`, Policy: "policy"}
  100. So(query.renderMeasurement(), ShouldEqual, ` FROM "policy"./apa/`)
  101. })
  102. })
  103. }