From b8516ed6bab7ec50aae981698ce3f67f1be2e45a Mon Sep 17 00:00:00 2001 From: IanDelMar <42134098+IanDelMar@users.noreply.github.com> Date: Mon, 16 Oct 2023 19:23:56 +0200 Subject: [PATCH] Fix dynamic return type extension for `wp_die()` (#204) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Add missing tests for wp_die() * Fix wp_die() extension * Bump min PHPStan --------- Co-authored-by: Viktor Szépe --- composer.json | 2 +- src/WpDieDynamicFunctionReturnTypeExtension.php | 8 ++++---- tests/data/wp_die.php | 6 ++++-- 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/composer.json b/composer.json index b52b825..5f359b9 100644 --- a/composer.json +++ b/composer.json @@ -13,7 +13,7 @@ "require": { "php": "^7.2 || ^8.0", "php-stubs/wordpress-stubs": "^4.7 || ^5.0 || ^6.0", - "phpstan/phpstan": "^1.10.0", + "phpstan/phpstan": "^1.10.30", "symfony/polyfill-php73": "^1.12.0" }, "require-dev": { diff --git a/src/WpDieDynamicFunctionReturnTypeExtension.php b/src/WpDieDynamicFunctionReturnTypeExtension.php index bce6590..29c1fd6 100644 --- a/src/WpDieDynamicFunctionReturnTypeExtension.php +++ b/src/WpDieDynamicFunctionReturnTypeExtension.php @@ -14,7 +14,7 @@ use PHPStan\Type\Constant\ConstantStringType; use PHPStan\Type\Type; use PHPStan\Type\VoidType; -use PHPStan\Type\NeverType; +use PHPStan\Type\NonAcceptingNeverType; class WpDieDynamicFunctionReturnTypeExtension implements \PHPStan\Type\DynamicFunctionReturnTypeExtension { @@ -30,7 +30,7 @@ public function getTypeFromFunctionCall(FunctionReflection $functionReflection, // Called without $args parameter if (count($args) < 3) { - return new NeverType(); + return new NonAcceptingNeverType(); } $argType = $scope->getType($args[2]->value); @@ -42,12 +42,12 @@ public function getTypeFromFunctionCall(FunctionReflection $functionReflection, // Return never if the key 'exit' is not set. if (! $argType->hasOffsetValueType(new ConstantStringType('exit'))->yes()) { - return new NeverType(); + return new NonAcceptingNeverType(); } // Note WP's wp_die handlers do lazy comparison return $argType->getOffsetValueType(new ConstantStringType('exit'))->toBoolean()->isTrue()->yes() - ? new NeverType() + ? new NonAcceptingNeverType() : new VoidType(); } } diff --git a/tests/data/wp_die.php b/tests/data/wp_die.php index 0f2744f..e5d383d 100644 --- a/tests/data/wp_die.php +++ b/tests/data/wp_die.php @@ -9,7 +9,9 @@ /** @var array $array */ $array = null; -assertType('*NEVER*', wp_die('', '')); -assertType('*NEVER*', wp_die('', '', ['exit' => true])); +assertType('never', wp_die()); +assertType('never', wp_die('')); +assertType('never', wp_die('', '')); +assertType('never', wp_die('', '', ['exit' => true])); assertType('void', wp_die('', '', ['exit' => false])); assertType('void', wp_die('', '', $array));