package aws import ( "context" "testing" remoteerror "github.com/cloudskiff/driftctl/pkg/remote/error" resourceaws "github.com/cloudskiff/driftctl/pkg/resource/aws" "github.com/stretchr/testify/assert" "github.com/aws/aws-sdk-go/aws/awserr" "github.com/cloudskiff/driftctl/pkg/parallel" awsdeserializer "github.com/cloudskiff/driftctl/pkg/resource/aws/deserializer" "github.com/cloudskiff/driftctl/test/goldenfile" "github.com/cloudskiff/driftctl/pkg/resource" "github.com/cloudskiff/driftctl/pkg/terraform" "github.com/cloudskiff/driftctl/test" "github.com/cloudskiff/driftctl/test/mocks" ) func TestS3BucketPolicySupplier_Resources(t *testing.T) { tests := []struct { test string dirName string bucketsIDs []string bucketLocation map[string]string listError error wantErr error }{ { test: "single bucket without policy", dirName: "s3_bucket_policy_no_policy", bucketsIDs: []string{ "dritftctl-test-no-policy", }, bucketLocation: map[string]string{ "dritftctl-test-no-policy": "eu-west-3", }, }, { test: "multiple bucket with policies", dirName: "s3_bucket_policies_multiple", bucketsIDs: []string{ "bucket-martin-test-drift", "bucket-martin-test-drift2", "bucket-martin-test-drift3", }, bucketLocation: map[string]string{ "bucket-martin-test-drift": "eu-west-1", "bucket-martin-test-drift2": "eu-west-3", "bucket-martin-test-drift3": "ap-northeast-1", }, }, { test: "cannot list bucket", dirName: "s3_bucket_policies_list_bucket", bucketsIDs: nil, listError: awserr.NewRequestFailure(nil, 403, ""), bucketLocation: map[string]string{ "bucket-martin-test-drift": "eu-west-1", "bucket-martin-test-drift2": "eu-west-3", "bucket-martin-test-drift3": "ap-northeast-1", }, wantErr: remoteerror.NewResourceEnumerationErrorWithType(awserr.NewRequestFailure(nil, 403, ""), resourceaws.AwsS3BucketPolicyResourceType, resourceaws.AwsS3BucketResourceType), }, } for _, tt := range tests { shouldUpdate := tt.dirName == *goldenfile.Update providerLibrary := terraform.NewProviderLibrary() supplierLibrary := resource.NewSupplierLibrary() if shouldUpdate { provider, err := InitTestAwsProvider(providerLibrary) if err != nil { t.Fatal(err) } factory := AwsClientFactory{config: provider.session} supplierLibrary.AddSupplier(NewS3BucketPolicySupplier(provider, factory)) } t.Run(tt.test, func(t *testing.T) { mock := mocks.NewMockAWSS3Client(tt.bucketsIDs, nil, nil, nil, tt.bucketLocation, tt.listError) factory := mocks.NewMockAwsClientFactory(mock) provider := mocks.NewMockedGoldenTFProvider(tt.dirName, providerLibrary.Provider(terraform.AWS), shouldUpdate) deserializer := awsdeserializer.NewS3BucketPolicyDeserializer() s := &S3BucketPolicySupplier{ provider, deserializer, factory, terraform.NewParallelResourceReader(parallel.NewParallelRunner(context.TODO(), 10)), } got, err := s.Resources() assert.Equal(t, err, tt.wantErr) test.CtyTestDiff(got, tt.dirName, provider, deserializer, shouldUpdate, t) }) } }