Skip to content

Commit f924b24

Browse files
committed
tech(influxdb): refactor query builder
trying to reduce the amounts of moving parts for influxdb
1 parent a948dfe commit f924b24

File tree

3 files changed

+26
-32
lines changed

3 files changed

+26
-32
lines changed

pkg/tsdb/influxdb/influxdb.go

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -18,15 +18,13 @@ import (
1818
type InfluxDBExecutor struct {
1919
*tsdb.DataSourceInfo
2020
QueryParser *InfluxdbQueryParser
21-
QueryBuilder *QueryBuilder
2221
ResponseParser *ResponseParser
2322
}
2423

2524
func NewInfluxDBExecutor(dsInfo *tsdb.DataSourceInfo) tsdb.Executor {
2625
return &InfluxDBExecutor{
2726
DataSourceInfo: dsInfo,
2827
QueryParser: &InfluxdbQueryParser{},
29-
QueryBuilder: &QueryBuilder{},
3028
ResponseParser: &ResponseParser{},
3129
}
3230
}
@@ -51,7 +49,7 @@ func (e *InfluxDBExecutor) Execute(ctx context.Context, queries tsdb.QuerySlice,
5149
return result.WithError(err)
5250
}
5351

54-
rawQuery, err := e.QueryBuilder.Build(query, context)
52+
rawQuery, err := query.Build(context)
5553
if err != nil {
5654
return result.WithError(err)
5755
}

pkg/tsdb/influxdb/query_builder.go renamed to pkg/tsdb/influxdb/query.go

Lines changed: 14 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -14,28 +14,26 @@ var (
1414
regexpOperatorPattern *regexp.Regexp = regexp.MustCompile(`^\/.*\/$`)
1515
)
1616

17-
type QueryBuilder struct{}
18-
19-
func (qb *QueryBuilder) Build(query *Query, queryContext *tsdb.QueryContext) (string, error) {
17+
func (query *Query) Build(queryContext *tsdb.QueryContext) (string, error) {
2018
if query.UseRawQuery && query.RawQuery != "" {
2119
q := query.RawQuery
2220

23-
q = strings.Replace(q, "$timeFilter", qb.renderTimeFilter(query, queryContext), 1)
21+
q = strings.Replace(q, "$timeFilter", query.renderTimeFilter(queryContext), 1)
2422
q = strings.Replace(q, "$interval", tsdb.CalculateInterval(queryContext.TimeRange), 1)
2523

2624
return q, nil
2725
}
2826

29-
res := qb.renderSelectors(query, queryContext)
30-
res += qb.renderMeasurement(query)
31-
res += qb.renderWhereClause(query)
32-
res += qb.renderTimeFilter(query, queryContext)
33-
res += qb.renderGroupBy(query, queryContext)
27+
res := query.renderSelectors(queryContext)
28+
res += query.renderMeasurement()
29+
res += query.renderWhereClause()
30+
res += query.renderTimeFilter(queryContext)
31+
res += query.renderGroupBy(queryContext)
3432

3533
return res, nil
3634
}
3735

38-
func (qb *QueryBuilder) renderTags(query *Query) []string {
36+
func (query *Query) renderTags() []string {
3937
var res []string
4038
for i, tag := range query.Tags {
4139
str := ""
@@ -76,7 +74,7 @@ func (qb *QueryBuilder) renderTags(query *Query) []string {
7674
return res
7775
}
7876

79-
func (qb *QueryBuilder) renderTimeFilter(query *Query, queryContext *tsdb.QueryContext) string {
77+
func (query *Query) renderTimeFilter(queryContext *tsdb.QueryContext) string {
8078
from := "now() - " + queryContext.TimeRange.From
8179
to := ""
8280

@@ -87,7 +85,7 @@ func (qb *QueryBuilder) renderTimeFilter(query *Query, queryContext *tsdb.QueryC
8785
return fmt.Sprintf("time > %s%s", from, to)
8886
}
8987

90-
func (qb *QueryBuilder) renderSelectors(query *Query, queryContext *tsdb.QueryContext) string {
88+
func (query *Query) renderSelectors(queryContext *tsdb.QueryContext) string {
9189
res := "SELECT "
9290

9391
var selectors []string
@@ -103,7 +101,7 @@ func (qb *QueryBuilder) renderSelectors(query *Query, queryContext *tsdb.QueryCo
103101
return res + strings.Join(selectors, ", ")
104102
}
105103

106-
func (qb *QueryBuilder) renderMeasurement(query *Query) string {
104+
func (query *Query) renderMeasurement() string {
107105
policy := ""
108106
if query.Policy == "" || query.Policy == "default" {
109107
policy = ""
@@ -113,9 +111,9 @@ func (qb *QueryBuilder) renderMeasurement(query *Query) string {
113111
return fmt.Sprintf(` FROM %s"%s"`, policy, query.Measurement)
114112
}
115113

116-
func (qb *QueryBuilder) renderWhereClause(query *Query) string {
114+
func (query *Query) renderWhereClause() string {
117115
res := " WHERE "
118-
conditions := qb.renderTags(query)
116+
conditions := query.renderTags()
119117
res += strings.Join(conditions, " ")
120118
if len(conditions) > 0 {
121119
res += " AND "
@@ -124,7 +122,7 @@ func (qb *QueryBuilder) renderWhereClause(query *Query) string {
124122
return res
125123
}
126124

127-
func (qb *QueryBuilder) renderGroupBy(query *Query, queryContext *tsdb.QueryContext) string {
125+
func (query *Query) renderGroupBy(queryContext *tsdb.QueryContext) string {
128126
groupBy := ""
129127
for i, group := range query.GroupBy {
130128
if i == 0 {

pkg/tsdb/influxdb/query_builder_test.go renamed to pkg/tsdb/influxdb/query_test.go

Lines changed: 11 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,6 @@ import (
1212
func TestInfluxdbQueryBuilder(t *testing.T) {
1313

1414
Convey("Influxdb query builder", t, func() {
15-
builder := QueryBuilder{}
1615

1716
qp1, _ := NewQueryPart("field", []string{"value"})
1817
qp2, _ := NewQueryPart("mean", []string{})
@@ -37,7 +36,7 @@ func TestInfluxdbQueryBuilder(t *testing.T) {
3736
Interval: "10s",
3837
}
3938

40-
rawQuery, err := builder.Build(query, queryContext)
39+
rawQuery, err := query.Build(queryContext)
4140
So(err, ShouldBeNil)
4241
So(rawQuery, ShouldEqual, `SELECT mean("value") FROM "policy"."cpu" WHERE time > now() - 5m GROUP BY time(10s) fill(null)`)
4342
})
@@ -51,23 +50,22 @@ func TestInfluxdbQueryBuilder(t *testing.T) {
5150
Interval: "5s",
5251
}
5352

54-
rawQuery, err := builder.Build(query, queryContext)
53+
rawQuery, err := query.Build(queryContext)
5554
So(err, ShouldBeNil)
5655
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)`)
5756
})
5857

5958
Convey("can render time range", func() {
6059
query := Query{}
61-
builder := &QueryBuilder{}
6260
Convey("render from: 2h to now-1h", func() {
6361
query := Query{}
6462
queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("2h", "now-1h")}
65-
So(builder.renderTimeFilter(&query, queryContext), ShouldEqual, "time > now() - 2h and time < now() - 1h")
63+
So(query.renderTimeFilter(queryContext), ShouldEqual, "time > now() - 2h and time < now() - 1h")
6664
})
6765

6866
Convey("render from: 10m", func() {
6967
queryContext := &tsdb.QueryContext{TimeRange: tsdb.NewTimeRange("10m", "now")}
70-
So(builder.renderTimeFilter(&query, queryContext), ShouldEqual, "time > now() - 10m")
68+
So(query.renderTimeFilter(queryContext), ShouldEqual, "time > now() - 10m")
7169
})
7270
})
7371

@@ -82,45 +80,45 @@ func TestInfluxdbQueryBuilder(t *testing.T) {
8280
UseRawQuery: true,
8381
}
8482

85-
rawQuery, err := builder.Build(query, queryContext)
83+
rawQuery, err := query.Build(queryContext)
8684
So(err, ShouldBeNil)
8785
So(rawQuery, ShouldEqual, `Raw query`)
8886
})
8987

9088
Convey("can render normal tags without operator", func() {
9189
query := &Query{Tags: []*Tag{&Tag{Operator: "", Value: `value`, Key: "key"}}}
9290

93-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 'value'`)
91+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 'value'`)
9492
})
9593

9694
Convey("can render regex tags without operator", func() {
9795
query := &Query{Tags: []*Tag{&Tag{Operator: "", Value: `/value/`, Key: "key"}}}
9896

99-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" =~ /value/`)
97+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" =~ /value/`)
10098
})
10199

102100
Convey("can render regex tags", func() {
103101
query := &Query{Tags: []*Tag{&Tag{Operator: "=~", Value: `/value/`, Key: "key"}}}
104102

105-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" =~ /value/`)
103+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" =~ /value/`)
106104
})
107105

108106
Convey("can render number tags", func() {
109107
query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "10001", Key: "key"}}}
110108

111-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 10001`)
109+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 10001`)
112110
})
113111

114112
Convey("can render number tags with decimals", func() {
115113
query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "10001.1", Key: "key"}}}
116114

117-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 10001.1`)
115+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 10001.1`)
118116
})
119117

120118
Convey("can render string tags", func() {
121119
query := &Query{Tags: []*Tag{&Tag{Operator: "=", Value: "value", Key: "key"}}}
122120

123-
So(strings.Join(builder.renderTags(query), ""), ShouldEqual, `"key" = 'value'`)
121+
So(strings.Join(query.renderTags(), ""), ShouldEqual, `"key" = 'value'`)
124122
})
125123
})
126124
}

0 commit comments

Comments
 (0)