mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 00:00:39 +01:00
128 lines
2.5 KiB
Go
128 lines
2.5 KiB
Go
|
package influx
|
||
|
|
||
|
import "testing"
|
||
|
|
||
|
func TestFetchQuery(t *testing.T) {
|
||
|
testCases := []struct {
|
||
|
s Series
|
||
|
timeFilter string
|
||
|
expected string
|
||
|
}{
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
LabelPairs: []LabelPair{
|
||
|
{
|
||
|
Name: "foo",
|
||
|
Value: "bar",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
expected: `select "value" from "cpu" where "foo"='bar'`,
|
||
|
},
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
LabelPairs: []LabelPair{
|
||
|
{
|
||
|
Name: "foo",
|
||
|
Value: "bar",
|
||
|
},
|
||
|
{
|
||
|
Name: "baz",
|
||
|
Value: "qux",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
expected: `select "value" from "cpu" where "foo"='bar' and "baz"='qux'`,
|
||
|
},
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
LabelPairs: []LabelPair{
|
||
|
{
|
||
|
Name: "foo",
|
||
|
Value: "b'ar",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
timeFilter: "time >= now()",
|
||
|
expected: `select "value" from "cpu" where "foo"='b\'ar' and time >= now()`,
|
||
|
},
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
LabelPairs: []LabelPair{
|
||
|
{
|
||
|
Name: "name",
|
||
|
Value: `dev-mapper-centos\x2dswap.swap`,
|
||
|
},
|
||
|
{
|
||
|
Name: "state",
|
||
|
Value: "dev-mapp'er-c'en'tos",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
timeFilter: "time >= now()",
|
||
|
expected: `select "value" from "cpu" where "name"='dev-mapper-centos\\x2dswap.swap' and "state"='dev-mapp\'er-c\'en\'tos' and time >= now()`,
|
||
|
},
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
},
|
||
|
timeFilter: "time >= now()",
|
||
|
expected: `select "value" from "cpu" where time >= now()`,
|
||
|
},
|
||
|
{
|
||
|
s: Series{
|
||
|
Measurement: "cpu",
|
||
|
Field: "value",
|
||
|
},
|
||
|
expected: `select "value" from "cpu"`,
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tc := range testCases {
|
||
|
query := tc.s.fetchQuery(tc.timeFilter)
|
||
|
if query != tc.expected {
|
||
|
t.Fatalf("got: \n%s;\nexpected: \n%s", query, tc.expected)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestTimeFilter(t *testing.T) {
|
||
|
testCases := []struct {
|
||
|
start string
|
||
|
end string
|
||
|
expected string
|
||
|
}{
|
||
|
{
|
||
|
start: "2020-01-01T20:07:00Z",
|
||
|
end: "2020-01-01T21:07:00Z",
|
||
|
expected: "time >= '2020-01-01T20:07:00Z' and time <= '2020-01-01T21:07:00Z'",
|
||
|
},
|
||
|
{
|
||
|
expected: "",
|
||
|
},
|
||
|
{
|
||
|
start: "2020-01-01T20:07:00Z",
|
||
|
expected: "time >= '2020-01-01T20:07:00Z'",
|
||
|
},
|
||
|
{
|
||
|
end: "2020-01-01T21:07:00Z",
|
||
|
expected: "time <= '2020-01-01T21:07:00Z'",
|
||
|
},
|
||
|
}
|
||
|
for _, tc := range testCases {
|
||
|
f := timeFilter(tc.start, tc.end)
|
||
|
if f != tc.expected {
|
||
|
t.Fatalf("got: \n%q;\nexpected: \n%q", f, tc.expected)
|
||
|
}
|
||
|
}
|
||
|
}
|