KEMBAR78
Remove some unnecessary defer rounds by flaeppe · Pull Request #2252 · typeddjango/django-stubs · GitHub
Skip to content

Conversation

@flaeppe
Copy link
Member

@flaeppe flaeppe commented Jul 5, 2024

Change so that we don't trigger unnecessary defer rounds during manager creation via the from_queryset method call.

Refs:

Comment on lines +544 to +562
Copy link
Member Author

Choose a reason for hiding this comment

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

I'm going to argue that the changes here improves correctness. Since the manager in the test comes from a function that specifies a manager as return type:

def LocalManager() -> models.Manager:
    """
    Returns a manager instance of an inlined manager type that can't
    be resolved.
    """
    class InnerManager(models.Manager): ...
    return InnerManager()

This (now) assigns a type models.Manager[Any], the return type of the function. I would say that the previous behaviour did too much, since it tried to express that assigned an invalid manager. But to know that it had to draw conclusions from the function body and thus "override" the return type.

The plugin should now only consider calls of the format: objects = <Manager>.from_queryset(<QuerySet>)() or objects = <QuerySet>.as_manager() in this case

Change so that we don't trigger unnecessary defer rounds during manager
creation via the `from_queryset` method call.
@flaeppe flaeppe force-pushed the fix/pointless-defers branch from 8ed6834 to 07503e6 Compare July 13, 2024 10:00
@flaeppe
Copy link
Member Author

flaeppe commented Jul 13, 2024

To clarify a little bit more; previously the plugin could tell mypy to defer on e.g. a case like this:

def not_a_manager() -> Any: ...

class SomeModel(models.Model):
    objects = not_a_manager()

Deferring isn't gonna make it a more of a manager. The changed code looks for a more narrow/specific case that we want and can handle that comes from from_queryset. For any other situation we now just continue without deferring.

@flaeppe
Copy link
Member Author

flaeppe commented Jul 15, 2024

@sobolevn, @intgr would any of you guys mind checking this out? I'm suspecting it could improve a couple of errors in #1023 (though I have no proof that it will)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Development

Successfully merging this pull request may close these issues.

1 participant