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

Set BAD_REQUEST error code for 400 error instead of UNKNOWN #2062

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

pcmoritz
Copy link

Issue #, if available:

This fixes #1843

More crucially, it removes the current inconsistency between boto3 and the AWS CLI on the one hand and the C++ SDK on the other hand when it comes to 400 return codes.

Description of changes:

Convert a 400 http status code into a BAD_REQUEST error instead of UNKNOWN.

This PR might need to be re-done from the Amazon side since I'm not familiar with the code generation tools used. I just fixed the occurrences manually.

Check all that applies:

  • Did a review by yourself.
  • Added proper tests to cover this PR. (If tests are not applicable, explain.)
  • Checked if this PR is a breaking (APIs have been changed) change.
  • Checked if this PR will not introduce cross-platform inconsistent behavior.
  • Checked if this PR would require a ReadMe/Wiki update.

Check which platforms you have built SDK on to verify the correctness of this PR.

  • Linux
  • Windows
  • Android
  • MacOS
  • IOS
  • Other Platforms

By submitting this pull request, I confirm that you can use, modify, copy, and redistribute this contribution, under the terms of your choice.

@@ -73,6 +73,8 @@ static CoreErrors GuessBodylessErrorType(Aws::Http::HttpResponseCode responseCod
return CoreErrors::ACCESS_DENIED;
case HttpResponseCode::NOT_FOUND:
return CoreErrors::RESOURCE_NOT_FOUND;
case HttpResponseCode::BAD_REQUEST:
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the main change of this PR, everything else is plumbing to make the BAD_REQUEST error code available in every error class.

@pcmoritz
Copy link
Author

pcmoritz commented Aug 29, 2022

This PR is part of trying to improve the error messages (to the same standard as boto3) that are raised from Apache Arrow when interacting with S3: https://issues.apache.org/jira/browse/ARROW-17079

@jmklix jmklix added the needs-review This issue or pull request needs review from a core team member. label Nov 18, 2022
@jmklix jmklix removed the needs-review This issue or pull request needs review from a core team member. label Aug 9, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Expire token error code?
2 participants