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

web: do not send content on HTTPError(204) #3361

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

Conversation

pawciobiel
Copy link

@pawciobiel pawciobiel commented Feb 16, 2024

Change write_error() to not send body if
status code in (204, 304) or (100 <= status code < 200),
refactored into RequestHandler._should_not_send_content(status_code)

Fixes #3360

Copy link
Member

@bdarnell bdarnell left a comment

Choose a reason for hiding this comment

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

One other thing to consider is that raise HTTPError(204) will be logged as a warning in log_exception. HTTPError was meant to be used for errors, not just a shorthand for "set status and return". We have another way to do that: self.set_status(204); raise tornado.web.Finish().

tornado/web.py Outdated Show resolved Hide resolved
tornado/web.py Outdated Show resolved Hide resolved
@bdarnell bdarnell added the web label Jun 12, 2024
@pawciobiel pawciobiel force-pushed the 3360-send-204-as-httperror branch from f627e91 to a39571b Compare June 14, 2024 12:20
Change `write_error()` to not send body if
 status code in (204, 304) or (100 <= status code < 200)
 - refactored into `RequestHandler._should_not_send_content(status_code)`

Fixes tornadoweb#3360
@pawciobiel pawciobiel force-pushed the 3360-send-204-as-httperror branch from a39571b to e33d592 Compare June 14, 2024 12:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Send 204 as HTTPError
2 participants