mirror of
https://github.com/grafana/grafana.git
synced 2025-07-29 05:02:21 +08:00

* CloudWatch: Backport aws-sdk-go-v2 update from external plugin * Review feedback & cleaning up a couple typos
220 lines
7.8 KiB
Go
220 lines
7.8 KiB
Go
package cloudwatch
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/mock"
|
|
|
|
"github.com/grafana/grafana/pkg/tsdb/cloudwatch/mocks"
|
|
"github.com/grafana/grafana/pkg/tsdb/cloudwatch/models"
|
|
"github.com/grafana/grafana/pkg/tsdb/cloudwatch/models/resources"
|
|
"github.com/grafana/grafana/pkg/tsdb/cloudwatch/services"
|
|
"github.com/grafana/grafana/pkg/tsdb/cloudwatch/utils"
|
|
)
|
|
|
|
func TestLogGroupsRoute(t *testing.T) {
|
|
origLogGroupsService := services.NewLogGroupsService
|
|
t.Cleanup(func() {
|
|
services.NewLogGroupsService = origLogGroupsService
|
|
})
|
|
|
|
var mockLogsService = mocks.LogsService{}
|
|
services.NewLogGroupsService = func(models.CloudWatchLogsAPIProvider, bool) models.LogGroupsProvider {
|
|
return &mockLogsService
|
|
}
|
|
|
|
t.Run("successfully returns 1 log group with account id", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{{
|
|
Value: resources.LogGroup{
|
|
Arn: "some arn",
|
|
Name: "some name",
|
|
},
|
|
AccountId: utils.Pointer("111"),
|
|
}}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
assert.Equal(t, http.StatusOK, rr.Code)
|
|
assert.JSONEq(t, `[{"value":{"name":"some name", "arn":"some arn"},"accountId":"111"}]`, rr.Body.String())
|
|
})
|
|
|
|
t.Run("successfully returns multiple log groups with account id", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return(
|
|
[]resources.ResourceResponse[resources.LogGroup]{
|
|
{
|
|
Value: resources.LogGroup{
|
|
Arn: "arn 1",
|
|
Name: "name 1",
|
|
},
|
|
AccountId: utils.Pointer("111"),
|
|
}, {
|
|
Value: resources.LogGroup{
|
|
Arn: "arn 2",
|
|
Name: "name 2",
|
|
},
|
|
AccountId: utils.Pointer("222"),
|
|
},
|
|
}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
assert.Equal(t, http.StatusOK, rr.Code)
|
|
assert.JSONEq(t, `[
|
|
{
|
|
"value":{
|
|
"name":"name 1",
|
|
"arn":"arn 1"
|
|
},
|
|
"accountId":"111"
|
|
},
|
|
{
|
|
"value":{
|
|
"name":"name 2",
|
|
"arn":"arn 2"
|
|
},
|
|
"accountId":"222"
|
|
}
|
|
]`, rr.Body.String())
|
|
})
|
|
|
|
t.Run("returns error when both logGroupPrefix and logGroup Pattern are provided", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups?logGroupNamePrefix=some-prefix&logGroupPattern=some-pattern", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
assert.Equal(t, http.StatusBadRequest, rr.Code)
|
|
assert.JSONEq(t, `{"Error":"cannot set both log group name prefix and pattern", "Message":"cannot set both log group name prefix and pattern: cannot set both log group name prefix and pattern", "StatusCode":400}`, rr.Body.String())
|
|
})
|
|
|
|
t.Run("passes default log group limit and nil for logGroupNamePrefix, accountId, and logGroupPattern", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 50,
|
|
ResourceRequest: resources.ResourceRequest{},
|
|
LogGroupNamePrefix: nil,
|
|
LogGroupNamePattern: nil,
|
|
})
|
|
})
|
|
|
|
t.Run("passes default log group limit and nil for logGroupNamePrefix when both are absent", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 50,
|
|
LogGroupNamePrefix: nil,
|
|
})
|
|
})
|
|
|
|
t.Run("passes log group limit from query parameter", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups?limit=2", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 2,
|
|
})
|
|
})
|
|
|
|
t.Run("passes logGroupPrefix from query parameter", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups?logGroupNamePrefix=some-prefix", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 50,
|
|
LogGroupNamePrefix: utils.Pointer("some-prefix"),
|
|
})
|
|
})
|
|
|
|
t.Run("passes logGroupPattern from query parameter", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups?logGroupPattern=some-pattern", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 50,
|
|
LogGroupNamePattern: utils.Pointer("some-pattern"),
|
|
})
|
|
})
|
|
|
|
t.Run("passes logGroupPattern from query parameter", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).Return([]resources.ResourceResponse[resources.LogGroup]{}, nil)
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups?accountId=some-account-id", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
mockLogsService.AssertCalled(t, "GetLogGroups", resources.LogGroupsRequest{
|
|
Limit: 50,
|
|
ResourceRequest: resources.ResourceRequest{AccountId: utils.Pointer("some-account-id")},
|
|
})
|
|
})
|
|
|
|
t.Run("returns error if service returns error", func(t *testing.T) {
|
|
mockLogsService = mocks.LogsService{}
|
|
mockLogsService.On("GetLogGroups", mock.Anything).
|
|
Return([]resources.ResourceResponse[resources.LogGroup]{}, fmt.Errorf("some error"))
|
|
|
|
rr := httptest.NewRecorder()
|
|
req := httptest.NewRequest("GET", "/log-groups", nil)
|
|
ds := newTestDatasource()
|
|
handler := http.HandlerFunc(ds.resourceRequestMiddleware(ds.LogGroupsHandler))
|
|
handler.ServeHTTP(rr, req)
|
|
|
|
assert.Equal(t, http.StatusInternalServerError, rr.Code)
|
|
assert.JSONEq(t, `{"Error":"some error","Message":"GetLogGroups error: some error","StatusCode":500}`, rr.Body.String())
|
|
})
|
|
}
|