|
|
|
|
@@ -21,6 +21,7 @@ import (
|
|
|
|
|
"github.com/grafana/grafana/pkg/plugins"
|
|
|
|
|
acmock "github.com/grafana/grafana/pkg/services/accesscontrol/mock"
|
|
|
|
|
datasourceservice "github.com/grafana/grafana/pkg/services/datasources/service"
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/featuremgmt"
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/oauthtoken"
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/secrets"
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/secrets/fakes"
|
|
|
|
|
@@ -129,7 +130,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("When matching route path", func(t *testing.T) {
|
|
|
|
|
ctx, req := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/v4/some/method", cfg, httpClientProvider,
|
|
|
|
|
&oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -142,7 +143,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("When matching route path and has dynamic url", func(t *testing.T) {
|
|
|
|
|
ctx, req := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/common/some/method", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
proxy.matchedRoute = routes[3]
|
|
|
|
|
@@ -154,7 +155,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("When matching route path with no url", func(t *testing.T) {
|
|
|
|
|
ctx, req := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
proxy.matchedRoute = routes[4]
|
|
|
|
|
@@ -165,7 +166,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("When matching route path and has dynamic body", func(t *testing.T) {
|
|
|
|
|
ctx, req := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/body", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
proxy.matchedRoute = routes[5]
|
|
|
|
|
@@ -179,7 +180,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
t.Run("Validating request", func(t *testing.T) {
|
|
|
|
|
t.Run("plugin route with valid role", func(t *testing.T) {
|
|
|
|
|
ctx, _ := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/v4/some/method", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
err = proxy.validateRequest()
|
|
|
|
|
@@ -188,7 +189,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("plugin route with admin role and user is editor", func(t *testing.T) {
|
|
|
|
|
ctx, _ := setUp()
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
err = proxy.validateRequest()
|
|
|
|
|
@@ -198,7 +199,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
t.Run("plugin route with admin role and user is admin", func(t *testing.T) {
|
|
|
|
|
ctx, _ := setUp()
|
|
|
|
|
ctx.SignedInUser.OrgRole = models.ROLE_ADMIN
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
err = proxy.validateRequest()
|
|
|
|
|
@@ -289,7 +290,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken1", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, routes[0], dsInfo, cfg)
|
|
|
|
|
@@ -305,7 +306,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
req, err := http.NewRequest("GET", "http://localhost/asd", nil)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
client = newFakeHTTPClient(t, json2)
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken2", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, routes[1], dsInfo, cfg)
|
|
|
|
|
@@ -322,7 +323,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
client = newFakeHTTPClient(t, []byte{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken1", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, routes[0], dsInfo, cfg)
|
|
|
|
|
@@ -344,7 +345,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
ctx := &models.ReqContext{}
|
|
|
|
|
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{BuildVersion: "5.3.0"}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil)
|
|
|
|
|
@@ -370,7 +371,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
ctx := &models.ReqContext{}
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -394,7 +395,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
ctx := &models.ReqContext{}
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -422,7 +423,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
ctx := &models.ReqContext{}
|
|
|
|
|
var pluginRoutes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, pluginRoutes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -445,7 +446,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
ctx := &models.ReqContext{}
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/to/folder/", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil)
|
|
|
|
|
@@ -509,7 +510,7 @@ func TestDataSourceProxy_routeRule(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/to/folder/", &setting.Cfg{}, httpClientProvider, &mockAuthToken, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
req, err = http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil)
|
|
|
|
|
@@ -642,7 +643,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
ctx, ds := setUp(t)
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -660,7 +661,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
})
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -674,7 +675,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
ctx, ds := setUp(t)
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -696,7 +697,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
})
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -721,7 +722,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
ctx.Req = httptest.NewRequest("GET", "/api/datasources/proxy/1/path/%2Ftest%2Ftest%2F?query=%2Ftest%2Ftest%2F", nil)
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -745,7 +746,7 @@ func TestDataSourceProxy_requestHandling(t *testing.T) {
|
|
|
|
|
ctx.Req = httptest.NewRequest("GET", "/api/datasources/proxy/1/path/%2Ftest%2Ftest%2F?query=%2Ftest%2Ftest%2F", nil)
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -770,7 +771,7 @@ func TestNewDataSourceProxy_InvalidURL(t *testing.T) {
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
_, err = NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
assert.True(t, strings.HasPrefix(err.Error(), `validation of data source URL "://host/root" failed`))
|
|
|
|
|
@@ -791,7 +792,7 @@ func TestNewDataSourceProxy_ProtocolLessURL(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
_, err = NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -834,7 +835,7 @@ func TestNewDataSourceProxy_MSSQL(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
p, err := NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
if tc.err == nil {
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -861,7 +862,7 @@ func getDatasourceProxiedRequest(t *testing.T, ctx *models.ReqContext, cfg *sett
|
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil)
|
|
|
|
|
@@ -985,7 +986,7 @@ func runDatasourceAuthTest(t *testing.T, secretsService secrets.Service, test *t
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(test.datasource, routes, ctx, "", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -1027,7 +1028,7 @@ func Test_PathCheck(t *testing.T) {
|
|
|
|
|
}
|
|
|
|
|
ctx, _ := setUp()
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore())
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{})
|
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, featuremgmt.WithFeatures(), &acmock.Mock{}, acmock.NewPermissionsServicesMock())
|
|
|
|
|
proxy, err := NewDataSourceProxy(&models.DataSource{}, routes, ctx, "b", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
|