grafana/pkg/tsdb/testdatasource/testdata.go

43 lines
1.1 KiB
Go
Raw Normal View History

package testdatasource
2016-09-27 07:39:51 -05:00
import (
"context"
"github.com/grafana/grafana/pkg/infra/log"
"github.com/grafana/grafana/pkg/models"
2016-09-27 07:39:51 -05:00
"github.com/grafana/grafana/pkg/tsdb"
)
type TestDataExecutor struct {
*models.DataSource
log log.Logger
2016-09-27 07:39:51 -05:00
}
2017-09-21 03:44:25 -05:00
func NewTestDataExecutor(dsInfo *models.DataSource) (tsdb.TsdbQueryEndpoint, error) {
return &TestDataExecutor{
DataSource: dsInfo,
log: log.New("tsdb.testdata"),
}, nil
2016-09-27 07:39:51 -05:00
}
func init() {
tsdb.RegisterTsdbQueryEndpoint("testdata", NewTestDataExecutor)
2016-09-27 07:39:51 -05:00
}
func (e *TestDataExecutor) Query(ctx context.Context, dsInfo *models.DataSource, tsdbQuery *tsdb.TsdbQuery) (*tsdb.Response, error) {
result := &tsdb.Response{}
result.Results = make(map[string]*tsdb.QueryResult)
2016-09-27 07:39:51 -05:00
2017-09-21 08:23:34 -05:00
for _, query := range tsdbQuery.Queries {
scenarioId := query.Model.Get("scenarioId").MustString("random_walk")
if scenario, exist := ScenarioRegistry[scenarioId]; exist {
result.Results[query.RefId] = scenario.Handler(query, tsdbQuery)
result.Results[query.RefId].RefId = query.RefId
} else {
e.log.Error("Scenario not found", "scenarioId", scenarioId)
2016-09-27 07:39:51 -05:00
}
}
return result, nil
2016-09-27 07:39:51 -05:00
}