From cca0d02a369d02451e19312e3c53aa3445ab4633 Mon Sep 17 00:00:00 2001 From: Tim Martin Date: Fri, 15 Apr 2022 19:27:09 +0100 Subject: [PATCH] Suppress ``useless-super-delegation`` if return type changed (#5822) (#6141) * Reinstate warning if base method has no return type annotation --- pylint/checkers/classes/class_checker.py | 8 +++++ .../useless/useless_super_delegation_py35.py | 34 +++++++++++++++++++ .../useless/useless_super_delegation_py35.txt | 2 ++ 3 files changed, 44 insertions(+) diff --git a/pylint/checkers/classes/class_checker.py b/pylint/checkers/classes/class_checker.py index 0156c3fcb8..fba2b6ad84 100644 --- a/pylint/checkers/classes/class_checker.py +++ b/pylint/checkers/classes/class_checker.py @@ -1277,6 +1277,14 @@ def form_annotations(arguments): if called_annotations != overridden_annotations: return + if ( + function.returns is not None + and meth_node.returns is not None + and meth_node.returns.as_string() != function.returns.as_string() + ): + # Override adds typing information to the return type + return + if _definition_equivalent_to_call(params, args): self.add_message( "useless-super-delegation", node=function, args=(function.name,) diff --git a/tests/functional/u/useless/useless_super_delegation_py35.py b/tests/functional/u/useless/useless_super_delegation_py35.py index 16030f8a4d..789ae55d3d 100644 --- a/tests/functional/u/useless/useless_super_delegation_py35.py +++ b/tests/functional/u/useless/useless_super_delegation_py35.py @@ -10,3 +10,37 @@ class UselessSuper(object): def useless(self, first, *, second=None, **kwargs): # [useless-super-delegation] return super().useless(first, second=second, **kwargs) + +# pylint: disable=wrong-import-position +import random +from typing import Any + +class ReturnTypeAny: + choices = ['a', 1, (2, 3)] + + def draw(self) -> Any: + return random.choice(self.choices) + +class ReturnTypeNarrowed(ReturnTypeAny): + choices = [1, 2, 3] + + def draw(self) -> int: + return super().draw() + +class NoReturnType: + choices = ['a', 1, (2, 3)] + + def draw(self): + return random.choice(self.choices) + +class ReturnTypeSpecified(NoReturnType): + choices = ['a', 'b'] + + def draw(self) -> str: # [useless-super-delegation] + return super().draw() + +class ReturnTypeSame(ReturnTypeAny): + choices = ['a', 'b'] + + def draw(self) -> Any: # [useless-super-delegation] + return super().draw() diff --git a/tests/functional/u/useless/useless_super_delegation_py35.txt b/tests/functional/u/useless/useless_super_delegation_py35.txt index abcf6c5fb4..58c98b0f99 100644 --- a/tests/functional/u/useless/useless_super_delegation_py35.txt +++ b/tests/functional/u/useless/useless_super_delegation_py35.txt @@ -1 +1,3 @@ useless-super-delegation:11:4:11:15:UselessSuper.useless:Useless super delegation in method 'useless':UNDEFINED +useless-super-delegation:39:4:39:12:ReturnTypeSpecified.draw:Useless super delegation in method 'draw':UNDEFINED +useless-super-delegation:45:4:45:12:ReturnTypeSame.draw:Useless super delegation in method 'draw':UNDEFINED