package repository import ( "strings" "testing" "github.com/aws/aws-sdk-go/service/kms" "github.com/aws/aws-sdk-go/aws" "github.com/stretchr/testify/mock" "github.com/cloudskiff/driftctl/mocks" "github.com/r3labs/diff/v2" "github.com/stretchr/testify/assert" ) func Test_KMSRepository_ListAllKeys(t *testing.T) { tests := []struct { name string mocks func(client *mocks.KMSClient) want []*kms.KeyListEntry wantErr error }{ { name: "List only customer keys", mocks: func(client *mocks.KMSClient) { client.On("ListKeysPages", &kms.ListKeysInput{}, mock.MatchedBy(func(callback func(res *kms.ListKeysOutput, lastPage bool) bool) bool { callback(&kms.ListKeysOutput{ Keys: []*kms.KeyListEntry{ {KeyId: aws.String("1")}, {KeyId: aws.String("2")}, {KeyId: aws.String("3")}, }, }, true) return true })).Return(nil) client.On("DescribeKey", &kms.DescribeKeyInput{ KeyId: aws.String("1"), }).Return(&kms.DescribeKeyOutput{ KeyMetadata: &kms.KeyMetadata{ KeyId: aws.String("1"), KeyManager: aws.String("CUSTOMER"), }, }, nil) client.On("DescribeKey", &kms.DescribeKeyInput{ KeyId: aws.String("2"), }).Return(&kms.DescribeKeyOutput{ KeyMetadata: &kms.KeyMetadata{ KeyId: aws.String("2"), KeyManager: aws.String("AWS"), }, }, nil) client.On("DescribeKey", &kms.DescribeKeyInput{ KeyId: aws.String("3"), }).Return(&kms.DescribeKeyOutput{ KeyMetadata: &kms.KeyMetadata{ KeyId: aws.String("3"), KeyManager: aws.String("AWS"), }, }, nil) }, want: []*kms.KeyListEntry{ {KeyId: aws.String("1")}, }, }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { client := &mocks.KMSClient{} tt.mocks(client) r := &kmsRepository{ client: client, } got, err := r.ListAllKeys() assert.Equal(t, tt.wantErr, err) changelog, err := diff.Diff(got, tt.want) assert.Nil(t, err) if len(changelog) > 0 { for _, change := range changelog { t.Errorf("%s: %v -> %v", strings.Join(change.Path, "."), change.From, change.To) } t.Fail() } }) } }