-
-
Notifications
You must be signed in to change notification settings - Fork 2.9k
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
Cannot set return type of asynccontextmanagers in Protocol classes #17996
Comments
Workaround: provide an implementation in the Protocol Definition that yield an instance of the correct type: from collections.abc import AsyncIterator
from contextlib import asynccontextmanager
from typing import Protocol
class P(Protocol):
@asynccontextmanager
async def f(self) -> AsyncIterator[None]:
"""Create a context but yield nothing."""
yield None # Workaround for https://github.com/python/mypy/issues/17996 |
You should use a This unfortunate edge case comes up pretty regularly; we should add it to https://mypy.readthedocs.io/en/stable/common_issues.html. |
@JelleZijlstra Thanks, using a It's pretty surprising, having to bend the Prototype definition away from what will get implemented, and in effect making the Prototype less representative of what is expected. If the error is expected to stay, then having it mentioned in Common Issues, as you suggest, is a good idea. Not only is it the natural place to find such information; it's also a respectable and high-ranking source that will hopefully improve web search results. To help with the latter, I suggest also including the error message in the common issues document. |
There's reasonable docs for this in https://mypy.readthedocs.io/en/stable/more_types.html#typing-async-await A PR that mentions the error message in "Common issues" and links to the above section would be welcome |
Bug Report
When decorating an empty method ("
...
") inside of aProtocol
definition as anasynccontextmanager
, the type checker insists that the return type must useNever
instead of allowing to specify the type intended by the protocol.To Reproduce
See also in Playground.
Importing
AsyncIterator
fromtyping
instead ofcollections.abc
makes no difference.Expected Behavior
I should be allowed to annotate the expected
yield
-Type of the context manager in a Protocol without having to provide an implementation. (None
in this case, but also any other type that the context will yield to thewith
statement.)Actual Behavior
Produces this error:
Your Environment
mypy.ini
(and other config files): (see below)My mypy config (but it also reproduces when leaving all options unchecked in the Playground):
The text was updated successfully, but these errors were encountered: