2016-09-27 14:39:51 +02:00
|
|
|
package testdata
|
|
|
|
|
|
|
|
|
|
import (
|
2016-10-03 09:38:03 +02:00
|
|
|
"context"
|
|
|
|
|
|
2016-09-27 18:17:39 +02:00
|
|
|
"github.com/grafana/grafana/pkg/log"
|
2016-09-27 14:39:51 +02:00
|
|
|
"github.com/grafana/grafana/pkg/tsdb"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type TestDataExecutor struct {
|
|
|
|
|
*tsdb.DataSourceInfo
|
2016-09-27 18:17:39 +02:00
|
|
|
log log.Logger
|
2016-09-27 14:39:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewTestDataExecutor(dsInfo *tsdb.DataSourceInfo) tsdb.Executor {
|
2016-09-27 18:17:39 +02:00
|
|
|
return &TestDataExecutor{
|
|
|
|
|
DataSourceInfo: dsInfo,
|
|
|
|
|
log: log.New("tsdb.testdata"),
|
|
|
|
|
}
|
2016-09-27 14:39:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
|
tsdb.RegisterExecutor("grafana-testdata-datasource", NewTestDataExecutor)
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-03 09:38:03 +02:00
|
|
|
func (e *TestDataExecutor) Execute(ctx context.Context, queries tsdb.QuerySlice, context *tsdb.QueryContext) *tsdb.BatchResult {
|
2016-09-27 14:39:51 +02:00
|
|
|
result := &tsdb.BatchResult{}
|
|
|
|
|
result.QueryResults = make(map[string]*tsdb.QueryResult)
|
|
|
|
|
|
|
|
|
|
for _, query := range queries {
|
2016-09-27 18:17:39 +02:00
|
|
|
scenarioId := query.Model.Get("scenarioId").MustString("random_walk")
|
|
|
|
|
if scenario, exist := ScenarioRegistry[scenarioId]; exist {
|
|
|
|
|
result.QueryResults[query.RefId] = scenario.Handler(query, context)
|
|
|
|
|
result.QueryResults[query.RefId].RefId = query.RefId
|
|
|
|
|
} else {
|
|
|
|
|
e.log.Error("Scenario not found", "scenarioId", scenarioId)
|
2016-09-27 14:39:51 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
}
|