Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug]: Error emptying S3 Bucket when objects are in it, even though force-destroy is enabled. #32307

Closed
porrige51122 opened this issue Jun 30, 2023 · 5 comments · Fixed by #32317
Labels
bug Addresses a defect in current functionality. regression Pertains to a degraded workflow resulting from an upstream patch or internal enhancement. service/s3 Issues and PRs that pertain to the s3 service. upstream Addresses functionality related to the cloud provider.

Comments

@porrige51122
Copy link

porrige51122 commented Jun 30, 2023

Terraform Core Version

1.5.1

AWS Provider Version

5.6.0, 5,6,1

Affected Resource(s)

  • aws_s3_bucket.bucket

Expected Behavior

Terraform init an S3 bucket module which contains all the things to make an S3 bucket secure and with force_destroy = true

Terraform apply to an account.

Add objects to bucket.

Terraform destroy, empties the bucket and then destroys it and all corresponding resources.

Actual Behavior

When running terraform destroy, it throws an error and doesn't delete the bucket or objects inside of it.

This is different to the behaviour in the version prior.

Relevant Error/Panic Output Snippet

╷
│ Error: emptying S3 Bucket (test-bucket-...): listing S3 Bucket (test-bucket-...) object versions: InvalidArgument: Invalid attribute name specified.
│       status code: 400, request id: JD08VXT7P4Y19J58, host id: .../...
│ 
│ 

Terraform Configuration Files

https://github.com/porrige51122/terraform-aws-secure-s3-bucket

Steps to Reproduce

terraform init

terraform apply

add an object to the bucket

terraform destroy

Debug Output

https://gist.github.com/porrige51122/b63e062cf5f670e84412c93d91830445

Panic Output

No response

Important Factoids

This is on an arm chip, and also failed on aws codebuild on an arm chip.

This also worked on versions <5.6.0

References

No response

Would you like to implement a fix?

No

@porrige51122 porrige51122 added bug Addresses a defect in current functionality. needs-triage Waiting for first response or review from a maintainer. labels Jun 30, 2023
@github-actions github-actions bot added the service/s3 Issues and PRs that pertain to the s3 service. label Jun 30, 2023
@github-actions
Copy link

Community Note

Voting for Prioritization

  • Please vote on this issue by adding a 👍 reaction to the original post to help the community and maintainers prioritize this request.
  • Please see our prioritization guide for information on how we prioritize.
  • Please do not leave "+1" or other comments that do not add relevant new information or questions, they generate extra noise for issue followers and do not help prioritize the request.

Volunteering to Work on This Issue

  • If you are interested in working on this issue, please leave a comment.
  • If this would be your first contribution, please review the contribution guide.

@porrige51122
Copy link
Author

I am going to see how minimal I can make the example. Hopefully that will narrow it down a bit more

@porrige51122
Copy link
Author

Okay, I've removed all the extra infrastructure, and just deployed the s3 bucket resource alone and the error still occurs.

@ewbankkit ewbankkit removed the needs-triage Waiting for first response or review from a maintainer. label Jun 30, 2023
@ewbankkit
Copy link
Contributor

ewbankkit commented Jun 30, 2023

Can reproduce with one of our unit tests (v5.6.1):

% AWS_REGION=us-west-2 go test -v ./internal/service/s3 -run=TestEmptyBucket -b ewbankkit-test-empty-bucket-001 -f
=== RUN   TestEmptyBucket
=== PAUSE TestEmptyBucket
=== CONT  TestEmptyBucket
    delete_test.go:33: error emptying S3 bucket (ewbankkit-test-empty-bucket-001): listing S3 Bucket (ewbankkit-test-empty-bucket-001) object versions: InvalidArgument: Invalid attribute name specified.
        	status code: 400, request id: YWJBA8NQBVRPCPMN, host id: fC3v2YQGsnRTjPsUh+g1WolqlDiyDBFrYSoASfAfaX7/tB+xVeLLlPye4YkqX8RdkpTdqwtNlfQWICS894j2yw==
--- FAIL: TestEmptyBucket (0.52s)
FAIL
FAIL	github.com/hashicorp/terraform-provider-aws/internal/service/s3	6.342s
FAIL

The same test passes with v5.5.0:

% AWS_REGION=us-west-2 go test -v ./internal/service/s3 -run=TestEmptyBucket -b ewbankkit-test-empty-bucket-002 -f
=== RUN   TestEmptyBucket
=== PAUSE TestEmptyBucket
=== CONT  TestEmptyBucket
    delete_test.go:36: 0 S3 objects deleted
--- PASS: TestEmptyBucket (0.51s)
PASS
ok  	github.com/hashicorp/terraform-provider-aws/internal/service/s3	5.788s

Suspicious:

Downgrade to AWS SDK for Go v1.44.291 and the test passes:

% go get github.com/aws/[email protected] && go mod tidy
go: downgraded github.com/aws/aws-sdk-go v1.44.292 => v1.44.291
% AWS_REGION=us-west-2 go test -v ./internal/service/s3 -run=TestEmptyBucket -b ewbankkit-test-empty-bucket-002 -f
=== RUN   TestEmptyBucket
=== PAUSE TestEmptyBucket
=== CONT  TestEmptyBucket
    delete_test.go:36: 0 S3 objects deleted
--- PASS: TestEmptyBucket (0.51s)
PASS
ok  	github.com/hashicorp/terraform-provider-aws/internal/service/s3	6.175s

Relates aws/aws-sdk-go#4897.
Relates aws/aws-sdk-go#4898.

Fixed in AWS SDK for Go v1.44.293: #32305.

@ewbankkit ewbankkit added regression Pertains to a degraded workflow resulting from an upstream patch or internal enhancement. upstream Addresses functionality related to the cloud provider. labels Jun 30, 2023
@github-actions
Copy link

I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.
If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Jul 31, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
bug Addresses a defect in current functionality. regression Pertains to a degraded workflow resulting from an upstream patch or internal enhancement. service/s3 Issues and PRs that pertain to the s3 service. upstream Addresses functionality related to the cloud provider.
Projects
None yet
2 participants