-
-
Notifications
You must be signed in to change notification settings - Fork 30.8k
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
bpo-46195: Do not add Optional
in get_type_hints
#30304
Conversation
A note about commit messages / PR titles:
So for this PR (if I understand current title correctly) it could be:
|
get_type_hints
does not add Optional
anymoreOptional
in get_type_hints
@merwok thanks, it is way more readable now! Wording (and writing in general) in English is something I really try to improve. |
@Zac-HD do we rely on this behavior in |
It's certainly observable by our users, and would probably make some of our tests fail. That said, I support the more consistent design proposed in the BPO issue, and we'll be fine carrying another clause in our type hints wrapper in Hypothesis. Probably important to reference the relevant PEP (section of 484, I think?) in the changelog though. |
Will this be applied in Python 3.11, or is it intended to be back-ported to previous versions? |
In my opinion this should be 3.11+ only 🤔 |
I have production code that currently assumes parameters that default to |
A Python core developer has requested some changes be made to your pull request before we can consider merging it. If you could please address their requests along with any other requests in other reviews from core developers that would be appreciated. Once you have made the requested changes, please leave a comment on this pull request containing the phrase |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In my opinion this should be 3.11+ only 🤔
Yeah. This is definitely a breaking change so it should be 3.11+ only. I wonder how many runtime checkers are affected or even use get_type_hints
for that matter? @samuelcolvin can I trouble you for an opinion on this please? @Tinche too for cattrs too please. Thank you.
In short, typing.get_type_hints
automatically wraps a type annotation with Optional
if it sees a default None
. This PR proposes to cease that behavior.
Misc/NEWS.d/next/Library/2021-12-30-21-38-51.bpo-46195.jFKGq_.rst
Outdated
Show resolved
Hide resolved
@Fidget-Spinner I'm totally fine with this, correct change in my opinion. Just out of curiosity, does this change only apply to function parameters or class members too? |
Co-authored-by: Ken Jin <28750310+Fidget-Spinner@users.noreply.github.com>
@Tinche for classes Here are two examples, » ./python.exe
Python 3.11.0a3+ (heads/main:e13cdca0f5, Jan 11 2022, 12:43:49) [Clang 11.0.0 (clang-1100.0.33.16)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import typing
>>> class A:
... x: int = None
...
>>> typing.get_type_hints(A)
{'x': <class 'int'>} » python
Python 3.9.9 (main, Dec 21 2021, 11:35:28)
[Clang 11.0.0 (clang-1100.0.33.16)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import typing
>>> class A:
... x: int = None
...
>>> typing.get_type_hints(A)
{'x': <class 'int'>} However, I can't find a test case for this 🤔 |
Thanks for the info! |
Thanks for the great question! 👍 I've added this corner case to our tests in a separate PR: #30535 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like this change, just a comment on the docs.
Doc/library/typing.rst
Outdated
``Optional`` annotation is not added implicitly anymore | ||
when ``None`` default is used for a function argument. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like the wording in the removed docs better. Suggestion:
"Previously, Optional[t]
was added for function and method annotations if a default value equal to None
was set. Now the annotation is returned unchanged."
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great addition!
Thanks @Fidget-Spinner for asking my opinion, really useful to get a heads up about things like this. I don't think it will affect pydantic, if it does we can take care of it when adding support for 3.11. I'm happy with this change provided it's no back-ported to other versions of python. |
Misc/NEWS.d/next/Library/2021-12-30-21-38-51.bpo-46195.jFKGq_.rst
Outdated
Show resolved
Hide resolved
Co-authored-by: Jelle Zijlstra <jelle.zijlstra@gmail.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@gvanrossum this is another one I'd like to merge.
@gpshead previously requested changes, but his request was addressed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
IIUC, @gpshead mist still approve it.
Since python-3.11, `typing.get_type_hints()` will not add Optional[t] to type annotations even if a default value for function argument is None. refs: python/cpython#30304 (bpo-46195)
Just re-found this issue because Hypothesis does indeed have a test for this 😂 Let's mention this change in https://docs.python.org/3.11/whatsnew/3.11.html, not just the docs for |
Useful related links:
https://bugs.python.org/issue46195