Skip to content
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

Add runtime type checking in CI tests #9745

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

DimitriPapadopoulos
Copy link
Contributor

This should prevent TYPE_CHECKING misuse.

Fixes #9744.

@DimitriPapadopoulos DimitriPapadopoulos force-pushed the pytest-beartype branch 2 times, most recently from 7c7eee9 to 4b2f732 Compare November 7, 2024 17:33
.github/workflows/ci.yaml Outdated Show resolved Hide resolved
@max-sixty
Copy link
Collaborator

This is a good test! Unfortunately our CI fails, and we couldn't work out a succinct way of changing our annotations so that we could resolve #9581.

If there were some way of adding this in part, that would be great. But likely we'll need to wait for more support so we can support this while having just DataArray in the type definition without the full path (more discussion in the attached issue)

@headtr1ck
Copy link
Collaborator

Maybe we make it optional, similar to pyright?

@DimitriPapadopoulos
Copy link
Contributor Author

I was planning on exploring the suggestions in #9581.

But yes, I could make the test optional for now.

@DimitriPapadopoulos DimitriPapadopoulos force-pushed the pytest-beartype branch 3 times, most recently from 1c7d925 to 2aaf037 Compare November 10, 2024 13:01
@max-sixty
Copy link
Collaborator

Is it helpful to have an optional CI which fails everytime at the first import though?

@DimitriPapadopoulos
Copy link
Contributor Author

It looks like solutions that might work with beartype fail with MyPy. I haven't been able to find a solution within the little time I can dedicate to this issue.

In any case, it looks like TYPE_CHECKING shouldn't be used, except to avoid circular imports.

This should prevent TYPE_CHECKING misuse.

It might also found issues not found by static type checking,
typically by the current MyPy.

Make it optional for now, while we fix issues.
This setting is only applicable when the target Python version is
below 3.9 and 3.10 respectively.
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.

Add runtime type checking
4 participants