KEMBAR78
Emit error for "raise NotImplemented" by brianschubert · Pull Request #17890 · python/mypy · GitHub
Skip to content

Conversation

@brianschubert
Copy link
Member

@brianschubert brianschubert commented Oct 7, 2024

Refs #5710

Adds special-case handling for raising NotImplemented:

raise NotImplemented  # E: Exception must be derived from BaseException; did you mean "NotImplementedError"?

Per the linked issue, there's some debate as to how to best handle NotImplemented. This PR special-cases its behavior in raise statements, whereas the leaning in the issue (at the time it was opened) was towards updating its definition in typeshed and possibly special-casing its use in the relevant dunder methods.

Going the typeshed/special-dunder route may still happen, but it hasn't in the six years since the issue was opened. It would be nice to at least catch errors from raising NotImplemented in the interim.

Making this change also uncovered a regression introduced in python/typeshed#4222. Previously, NotImplemented was annotated as Any in typeshed, so returning NotImplemented from a non-dunder would emit an error when --warn-return-any was used:

class A:
    def some(self) -> bool: return NotImplemented  # E: Returning Any from function declared to return "bool"

However, in python/typeshed#4222, the type of NotImplemented was updated to be a subclass of Any. This broke the handling of --warn-return-any, but it wasn't caught since the definition of NotImplemented in fixtures/notimplemented.pyi wasn't updated along with the definition in typeshed. As a result, current mypy doesn't emit an error here (playground), despite having a test case saying that it should. As a bandaid, this PR add special handling for NotImplemented in return statements to treat it like an explicit Any, restoring the pre- python/typeshed#4222 behavior.

Test case testReturnAnyForNotImplementedInNormalMethods become silently
invalid after typeshed changes it defintiion of NotImplemented from
Any to a subclass to Any.

We can store the old behavior by special casing NotImplemented in
check_return_stmt.
@brianschubert brianschubert changed the title Emit error on 'raise NotImplemented Emit error for "raise NotImplemented" Oct 7, 2024
@github-actions

This comment has been minimized.

@brianschubert brianschubert reopened this Oct 7, 2024
@github-actions

This comment has been minimized.

Copy link
Collaborator

@JukkaL JukkaL left a comment

Choose a reason for hiding this comment

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

Nice, thanks for the fix! I have more minor suggestions, otherwise looks good.

@github-actions
Copy link
Contributor

github-actions bot commented Oct 8, 2024

Diff from mypy_primer, showing the effect of this PR on open source code:

manticore (https://github.com/trailofbits/manticore)
+ manticore/platforms/linux.py:328: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:331: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:334: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:341: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:344: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:347: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:350: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]
+ manticore/platforms/linux.py:353: error: Exception must be derived from BaseException; did you mean "NotImplementedError"?  [misc]

@JukkaL JukkaL merged commit 62a971c into python:master Oct 9, 2024
19 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