KEMBAR78
Correctly handle Enum name on Python 3.11 by ilevkivskyi · Pull Request #14133 · python/mypy · GitHub
Skip to content

Conversation

@ilevkivskyi
Copy link
Member

@ilevkivskyi ilevkivskyi commented Nov 18, 2022

Fixes #12483
Fixes python/typeshed#7564
Ref #12841

The fix is straightforward. I can't use a unit test for this because there are some builtins fixtures that don't have tuple, so I can't do version check.

@github-actions

This comment has been minimized.

Copy link
Member

@AlexWaygood AlexWaygood left a comment

Choose a reason for hiding this comment

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

Looks good, and it's great to have this fixed. This PR also fixes python/typeshed#7564.

There's still the outstanding issue that mypy won't spot that this will raise an AttributeError at runtime on 3.11+:

import enum

class E(enum.Enum):
    X = 1
    @enum.property
    def foo(self) -> int: return 42

assert E.X.foo == 42  # this is fine
E.foo  # AttributeError raised here at runtime

But this is a much lower-priority problem, and can be filed as a follow-up issue.

@github-actions
Copy link
Contributor

According to mypy_primer, this change has no effect on the checked open source code. 🤖🎉

@ilevkivskyi ilevkivskyi merged commit 05a3f7d into python:master Nov 18, 2022
@ilevkivskyi ilevkivskyi deleted the enum-311 branch November 18, 2022 19:38
JukkaL pushed a commit that referenced this pull request Nov 21, 2024
This enables typeshed to define types.DynamicClassAttribute as a
different class from builtins.property without breakage.

Would enable python/typeshed#12762
see also #14133
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.

(🐞) Enum.name is Any in 3.11 / support enum.property (🐞) Enum.name is Any in 3.11

2 participants