-
-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
[django-filter] Absorb django-filter-stubs into typeshed #10919
base: main
Are you sure you want to change the base?
Conversation
pre-commit.ci autofix |
This comment has been minimized.
This comment has been minimized.
ecdac04
to
1e34eaa
Compare
This comment has been minimized.
This comment has been minimized.
9cf4747
to
1549268
Compare
6b08536
to
63e9ab6
Compare
This should be more or less ready for initial merge. If we can get this merged, I can look into the stubtest allowlist issues separately. Unless you think I should fix them immediately here? Some questions:
|
This comment has been minimized.
This comment has been minimized.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some further questions. Personally I'd prefer to get this merged first and then do further improvements in follow-up PRs.
from django import forms | ||
|
||
from .conf import settings as settings | ||
from .constants import EMPTY_VALUES as EMPTY_VALUES |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are lots of re-exports that shouldn't be re-exported. Should I clean these up before initial merge, or in follow-up?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
follow-up is fine imo
def __init__(self, *args: Any, **kwargs: Any) -> None: ... | ||
|
||
class TimeRangeField(RangeField): | ||
widget: Any = ... |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should I clean up attribute assignments?
widget: Any = ... | |
widget: Any |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fine to do this in a follow-up imo
(Writing from my phone, I have limited access to a laptop with Internet until Tuesday) In general, I think it's fine to tackle issues with these stubs in followup PRs, now you've got CI passing (thanks!). Most things in For your question (1) — I can't remember off the top of my head what the exact rules are, but unfortunately adding For your question (2), I think we're reasonably open to adding special-casing for specific stubs packages if it means we can run stubtest on them in CI. If you look at |
Yep, that's also mentioned in typeshed-internal/stub_uploader#90 (comment) Ideally these wouldn't be hard dependencies of the pacakge, but would only be installed in CI when testing. But there seems to be no such option currently? Users of There are two different stubs packages for Django: |
This comment has been minimized.
This comment has been minimized.
0bc7b19
to
63e9ab6
Compare
This comment has been minimized.
This comment has been minimized.
I think anything else we can fix/improve afterwards, but the One idea would be to create a new |
I'd prefer to avoid doing that, if at all possible. In 99% of cases in typeshed, if an external package is needed to make our tests pass, it's also needed for the stubs to make sense when they're installed by a user. I worry that by adding this option to our I believe that if a stubs package from typeshed imports a type that mypy can't resolve (because a dependency is missing), the imported type will just get silently resolved as For the specific case of I'm going to take a look now and see if there are any other ways of solving this problem. |
Many months have gone past. Has anything changed in terms of introducing a dependency on There are a few other Django-related or djangorestframework-related projects I might want to provide stubs for, but no point in undertaking that work until this blocker has been cleared. And maintaining a 3rd party stubs project outside of |
This comment has been minimized.
This comment has been minimized.
@intgr Sorry for the long process. I've added the Django stubs to the stub uploader allowlist. I see this as uncritical. There are some type errors now, though. |
Thanks for helping push this forward. Note that stub_uploader tests are giving the following error:
This blocker was described in typeshed-internal/stub_uploader#111 (comment) / typeshed-internal/stub_uploader#90 (comment) Do you have an idea what to do about this error? I suspect django-filter upstream will not want to add django-stubs to its dependencies. |
@intgr maybe we can try try to make a PR with django-stubs as a dependency to django-filter? |
Sorry for the inaction here. I feel we should be able to address this with changes in stub-uploader. (Maybe a rule that if you depend on X at runtime, the stubs may depends on X-stubs, for some trusted values of X?) |
This comment has been minimized.
This comment has been minimized.
This has been addressed in typeshed-internal/stub_uploader#152. Perhaps someone can merge main to trigger ci to see if it works. |
This comment has been minimized.
This comment has been minimized.
8955f89
to
4e6227a
Compare
stubs/django-filter/METADATA.toml
Outdated
@@ -0,0 +1,3 @@ | |||
version = "23.3.*" | |||
upstream_repository = "https://github.com/carltongibson/django-filter" | |||
requires = ["django-stubs", "djangorestframework-stubs"] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You'd need to remove this to pass the stub_uploader CI. It doesn't look like it is used anywhere in the stubs, not sure why it was included.
requires = ["django-stubs", "djangorestframework-stubs"] | |
requires = ["django-stubs"] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It was used in __init__.pyi
: from . import rest_framework as rest_framework
. But indeed this is totally unnecessary and is the only usage, removed.
By the way, thanks a lot for improving stub-uploader, and for letting me know about the changes!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It was used in
__init__.pyi
:from . import rest_framework as rest_framework
. But indeed this is totally unnecessary and is the only usage, removed.
This looks like a locally defined module named rest_framework
, not the djangorestframework package. I don't think it should be removed.
By the way, thanks a lot for improving stub-uploader, and for letting me know about the changes!
Thank you and thanks for working on django stubs!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks like a locally defined module named rest_framework
Ah right you are!
I don't think it should be removed.
I don't think it does anything. It's re-exporting the module django_filter.rest_framework
in django_filter/__init__.py
that is already available under the exact same module path? 😄
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it does anything. It's re-exporting the module
django_filter.rest_framework
indjango_filter/__init__.py
that is already available under the exact same module path? 😄
If you remove it then this will not work (at least with pyright):
import django_filters
django_filters.rest_framework # <- this will be a type error and would not have autocompletion in VS Code
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@intgr I still think the the removed from . import rest_framework as rest_framework
must be restored. It is deliberately imported at runtime for the specific reason that would let pyright accept the code snippet I mentioned above, i.e. to avoid having to type import django_fiters.rest_framework
.
See the comment here:
https://github.com/carltongibson/django-filter/blob/2494df96c6387a9fa411fcb00b696b15dfd9216b/django_filters/__init__.py#L7-L10
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's silly and nobody should use it like that. The documentation and tests don't use it that way either.
But if you feel strongly about this, fair enough, I've restored it.
This comment has been minimized.
This comment has been minimized.
4e6227a
to
dfe1fbe
Compare
It's a mystery to me, why Pyright fails on this file (only with older Pythons)... I didn't even touch it 😄
|
This comment has been minimized.
This comment has been minimized.
|
See also my suggested solution for the pyright issue: #13101 (comment) (But it should be done in a separate PR to this one) |
|
dfe1fbe
to
db7df55
Compare
This comment has been minimized.
This comment has been minimized.
Nice, this now passes CI. As a reminder, Please don't use squash merge to merge this (unless there's explicit decision to reconsider #10918). I have preserved original commit authors in the commits here. |
db7df55
to
4f00327
Compare
According to mypy_primer, this change has no effect on the checked open source code. 🤖🎉 |
from .filters import * | ||
from .filterset import FilterSet as FilterSet | ||
|
||
def parse_version(version: Any): ... |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We now believe Any should be used only in places where the type system can't express the precise type. As a result, we'd want a comment with every Any explaining why it's there.
If this is Any merely because you haven't figured out the precise type, you can leave the parameter unannotated, or use _typeshed.Incomplete
in cases where that's not possible (e.g., for the global below).
As described in #10918, I have added stubs from
django-filter-stubs
project. Upstream issue: DavisRayM/django-filter-stubs#13Please don't use squash merge to merge this (unless there's explicit decision to reconsider #10918). I have preserved original commit authors. There really weren't many changes in stubs files.
django-filter-stubs
into typeshed #10918typeshed
? DavisRayM/django-filter-stubs#13