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

chore: support JSONRepsonse dumps callable return type bytes #3000

Merged
merged 2 commits into from
Dec 31, 2024

Conversation

imnotjames
Copy link
Contributor

@imnotjames imnotjames commented Sep 27, 2024

the dumps parameter is used to serialize the JSONResponse to text. this is often done with python's built in json.dumps but other times via ujson.dumps and orjson.dumps

however, to use orjson.dumps as suggested in the docs, you have to ignore the suggested type (str) because orjson.dumps returns a bytes

to correct this, the typing for the dumps callable has been switched to be an Callable[..., AnyStr] so either bytes or str returning callable can be passed

this was previously done in #2193 but for some reason not brought over to JSONResponse?

@imnotjames imnotjames marked this pull request as ready for review September 27, 2024 06:05
@imnotjames imnotjames requested a review from a team as a code owner September 27, 2024 06:05
@imnotjames imnotjames changed the title chore: match JSONRepsonse dumps param type to reality chore: match JSONRepsonse dumps callable return type to AnyStr Sep 27, 2024
@imnotjames imnotjames force-pushed the patch-1 branch 3 times, most recently from f390d04 to 6ba5dc7 Compare September 27, 2024 06:29
@imnotjames imnotjames changed the title chore: match JSONRepsonse dumps callable return type to AnyStr chore: support JSONRepsonse dumps callable return type bytes Sep 27, 2024
the `dumps` parameter is used to serialize the `JSONResponse` to text.  this is often done with python's built in `json.dumps` but other times via `orjson.dumps`

however, to use `orjson.dumps`, you have to ignore the suggested type (`str`) because `orjson.dumps` returns a `bytes`

to correct this, the typing for the dumps callable has been switched to be an `AnyStr` so either `bytes` or `str` returning callable can be passed
@imnotjames
Copy link
Contributor Author

For some reason the type checking is acting up - but it's on things that I don't think are related. Happy to fix as needed with a bit of direction, though.

@ahopkins ahopkins merged commit f23952e into sanic-org:main Dec 31, 2024
25 checks passed
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.

2 participants