From 6aae91559d29acd3042e1fd26e0d111261521010 Mon Sep 17 00:00:00 2001 From: Claudiu Popa Date: Fri, 1 May 2020 17:59:20 +0200 Subject: [PATCH] Protect against ``infer_call_result`` failing with `InferenceError` in `Super.getattr()` (#782) ``infer_call_result`` can raise InferenceError but we were not handling that when retrieving objects from the Super instance. Close PyCQA/pylint#3529 --- ChangeLog | 4 ++++ astroid/objects.py | 7 ++++++- tests/unittest_inference.py | 28 ++++++++++++++++++++++++++++ 3 files changed, 38 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 3d6cca2255..31f77da70a 100644 --- a/ChangeLog +++ b/ChangeLog @@ -29,6 +29,10 @@ Release Date: TBA Close PyCQA/pylint#3549 +* Protect against ``infer_call_result`` failing with `InferenceError` in `Super.getattr()` + + Close PyCQA/pylint#3529 + What's New in astroid 2.4.0? ============================ diff --git a/astroid/objects.py b/astroid/objects.py index 68d74aa2f3..fb782e6d7b 100644 --- a/astroid/objects.py +++ b/astroid/objects.py @@ -187,7 +187,12 @@ def igetattr(self, name, context=None): yield inferred elif isinstance(inferred, Property): function = inferred.function - yield from function.infer_call_result(caller=self, context=context) + try: + yield from function.infer_call_result( + caller=self, context=context + ) + except exceptions.InferenceError: + yield util.Uninferable elif bases._is_property(inferred): # TODO: support other descriptors as well. try: diff --git a/tests/unittest_inference.py b/tests/unittest_inference.py index e267f97022..cfbcd6f86b 100644 --- a/tests/unittest_inference.py +++ b/tests/unittest_inference.py @@ -5818,5 +5818,33 @@ def __new__(cls, name, bases, dictionary): assert dunder_new.implicit_parameters() == 0 +def test_super_inference_of_abstract_property(): + code = """ + from abc import abstractmethod + + class A: + @property + def test(self): + return "super" + + class C: + @property + @abstractmethod + def test(self): + "abstract method" + + class B(A, C): + + @property + def test(self): + super() #@ + + """ + node = extract_node(code) + inferred = next(node.infer()) + test = inferred.getattr("test") + assert len(test) == 2 + + if __name__ == "__main__": unittest.main()