From b005e25b17bf28f5d1e40321e0f73acc32a2abfb Mon Sep 17 00:00:00 2001 From: dpi Date: Fri, 20 Oct 2023 14:45:34 +0800 Subject: [PATCH] =?UTF-8?q?=E2=9C=A8=20Restore=20`SlevomatCodingStandard.T?= =?UTF-8?q?ypeHints.ReturnTypeHint.UselessAnnotation`=20(#53)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This reverts commit a4d68e37b31646dd90ff9a804a2dea748b2a9494. --- PreviousNextDrupal/ruleset.xml | 1 - README.md | 4 ---- composer.json | 2 +- tests/Sniffs/ReturnTypeHintTest.php | 13 +++++++++++++ tests/Sniffs/fixtures/ReturnTypeHintUseless.php | 12 ++++++++++++ .../ReturnTypeHintUselessWithDescription.php | 13 +++++++++++++ 6 files changed, 39 insertions(+), 6 deletions(-) create mode 100644 tests/Sniffs/fixtures/ReturnTypeHintUseless.php create mode 100644 tests/Sniffs/fixtures/ReturnTypeHintUselessWithDescription.php diff --git a/PreviousNextDrupal/ruleset.xml b/PreviousNextDrupal/ruleset.xml index 351bfe4..09b1e7a 100644 --- a/PreviousNextDrupal/ruleset.xml +++ b/PreviousNextDrupal/ruleset.xml @@ -42,7 +42,6 @@ - 0 0 diff --git a/README.md b/README.md index 34ba6e4..dea2c81 100644 --- a/README.md +++ b/README.md @@ -161,10 +161,6 @@ Developers are entrusted to properly self-describe code. Suggestions to improve This rule has trouble with newer PHP syntax, especially expression throwables. In any case this rule is best enforced with static analysis. -#### SlevomatCodingStandard.TypeHints.ReturnTypeHint.UselessAnnotation - -This rule is too greedy about what it thinks is 'useless'. Unique detail is removed. - --- _Drupal is a registered trademark of Dries Buytaert._ diff --git a/composer.json b/composer.json index 8b996da..a69b778 100644 --- a/composer.json +++ b/composer.json @@ -7,7 +7,7 @@ "php": "^8.0", "dealerdirect/phpcodesniffer-composer-installer": "^1.0.0", "drupal/coder": "^8.3.21", - "slevomat/coding-standard": "^8.7.1", + "slevomat/coding-standard": "^8.13.2", "squizlabs/php_codesniffer": "^3.7.1" }, "require-dev": { diff --git a/tests/Sniffs/ReturnTypeHintTest.php b/tests/Sniffs/ReturnTypeHintTest.php index 2932611..3656182 100644 --- a/tests/Sniffs/ReturnTypeHintTest.php +++ b/tests/Sniffs/ReturnTypeHintTest.php @@ -4,6 +4,8 @@ namespace PreviousNext\CodingStandard\Tests\Sniffs; +use SlevomatCodingStandard\Sniffs\TypeHints\ReturnTypeHintSniff; + /** * @covers \SlevomatCodingStandard\Sniffs\TypeHints\ReturnTypeHintSniff * @see https://github.com/slevomat/coding-standard/blob/master/doc/type-hints.md#slevomatcodingstandardtypehintsreturntypehint- @@ -26,6 +28,17 @@ public function testIgnoreTraversable(): void { self::assertNoSniffError($report, 8); } + public function testUseless(): void { + $report = self::checkFile(__DIR__ . '/fixtures/ReturnTypeHintUseless.php'); + self::assertSniffError($report, 8, code: ReturnTypeHintSniff::CODE_USELESS_ANNOTATION); + } + + public function testUselessWithDescription(): void { + $report = self::checkFile(__DIR__ . '/fixtures/ReturnTypeHintUselessWithDescription.php'); + self::assertSame(0, $report->getErrorCount()); + self::assertNoSniffError($report, 8); + } + protected static function getSniffName(): string { return 'SlevomatCodingStandard.TypeHints.ReturnTypeHint'; } diff --git a/tests/Sniffs/fixtures/ReturnTypeHintUseless.php b/tests/Sniffs/fixtures/ReturnTypeHintUseless.php new file mode 100644 index 0000000..8f57d33 --- /dev/null +++ b/tests/Sniffs/fixtures/ReturnTypeHintUseless.php @@ -0,0 +1,12 @@ +