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

Visit the transforms before handling delayed assattr nodes #2453

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

marmarek
Copy link

Type of Changes

Type
βœ“ πŸ› Bug fix

Description

When importing Gtk, it looks like this:

import gi
gi.require_version('Gtk', '3.0')
from gi.repository import Gtk

It is vital that gi.require_version() is made before related 'from gi.repository import ...'. The brain_gi tries to do that using transforms. And it works unless Gtk is imported as part of delayed assattr handling.

Fix this by handling transforms earlier.

Closes #2190
Closes pylint-dev/pylint#6352

@marmarek
Copy link
Author

My change made one test fail now:

____________________ TypingBrain.test_typing_generic_slots _____________________

self = <tests.brain.test_brain.TypingBrain testMethod=test_typing_generic_slots>

    def test_typing_generic_slots(self):
        """Test slots for Generic subclass."""
        node = builder.extract_node(
            """
        from typing import Generic, TypeVar
        T = TypeVar('T')
        class A(Generic[T]):
            __slots__ = ['value']
            def __init__(self, value):
                self.value = value
        """
        )
        inferred = next(node.infer())
        slots = inferred.slots()
>       assert len(slots) == 1
E       TypeError: object of type 'NoneType' has no len()

I don't fully understand why, yet, but I think one option to make my change less invasive is to add "early transforms" and leave the original transforms in the old place. And then make brain_gi use the early transforms for the gi.require_version thing. Is that okay?

@Pierre-Sassoulas
Copy link
Member

Thank you for the MR. I agree with the proposed early transform, it feels like a big API decision but applying the transform twice so it's possible to apply transform after delayed attr creation is a lot worse. Let's hear another maintainer opinion before committing to it, it's not like I'm a brain expert myself.

@DanielNoord
Copy link
Collaborator

Have you also tried running the pylint testsuite with this version of astroid? I'm wondering if this is a fix we can indeed make, the failing test doesn't make me too hopeful.

@marmarek
Copy link
Author

When running pylint test suite on plain main branch I got 12 failures already, but my change introduces 13th: test_functional[assigning_non_slot_4509] (assigning-non-slot message is not raised).
The failure here is also related to slots, so it's probably the same thing.

I'll change my patch to not affect other brains.

@marmarek marmarek force-pushed the gi-gtk-version branch 2 times, most recently from cde8a4d to 6b4eb78 Compare June 25, 2024 17:22
@marmarek
Copy link
Author

While at it, I've added also some basic test for brain_gi.

Copy link

codecov bot commented Jun 25, 2024

Codecov Report

All modified and coverable lines are covered by tests βœ…

Project coverage is 92.73%. Comparing base (453d307) to head (b1f540d).
Report is 1 commits behind head on main.

Additional details and impacted files

Impacted file tree graph

@@           Coverage Diff           @@
##             main    #2453   +/-   ##
=======================================
  Coverage   92.72%   92.73%           
=======================================
  Files          94       94           
  Lines       10993    11007   +14     
=======================================
+ Hits        10193    10207   +14     
  Misses        800      800           
Flag Coverage Ξ”
linux 92.61% <100.00%> (+<0.01%) ⬆️
pypy 92.73% <100.00%> (+<0.01%) ⬆️
windows 92.71% <100.00%> (+<0.01%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

Files Coverage Ξ”
astroid/brain/brain_gi.py 23.02% <100.00%> (ΓΈ)
astroid/builder.py 94.27% <100.00%> (+0.07%) ⬆️
astroid/manager.py 90.23% <100.00%> (+0.39%) ⬆️
astroid/test_utils.py 85.71% <100.00%> (+0.29%) ⬆️

marmarek added 2 commits June 27, 2024 02:31
When importing Gtk, it looks like this:

    import gi
    gi.require_version('Gtk', '3.0')
    from gi.repository import Gtk

It is vital that gi.require_version() is made before related 'from
gi.repository import ...'. The brain_gi tries to do that using
transforms. And it works unless Gtk is imported as part of delayed
assattr handling.

Fix this by adding early transforms that are called before delayed
assattr.

Fixes pylint-dev#2190
Fixes pylint-dev/pylint#6352
Just a simple one, that checks if the correct Gtk version gets
installed.

Note this test is checks for the linked regression only if both Gtk3 and
Gtk4 are installed. Otherwise, it checks if brain_gi works at all.
@marmarek
Copy link
Author

tests\brain\test_gi.py s [ 20%]

So, the test I added doesn't run in CI (which also explain minimal test coverage of brain_gi.py). Is it worth installing "gi" python module + Gtk3 (and maybe Gtk4 too?) in there to make the test run? Or is it enough for it to run when called manually locally (assuming those dependencies are installed)?

@DanielNoord
Copy link
Collaborator

Yeah I don't think we want to add those dependencies to the CI.

I do wonder if this warrants the API change. I can't really comment on that part (and I think most maintainers are a bit afraid of making such a decision). @Pierre-Sassoulas @jacobtylerwalls Do you have any opinions here?

@jacobtylerwalls jacobtylerwalls self-requested a review July 21, 2024 13:36
@jacobtylerwalls
Copy link
Member

I do wonder if this warrants the API change.

Yeah, I'm reluctant to add an early transforms API for this. We should consider alternatives:

  • in _register_require_version(): manipulate sys.modules or use importlib.reload to reimport gi if necessary
  • remove brain_gi in favor of a new plugin to be homed at pylint-dev/pylint-gi

@jacobtylerwalls jacobtylerwalls removed their request for review July 27, 2024 15:06
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.

brain_gi uses wrong Gtk version for analysis Pylint can't find some PyGObject classes' members
4 participants