|
|
|
|
@@ -1,6 +1,7 @@
|
|
|
|
|
package services
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"fmt"
|
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
@@ -17,11 +18,11 @@ import (
|
|
|
|
|
func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
t.Run("Should return an error in case of insufficient permissions from ListSinks", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{}, awserr.New("AccessDeniedException",
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{}, awserr.New("AccessDeniedException",
|
|
|
|
|
"AWS message", nil))
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Nil(t, resp)
|
|
|
|
|
@@ -31,10 +32,10 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Should return an error in case of any error from ListSinks", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{}, fmt.Errorf("some error"))
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{}, fmt.Errorf("some error"))
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Nil(t, resp)
|
|
|
|
|
@@ -43,10 +44,10 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Should return empty array in case no monitoring account exists", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{}, nil)
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{}, nil)
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
assert.Empty(t, resp)
|
|
|
|
|
@@ -54,26 +55,26 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Should return one monitoring account (the first) even though ListSinks returns multiple sinks", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 1"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1")},
|
|
|
|
|
{Name: aws.String("Account 2"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group2")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: new(string),
|
|
|
|
|
}, nil).Once()
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 3"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group3")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: nil,
|
|
|
|
|
}, nil)
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinks", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, nil)
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinksWithContext", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, nil)
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListSinks", 2)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListSinksWithContext", 2)
|
|
|
|
|
require.Len(t, resp, 1)
|
|
|
|
|
assert.True(t, resp[0].Value.IsMonitoringAccount)
|
|
|
|
|
assert.Equal(t, "Account 1", resp[0].Value.Label)
|
|
|
|
|
@@ -82,27 +83,27 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Should merge the first sink with attached links", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 1"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1")},
|
|
|
|
|
{Name: aws.String("Account 2"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group2")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: new(string),
|
|
|
|
|
}, nil).Once()
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 3"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group3")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: nil,
|
|
|
|
|
}, nil)
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinks", mock.Anything).Return(&oam.ListAttachedLinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinksWithContext", mock.Anything).Return(&oam.ListAttachedLinksOutput{
|
|
|
|
|
Items: []*oam.ListAttachedLinksItem{
|
|
|
|
|
{Label: aws.String("Account 10"), LinkArn: aws.String("arn:aws:logs:us-east-1:123456789013:log-group:my-log-group10")},
|
|
|
|
|
{Label: aws.String("Account 11"), LinkArn: aws.String("arn:aws:logs:us-east-1:123456789014:log-group:my-log-group11")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: new(string),
|
|
|
|
|
}, nil).Once()
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinks", mock.Anything).Return(&oam.ListAttachedLinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinksWithContext", mock.Anything).Return(&oam.ListAttachedLinksOutput{
|
|
|
|
|
Items: []*oam.ListAttachedLinksItem{
|
|
|
|
|
{Label: aws.String("Account 12"), LinkArn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group12")},
|
|
|
|
|
},
|
|
|
|
|
@@ -110,11 +111,11 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
}, nil)
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListSinks", 2)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListAttachedLinks", 2)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListSinksWithContext", 2)
|
|
|
|
|
fakeOAMClient.AssertNumberOfCalls(t, "ListAttachedLinksWithContext", 2)
|
|
|
|
|
expectedAccounts := []resources.ResourceResponse[resources.Account]{
|
|
|
|
|
{Value: resources.Account{Id: "123456789012", Label: "Account 1", Arn: "arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1", IsMonitoringAccount: true}},
|
|
|
|
|
{Value: resources.Account{Id: "123456789013", Label: "Account 10", Arn: "arn:aws:logs:us-east-1:123456789013:log-group:my-log-group10", IsMonitoringAccount: false}},
|
|
|
|
|
@@ -126,37 +127,37 @@ func TestHandleGetAccounts(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
t.Run("Should call ListAttachedLinks with arn of first sink", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 1"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: new(string),
|
|
|
|
|
}, nil).Once()
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{
|
|
|
|
|
{Name: aws.String("Account 3"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group3")},
|
|
|
|
|
},
|
|
|
|
|
NextToken: nil,
|
|
|
|
|
}, nil).Once()
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinks", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, nil)
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinksWithContext", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, nil)
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
_, _ = accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
_, _ = accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
fakeOAMClient.AssertCalled(t, "ListAttachedLinks", &oam.ListAttachedLinksInput{
|
|
|
|
|
fakeOAMClient.AssertCalled(t, "ListAttachedLinksWithContext", &oam.ListAttachedLinksInput{
|
|
|
|
|
SinkIdentifier: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1"),
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
t.Run("Should return an error in case of any error from ListAttachedLinks", func(t *testing.T) {
|
|
|
|
|
fakeOAMClient := &mocks.FakeOAMClient{}
|
|
|
|
|
fakeOAMClient.On("ListSinks", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
fakeOAMClient.On("ListSinksWithContext", mock.Anything).Return(&oam.ListSinksOutput{
|
|
|
|
|
Items: []*oam.ListSinksItem{{Name: aws.String("Account 1"), Arn: aws.String("arn:aws:logs:us-east-1:123456789012:log-group:my-log-group1")}},
|
|
|
|
|
}, nil)
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinks", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, fmt.Errorf("some error")).Once()
|
|
|
|
|
fakeOAMClient.On("ListAttachedLinksWithContext", mock.Anything).Return(&oam.ListAttachedLinksOutput{}, fmt.Errorf("some error")).Once()
|
|
|
|
|
accounts := NewAccountsService(fakeOAMClient)
|
|
|
|
|
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole()
|
|
|
|
|
resp, err := accounts.GetAccountsForCurrentUserOrRole(context.Background())
|
|
|
|
|
|
|
|
|
|
assert.Error(t, err)
|
|
|
|
|
assert.Nil(t, resp)
|
|
|
|
|
|