mirror of
https://github.com/grafana/grafana.git
synced 2024-11-25 10:20:29 -06:00
9a8ae3c932
* Loki: Support custom `X-Query-Tags` header * add comment
175 lines
5.7 KiB
Go
175 lines
5.7 KiB
Go
package loki
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
|
"github.com/grafana/grafana/pkg/tsdb/loki/kinds/dataquery"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestParseQuery(t *testing.T) {
|
|
t.Run("parsing query model", func(t *testing.T) {
|
|
queryContext := &backend.QueryDataRequest{
|
|
Queries: []backend.DataQuery{
|
|
{
|
|
JSON: []byte(`
|
|
{
|
|
"expr": "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms",
|
|
"format": "time_series",
|
|
"refId": "A"
|
|
}`,
|
|
),
|
|
TimeRange: backend.TimeRange{
|
|
From: time.Now().Add(-3000 * time.Second),
|
|
To: time.Now(),
|
|
},
|
|
Interval: time.Second * 15,
|
|
MaxDataPoints: 200,
|
|
},
|
|
},
|
|
}
|
|
models, err := parseQuery(queryContext)
|
|
require.NoError(t, err)
|
|
require.Equal(t, time.Second*15, models[0].Step)
|
|
require.Equal(t, "go_goroutines 15s 15000 3000s 3000 3000000", models[0].Expr)
|
|
})
|
|
|
|
t.Run("parsing query model with logsVolume supporting query type", func(t *testing.T) {
|
|
queryContext := &backend.QueryDataRequest{
|
|
Queries: []backend.DataQuery{
|
|
{
|
|
JSON: []byte(`
|
|
{
|
|
"expr": "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms",
|
|
"format": "time_series",
|
|
"refId": "A",
|
|
"supportingQueryType": "logsVolume"
|
|
}`,
|
|
),
|
|
TimeRange: backend.TimeRange{
|
|
From: time.Now().Add(-3000 * time.Second),
|
|
To: time.Now(),
|
|
},
|
|
Interval: time.Second * 15,
|
|
MaxDataPoints: 200,
|
|
},
|
|
},
|
|
}
|
|
models, err := parseQuery(queryContext)
|
|
require.NoError(t, err)
|
|
require.Equal(t, SupportingQueryLogsVolume, models[0].SupportingQueryType)
|
|
})
|
|
|
|
t.Run("parsing query model with any supporting query type", func(t *testing.T) {
|
|
queryContext := &backend.QueryDataRequest{
|
|
Queries: []backend.DataQuery{
|
|
{
|
|
JSON: []byte(`
|
|
{
|
|
"expr": "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms",
|
|
"format": "time_series",
|
|
"refId": "A",
|
|
"supportingQueryType": "foo"
|
|
}`,
|
|
),
|
|
TimeRange: backend.TimeRange{
|
|
From: time.Now().Add(-3000 * time.Second),
|
|
To: time.Now(),
|
|
},
|
|
Interval: time.Second * 15,
|
|
MaxDataPoints: 200,
|
|
},
|
|
},
|
|
}
|
|
models, err := parseQuery(queryContext)
|
|
require.NoError(t, err)
|
|
require.Equal(t, SupportingQueryType("foo"), models[0].SupportingQueryType)
|
|
})
|
|
|
|
t.Run("parsing query model with any empty query type", func(t *testing.T) {
|
|
queryContext := &backend.QueryDataRequest{
|
|
Queries: []backend.DataQuery{
|
|
{
|
|
JSON: []byte(`
|
|
{
|
|
"expr": "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms",
|
|
"format": "time_series",
|
|
"refId": "A",
|
|
"supportingQueryType": ""
|
|
}`,
|
|
),
|
|
TimeRange: backend.TimeRange{
|
|
From: time.Now().Add(-3000 * time.Second),
|
|
To: time.Now(),
|
|
},
|
|
Interval: time.Second * 15,
|
|
MaxDataPoints: 200,
|
|
},
|
|
},
|
|
}
|
|
models, err := parseQuery(queryContext)
|
|
require.NoError(t, err)
|
|
require.Equal(t, SupportingQueryNone, models[0].SupportingQueryType)
|
|
})
|
|
|
|
t.Run("interpolate variables, range between 1s and 0.5s", func(t *testing.T) {
|
|
expr := "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms"
|
|
queryType := dataquery.LokiQueryTypeRange
|
|
interval := time.Millisecond * 50
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Millisecond * 750
|
|
|
|
require.Equal(t, "go_goroutines 50ms 50 1s 1 750", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
t.Run("parsing query model, range below 0.5s", func(t *testing.T) {
|
|
expr := "go_goroutines $__interval $__interval_ms $__range $__range_s $__range_ms"
|
|
queryType := dataquery.LokiQueryTypeRange
|
|
interval := time.Millisecond * 50
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Millisecond * 250
|
|
|
|
require.Equal(t, "go_goroutines 50ms 50 0s 0 250", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
t.Run("interpolate variables, curly-braces syntax", func(t *testing.T) {
|
|
expr := "go_goroutines ${__interval} ${__interval_ms} ${__range} ${__range_s} ${__range_ms}"
|
|
queryType := dataquery.LokiQueryTypeRange
|
|
interval := time.Second * 2
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Second * 50
|
|
|
|
require.Equal(t, "go_goroutines 2s 2000 50s 50 50000", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
|
|
t.Run("interpolate variables should work with $__auto and instant query type", func(t *testing.T) {
|
|
expr := "rate({compose_project=\"docker-compose\"}[$__auto])"
|
|
queryType := dataquery.LokiQueryTypeInstant
|
|
interval := time.Second * 2
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Second * 50
|
|
|
|
require.Equal(t, "rate({compose_project=\"docker-compose\"}[50s])", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
|
|
t.Run("interpolate variables should work with $__auto and range query type", func(t *testing.T) {
|
|
expr := "rate({compose_project=\"docker-compose\"}[$__auto])"
|
|
queryType := dataquery.LokiQueryTypeRange
|
|
interval := time.Second * 2
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Second * 50
|
|
|
|
require.Equal(t, "rate({compose_project=\"docker-compose\"}[100ms])", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
|
|
t.Run("interpolate variables should return original query if no variables", func(t *testing.T) {
|
|
expr := "rate({compose_project=\"docker-compose\"}[10s])"
|
|
queryType := dataquery.LokiQueryTypeRange
|
|
interval := time.Second * 2
|
|
step := time.Millisecond * 100
|
|
timeRange := time.Second * 50
|
|
|
|
require.Equal(t, "rate({compose_project=\"docker-compose\"}[10s])", interpolateVariables(expr, interval, timeRange, queryType, step))
|
|
})
|
|
}
|