blob: e1ff6378ee4888d3a528e0b0c50c65579774e0bf [file] [log] [blame]
# Copyright (c) 2015-2018, 2020 Claudiu Popa <pcmanticore@gmail.com>
# Copyright (c) 2016 Derek Gustafson <degustaf@gmail.com>
# Copyright (c) 2019-2021 Pierre Sassoulas <pierre.sassoulas@gmail.com>
# Copyright (c) 2019 Ashley Whetter <ashley@awhetter.co.uk>
# Copyright (c) 2020 hippo91 <guillaume.peillex@gmail.com>
# Copyright (c) 2020 Damien Baty <damien.baty@polyconseil.fr>
# Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
# For details: https://github.com/PyCQA/pylint/blob/master/LICENSE
"""
for the visitors.diadefs module
"""
# pylint: disable=redefined-outer-name
import os
import astroid
import pytest
from unittest_pyreverse_writer import get_project
from pylint.pyreverse import inspector
@pytest.fixture
def project():
project = get_project("data", "data")
linker = inspector.Linker(project)
linker.visit(project)
return project
def test_class_implements(project):
klass = project.get_module("data.clientmodule_test")["Ancestor"]
assert hasattr(klass, "implements")
assert len(klass.implements) == 1
assert isinstance(klass.implements[0], astroid.nodes.ClassDef)
assert klass.implements[0].name == "Interface"
def test_class_implements_specialization(project):
klass = project.get_module("data.clientmodule_test")["Specialization"]
assert hasattr(klass, "implements")
assert len(klass.implements) == 0
def test_locals_assignment_resolution(project):
klass = project.get_module("data.clientmodule_test")["Specialization"]
assert hasattr(klass, "locals_type")
type_dict = klass.locals_type
assert len(type_dict) == 2
keys = sorted(type_dict.keys())
assert keys == ["TYPE", "top"]
assert len(type_dict["TYPE"]) == 1
assert type_dict["TYPE"][0].value == "final class"
assert len(type_dict["top"]) == 1
assert type_dict["top"][0].value == "class"
def test_instance_attrs_resolution(project):
klass = project.get_module("data.clientmodule_test")["Specialization"]
assert hasattr(klass, "instance_attrs_type")
type_dict = klass.instance_attrs_type
assert len(type_dict) == 2
keys = sorted(type_dict.keys())
assert keys == ["_id", "relation"]
assert isinstance(type_dict["relation"][0], astroid.bases.Instance), type_dict[
"relation"
]
assert type_dict["relation"][0].name == "DoNothing"
assert type_dict["_id"][0] is astroid.Uninferable
def test_concat_interfaces():
cls = astroid.extract_node(
'''
class IMachin: pass
class Correct2:
"""docstring"""
__implements__ = (IMachin,)
class BadArgument:
"""docstring"""
__implements__ = (IMachin,)
class InterfaceCanNowBeFound: #@
"""docstring"""
__implements__ = BadArgument.__implements__ + Correct2.__implements__
'''
)
interfaces = inspector.interfaces(cls)
assert [i.name for i in interfaces] == ["IMachin"]
def test_interfaces():
module = astroid.parse(
"""
class Interface(object): pass
class MyIFace(Interface): pass
class AnotherIFace(Interface): pass
class Concrete0(object):
__implements__ = MyIFace
class Concrete1:
__implements__ = (MyIFace, AnotherIFace)
class Concrete2:
__implements__ = (MyIFace, AnotherIFace)
class Concrete23(Concrete1): pass
"""
)
for klass, interfaces in (
("Concrete0", ["MyIFace"]),
("Concrete1", ["MyIFace", "AnotherIFace"]),
("Concrete2", ["MyIFace", "AnotherIFace"]),
("Concrete23", ["MyIFace", "AnotherIFace"]),
):
klass = module[klass]
assert [i.name for i in inspector.interfaces(klass)] == interfaces
def test_from_directory(project):
expected = os.path.join("tests", "data", "__init__.py")
assert project.name == "data"
assert project.path.endswith(expected)
def test_project_node(project):
expected = ["data", "data.clientmodule_test", "data.suppliermodule_test"]
assert sorted(project.keys()) == expected