mirror of
https://github.com/grafana/grafana.git
synced 2025-01-27 00:37:04 -06:00
10232c7857
* InfluxDB backend migration * Multiple queries and more * Added types * Updated preferredVisualisationType * Updated model parser test to include limit,slimit,orderByTime * Added test for building query with limit, slimit * Added test for building query with limit, slimit, orderByTime and puts them in the correct order * Add test: Influxdb response parser should parse two responses with different refIDs * Moved methods to responds parser * Add test to ensure ExecutedQueryString is populated * Move functions out of response parser class * Test for getSelectedParams * Merge cases * Change to const * Test get table columns correctly * Removed unecessary fields * Test get table rows correctly * Removed getSeries function * Added test for preferredVisualisationType * Added test for executedQueryString * Modified response parser * Removed test * Improvements * Tests * Review changes * Feature flag rename and code gen
204 lines
4.2 KiB
Go
204 lines
4.2 KiB
Go
package influxdb
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestInfluxdbQueryParser_Parse(t *testing.T) {
|
|
parser := &InfluxdbQueryParser{}
|
|
|
|
t.Run("can parse influxdb json model", func(t *testing.T) {
|
|
json := `
|
|
{
|
|
"groupBy": [
|
|
{
|
|
"params": [
|
|
"$interval"
|
|
],
|
|
"type": "time"
|
|
},
|
|
{
|
|
"params": [
|
|
"datacenter"
|
|
],
|
|
"type": "tag"
|
|
},
|
|
{
|
|
"params": [
|
|
"none"
|
|
],
|
|
"type": "fill"
|
|
}
|
|
],
|
|
"measurement": "logins.count",
|
|
"tz": "Europe/Paris",
|
|
"limit": "1",
|
|
"slimit": "1",
|
|
"orderByTime": "ASC",
|
|
"policy": "default",
|
|
"refId": "B",
|
|
"resultFormat": "time_series",
|
|
"select": [
|
|
[
|
|
{
|
|
"type": "field",
|
|
"params": [
|
|
"value"
|
|
]
|
|
},
|
|
{
|
|
"type": "count",
|
|
"params": []
|
|
}
|
|
],
|
|
[
|
|
{
|
|
"type": "field",
|
|
"params": [
|
|
"value"
|
|
]
|
|
},
|
|
{
|
|
"type": "bottom",
|
|
"params": [
|
|
3
|
|
]
|
|
}
|
|
],
|
|
[
|
|
{
|
|
"type": "field",
|
|
"params": [
|
|
"value"
|
|
]
|
|
},
|
|
{
|
|
"type": "mean",
|
|
"params": []
|
|
},
|
|
{
|
|
"type": "math",
|
|
"params": [
|
|
" / 100"
|
|
]
|
|
}
|
|
]
|
|
],
|
|
"alias": "series alias",
|
|
"tags": [
|
|
{
|
|
"key": "datacenter",
|
|
"operator": "=",
|
|
"value": "America"
|
|
},
|
|
{
|
|
"condition": "OR",
|
|
"key": "hostname",
|
|
"operator": "=",
|
|
"value": "server1"
|
|
}
|
|
]
|
|
}
|
|
`
|
|
|
|
query := backend.DataQuery{
|
|
JSON: []byte(json),
|
|
Interval: time.Second * 20,
|
|
}
|
|
|
|
res, err := parser.Parse(query)
|
|
require.NoError(t, err)
|
|
require.Len(t, res.GroupBy, 3)
|
|
require.Len(t, res.Selects, 3)
|
|
require.Len(t, res.Tags, 2)
|
|
require.Equal(t, "Europe/Paris", res.Tz)
|
|
require.Equal(t, "1", res.Limit)
|
|
require.Equal(t, "1", res.Slimit)
|
|
require.Equal(t, "ASC", res.OrderByTime)
|
|
require.Equal(t, time.Second*20, res.Interval)
|
|
require.Equal(t, "series alias", res.Alias)
|
|
})
|
|
|
|
t.Run("can parse raw query json model", func(t *testing.T) {
|
|
json := `
|
|
{
|
|
"groupBy": [
|
|
{
|
|
"params": [
|
|
"$interval"
|
|
],
|
|
"type": "time"
|
|
},
|
|
{
|
|
"params": [
|
|
"null"
|
|
],
|
|
"type": "fill"
|
|
}
|
|
],
|
|
"interval": ">10s",
|
|
"policy": "default",
|
|
"query": "RawDummyQuery",
|
|
"rawQuery": true,
|
|
"refId": "A",
|
|
"resultFormat": "time_series",
|
|
"select": [
|
|
[
|
|
{
|
|
"params": [
|
|
"value"
|
|
],
|
|
"type": "field"
|
|
},
|
|
{
|
|
"params": [
|
|
|
|
],
|
|
"type": "mean"
|
|
}
|
|
]
|
|
],
|
|
"tags": [
|
|
|
|
]
|
|
}
|
|
`
|
|
|
|
query := backend.DataQuery{
|
|
JSON: []byte(json),
|
|
Interval: time.Second * 10,
|
|
}
|
|
|
|
res, err := parser.Parse(query)
|
|
require.NoError(t, err)
|
|
require.Equal(t, "RawDummyQuery", res.RawQuery)
|
|
require.Len(t, res.GroupBy, 2)
|
|
require.Len(t, res.Selects, 1)
|
|
require.Empty(t, res.Tags)
|
|
require.Equal(t, time.Second*10, res.Interval)
|
|
})
|
|
|
|
t.Run("will enforce a minInterval of 1 millisecond", func(t *testing.T) {
|
|
json := `
|
|
{
|
|
"query": "RawDummyQuery",
|
|
"rawQuery": true,
|
|
"resultFormat": "time_series"
|
|
}
|
|
`
|
|
|
|
query := backend.DataQuery{
|
|
JSON: []byte(json),
|
|
Interval: time.Millisecond * 0,
|
|
}
|
|
|
|
res, err := parser.Parse(query)
|
|
require.NoError(t, err)
|
|
require.Equal(t, time.Millisecond*1, res.Interval)
|
|
})
|
|
}
|