From cb7c2cd8a964f48fdac94947cbd04f84b2ab6043 Mon Sep 17 00:00:00 2001 From: Tomas Votruba Date: Tue, 21 May 2024 11:20:29 +0900 Subject: [PATCH] Skip attributes on setter rule (#120) * add route test fixture * add route test fixture * skip attributed class method --- src/Rules/NoReturnSetterMethodRule.php | 16 +++++++++++++--- .../Fixture/SkipRoute.php | 17 +++++++++++++++++ .../NoReturnSetterMethodRuleTest.php | 1 + 3 files changed, 31 insertions(+), 3 deletions(-) create mode 100644 tests/Rules/NoReturnSetterMethodRule/Fixture/SkipRoute.php diff --git a/src/Rules/NoReturnSetterMethodRule.php b/src/Rules/NoReturnSetterMethodRule.php index 33009405..0a4ee1ba 100644 --- a/src/Rules/NoReturnSetterMethodRule.php +++ b/src/Rules/NoReturnSetterMethodRule.php @@ -53,12 +53,12 @@ public function getNodeType(): string */ public function processNode(Node $node, Scope $scope): array { - $classReflection = $scope->getClassReflection(); - if (! $classReflection instanceof ClassReflection) { + // possibly some important logic + if ($node->attrGroups !== []) { return []; } - if (! $classReflection->isClass()) { + if (! $this->isInsideClassReflection($scope)) { return []; } @@ -124,4 +124,14 @@ private function hasReturnReturnFunctionLike(ClassMethod $classMethod): bool $yield = $this->typeAwareNodeFinder->findFirstInstanceOf($classMethod, Yield_::class); return $yield instanceof Yield_; } + + private function isInsideClassReflection(Scope $scope): bool + { + $classReflection = $scope->getClassReflection(); + if (! $classReflection instanceof ClassReflection) { + return false; + } + + return $classReflection->isClass(); + } } diff --git a/tests/Rules/NoReturnSetterMethodRule/Fixture/SkipRoute.php b/tests/Rules/NoReturnSetterMethodRule/Fixture/SkipRoute.php new file mode 100644 index 00000000..8a3bca10 --- /dev/null +++ b/tests/Rules/NoReturnSetterMethodRule/Fixture/SkipRoute.php @@ -0,0 +1,17 @@ +