diff --git a/tests/Issues/ReplaceStmtToExpr/Fixture/fixture.php.inc b/tests/Issues/ReplaceStmtToExpr/Fixture/fixture.php.inc new file mode 100644 index 00000000000..b6f22098e18 --- /dev/null +++ b/tests/Issues/ReplaceStmtToExpr/Fixture/fixture.php.inc @@ -0,0 +1,59 @@ +getUser($user); + + if (!$user) { + return false; + } + + return $user->isFoo() || $user->isBar(); + } + +} + +?> +----- +getUser($user); + + if (!$user instanceof \Rector\Core\Tests\Issues\ReplaceStmtToExpr\Fixture\User) { + return false; + } + if ($user->isFoo()) { + return true; + } + return (bool) $user->isBar(); + } + +} + +?> diff --git a/tests/Issues/ReplaceStmtToExpr/ReplaceStmtToExprTest.php b/tests/Issues/ReplaceStmtToExpr/ReplaceStmtToExprTest.php new file mode 100644 index 00000000000..9bb2efe91c3 --- /dev/null +++ b/tests/Issues/ReplaceStmtToExpr/ReplaceStmtToExprTest.php @@ -0,0 +1,28 @@ +doTestFile($filePath); + } + + public static function provideData(): Iterator + { + return self::yieldFilesFromDirectory(__DIR__ . '/Fixture'); + } + + public function provideConfigFilePath(): string + { + return __DIR__ . '/config/configured_rule.php'; + } +} diff --git a/tests/Issues/ReplaceStmtToExpr/config/configured_rule.php b/tests/Issues/ReplaceStmtToExpr/config/configured_rule.php new file mode 100644 index 00000000000..c43dd74aff2 --- /dev/null +++ b/tests/Issues/ReplaceStmtToExpr/config/configured_rule.php @@ -0,0 +1,16 @@ +rules([ + ExplicitBoolCompareRector::class, + FlipTypeControlToUseExclusiveTypeRector::class, + ReturnBinaryOrToEarlyReturnRector::class, + ]); +};