-
-
Notifications
You must be signed in to change notification settings - Fork 278
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix
instance_attrs
building error in Qt brain (#1505)
Co-authored-by: Daniël van Noord <[email protected]>
- Loading branch information
1 parent
6c29972
commit c10f18c
Showing
6 changed files
with
81 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -31,3 +31,31 @@ jobs: | |
. venv2\scripts\activate | ||
echo "import distutils.util # pylint: disable=unused-import" > test.py | ||
pylint test.py | ||
additional-dependencies-linux-tests: | ||
name: Regression tests w/ additional dependencies (Linux) | ||
runs-on: ubuntu-latest | ||
timeout-minutes: 5 | ||
steps: | ||
- name: Check out code from GitHub | ||
uses: actions/[email protected] | ||
- name: Set up Python | ||
id: python | ||
uses: actions/[email protected] | ||
with: | ||
python-version: ${{ env.DEFAULT_PYTHON }} | ||
- name: Install Qt | ||
run: | | ||
sudo apt-get install build-essential libgl1-mesa-dev | ||
- name: Create Python virtual environment | ||
run: | | ||
python -m venv venv | ||
. venv/bin/activate | ||
python -m pip install -U pip setuptools wheel | ||
pip install -U -r requirements_test.txt -r requirements_test_brain.txt | ||
pip install -e . | ||
- name: Run brain_qt tests | ||
# Regression test added in https://github.com/PyCQA/astroid/pull/1505 | ||
run: | | ||
. venv/bin/activate | ||
pytest tests/unittest_brain_qt.py |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,6 +3,7 @@ types-attrs | |
nose | ||
numpy>=1.17.0 | ||
python-dateutil | ||
PyQt6 | ||
types-python-dateutil | ||
six | ||
types-six |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
# Licensed under the LGPL: https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html | ||
# For details: https://github.com/PyCQA/astroid/blob/main/LICENSE | ||
# Copyright (c) https://github.com/PyCQA/astroid/blob/main/CONTRIBUTORS.txt | ||
|
||
from importlib.util import find_spec | ||
|
||
import pytest | ||
|
||
from astroid import Uninferable, extract_node | ||
from astroid.bases import UnboundMethod | ||
from astroid.manager import AstroidManager | ||
from astroid.nodes import FunctionDef | ||
|
||
HAS_PYQT6 = find_spec("PyQt6") | ||
|
||
|
||
@pytest.mark.skipif(HAS_PYQT6 is None, reason="This test requires the PyQt6 library.") | ||
class TestBrainQt: | ||
@staticmethod | ||
def test_value_of_lambda_instance_attrs_is_list(): | ||
"""Regression test for https://github.com/PyCQA/pylint/issues/6221 | ||
A crash occurred in pylint when a nodes.FunctionDef was iterated directly, | ||
giving items like "self" instead of iterating a one-element list containing | ||
the wanted nodes.FunctionDef. | ||
""" | ||
src = """ | ||
from PyQt6 import QtPrintSupport as printsupport | ||
printsupport.QPrintPreviewDialog.paintRequested #@ | ||
""" | ||
AstroidManager.brain["extension_package_whitelist"] = {"PyQt6.QtPrintSupport"} | ||
node = extract_node(src) | ||
attribute_node = node.inferred()[0] | ||
if attribute_node is Uninferable: | ||
pytest.skip("PyQt6 C bindings may not be installed?") | ||
assert isinstance(attribute_node, UnboundMethod) | ||
# scoped_nodes.Lambda.instance_attrs is typed as Dict[str, List[NodeNG]] | ||
assert isinstance(attribute_node.instance_attrs["connect"][0], FunctionDef) |