|
|
|
|
@ -20,7 +20,7 @@ import ( |
|
|
|
|
"github.com/grafana/grafana/pkg/models" |
|
|
|
|
"github.com/grafana/grafana/pkg/plugins" |
|
|
|
|
acmock "github.com/grafana/grafana/pkg/services/accesscontrol/mock" |
|
|
|
|
"github.com/grafana/grafana/pkg/services/datasources" |
|
|
|
|
datasourceservice "github.com/grafana/grafana/pkg/services/datasources/service" |
|
|
|
|
"github.com/grafana/grafana/pkg/services/oauthtoken" |
|
|
|
|
"github.com/grafana/grafana/pkg/services/secrets" |
|
|
|
|
"github.com/grafana/grafana/pkg/services/secrets/fakes" |
|
|
|
|
@ -129,9 +129,9 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
t.Run("When matching route path", func(t *testing.T) { |
|
|
|
|
ctx, req := setUp() |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/v4/some/method", cfg, httpClientProvider, |
|
|
|
|
&oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
&oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
proxy.matchedRoute = routes[0] |
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, proxy.matchedRoute, dsInfo, cfg) |
|
|
|
|
@ -142,8 +142,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
t.Run("When matching route path and has dynamic url", func(t *testing.T) { |
|
|
|
|
ctx, req := setUp() |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/common/some/method", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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] |
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, proxy.matchedRoute, dsInfo, cfg) |
|
|
|
|
@ -154,8 +154,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
t.Run("When matching route path with no url", func(t *testing.T) { |
|
|
|
|
ctx, req := setUp() |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
proxy.matchedRoute = routes[4] |
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, proxy.matchedRoute, dsInfo, cfg) |
|
|
|
|
@ -165,8 +165,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
t.Run("When matching route path and has dynamic body", func(t *testing.T) { |
|
|
|
|
ctx, req := setUp() |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/body", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/body", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
proxy.matchedRoute = routes[5] |
|
|
|
|
ApplyRoute(proxy.ctx.Req.Context(), req, proxy.proxyPath, proxy.matchedRoute, dsInfo, cfg) |
|
|
|
|
@ -179,8 +179,8 @@ 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 := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/v4/some/method", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/v4/some/method", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
err = proxy.validateRequest() |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
@ -188,8 +188,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
t.Run("plugin route with admin role and user is editor", func(t *testing.T) { |
|
|
|
|
ctx, _ := setUp() |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
err = proxy.validateRequest() |
|
|
|
|
require.Error(t, err) |
|
|
|
|
@ -198,8 +198,8 @@ 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 := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "api/admin", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
err = proxy.validateRequest() |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
@ -289,8 +289,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
}, |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken1", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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,8 +305,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
req, err := http.NewRequest("GET", "http://localhost/asd", nil) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
client = newFakeHTTPClient(t, json2) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken2", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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,8 +322,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
client = newFakeHTTPClient(t, []byte{}) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "pathwithtoken1", cfg, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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,8 +344,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
ctx := &models.ReqContext{} |
|
|
|
|
|
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{BuildVersion: "5.3.0"}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
@ -370,8 +370,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
ctx := &models.ReqContext{} |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil) |
|
|
|
|
@ -394,8 +394,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
ctx := &models.ReqContext{} |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
requestURL, err := url.Parse("http://grafana.com/sub") |
|
|
|
|
@ -422,8 +422,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
ctx := &models.ReqContext{} |
|
|
|
|
var pluginRoutes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, pluginRoutes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, pluginRoutes, ctx, "", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
requestURL, err := url.Parse("http://grafana.com/sub") |
|
|
|
|
@ -445,8 +445,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
ctx := &models.ReqContext{} |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/to/folder/", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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) |
|
|
|
|
req.Header.Set("Origin", "grafana.com") |
|
|
|
|
@ -509,8 +509,8 @@ func TestDataSourceProxy_routeRule(t *testing.T) { |
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/to/folder/", &setting.Cfg{}, httpClientProvider, &mockAuthToken, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
@ -642,8 +642,8 @@ func TestDataSourceProxy_requestHandling(t *testing.T) { |
|
|
|
|
ctx, ds := setUp(t) |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -660,8 +660,8 @@ func TestDataSourceProxy_requestHandling(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -674,8 +674,8 @@ func TestDataSourceProxy_requestHandling(t *testing.T) { |
|
|
|
|
ctx, ds := setUp(t) |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -696,8 +696,8 @@ func TestDataSourceProxy_requestHandling(t *testing.T) { |
|
|
|
|
}) |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/render", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -721,8 +721,8 @@ 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 := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -745,8 +745,8 @@ 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 := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "/path/%2Ftest%2Ftest%2F", &setting.Cfg{}, httpClientProvider, &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
proxy.HandleRequest() |
|
|
|
|
@ -770,8 +770,8 @@ func TestNewDataSourceProxy_InvalidURL(t *testing.T) { |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
_, err = NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
_, 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,8 +791,8 @@ func TestNewDataSourceProxy_ProtocolLessURL(t *testing.T) { |
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
_, err = NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
_, err = NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
|
|
|
|
|
require.NoError(t, err) |
|
|
|
|
} |
|
|
|
|
@ -834,8 +834,8 @@ func TestNewDataSourceProxy_MSSQL(t *testing.T) { |
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
p, err := NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
p, err := NewDataSourceProxy(&ds, routes, &ctx, "api/method", &cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
if tc.err == nil { |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
assert.Equal(t, &url.URL{ |
|
|
|
|
@ -861,8 +861,8 @@ func getDatasourceProxiedRequest(t *testing.T, ctx *models.ReqContext, cfg *sett |
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(ds, routes, ctx, "", cfg, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
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) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
@ -985,8 +985,8 @@ func runDatasourceAuthTest(t *testing.T, secretsService secrets.Service, test *t |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
var routes []*plugins.Route |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(test.datasource, routes, ctx, "", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(test.datasource, routes, ctx, "", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://grafana.com/sub", nil) |
|
|
|
|
@ -1027,8 +1027,8 @@ func Test_PathCheck(t *testing.T) { |
|
|
|
|
} |
|
|
|
|
ctx, _ := setUp() |
|
|
|
|
secretsService := secretsManager.SetupTestService(t, fakes.NewFakeSecretsStore()) |
|
|
|
|
dsService := datasources.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(&models.DataSource{}, routes, ctx, "b", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer) |
|
|
|
|
dsService := datasourceservice.ProvideService(bus.New(), nil, secretsService, &acmock.Mock{}) |
|
|
|
|
proxy, err := NewDataSourceProxy(&models.DataSource{}, routes, ctx, "b", &setting.Cfg{}, httpclient.NewProvider(), &oauthtoken.Service{}, dsService, tracer, secretsService) |
|
|
|
|
require.NoError(t, err) |
|
|
|
|
|
|
|
|
|
require.Nil(t, proxy.validateRequest()) |
|
|
|
|
|