-
Notifications
You must be signed in to change notification settings - Fork 114
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
Matchers should be contravariant #222
Comments
Thanks, I'll look into this in a few days if no one else gets to it first. |
Thanks a lot. I think this should fix a number of type problems when using the library. |
Ah, I remember now. So, I did try this back when I added typing, but the trouble is getting the contravariant matcher to work with |
Maybe I'm missing something, but from typing import Any, Generic, Sized, TypeVar
T = TypeVar("T", contravariant=True)
class Matcher(Generic[T]):
def matches(self, _: T) -> bool:
...
def greater_than(_: Any) -> Matcher[Any]:
...
def has_length(_: int | Matcher[int]) -> Matcher[Sized]:
...
matcher: Matcher[str] = has_length(greater_than(0))
T2 = TypeVar("T2")
def assert_that(
actual_or_assertion: T2, matcher: Matcher[T2], reason: str = ""
) -> None:
...
assert_that("hi there bob", has_length(greater_than(0))) Doesn't give me any errors. Was there a specific case that fails? |
It may be be me who is missing something! Or perhaps the overrides are the problem? But in any case, I can't get this working in the real codebase. Do you want to try it? I'm sure a PR would be gratefully received as long as it's backward compatible. |
I can give it a shot later when I get some time. Probably won't be for a bit though. |
Thanks, I appreciate it. |
Currently, the
Matcher
class has a type argT
as it should, butMatcher
s are currently invariant with respect toT
. However, I think it's quite clear that the following should be legal code:I've recreated that definition here:
Pyright provides the following error:
Changing line 3 to
T = TypeVar('T', contravariant=True)
fixes the issue.python version: 3.10.8
pyhamcrest version: 2.0.4
pyright version: 1.1.280
The text was updated successfully, but these errors were encountered: