Fix phpstan/phpstan#4173: Consequest scope with the same condition #27618
Annotations
1 error and 8 warnings
|
Run infection
Process completed with exit code 1.
|
|
Complete job
Node.js 20 actions are deprecated. The following actions are running on Node.js 20 and may not work as expected: actions/cache/restore@0057852bfaa89a56745cba8c7296529d2fc39830, actions/cache/save@0057852bfaa89a56745cba8c7296529d2fc39830, actions/cache@v4, shivammathur/setup-php@44454db4f0199b8b9685a5d763dc37cbf79108e1, step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e. Actions will be forced to run with Node.js 24 by default starting June 2nd, 2026. Node.js 20 will be removed from the runner on September 16th, 2026. Please check if updated versions of these actions are available that support Node.js 24. To opt into Node.js 24 now, set the FORCE_JAVASCRIPT_ACTIONS_TO_NODE24=true environment variable on the runner or in your workflow file. Once Node.js 24 becomes the default, you can temporarily opt out by setting ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true. For more information see: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/
|
|
Run infection:
src/Type/Php/FilterFunctionReturnTypeHelper.php#L207
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
if ($hasRequireArrayFlag->yes()) {
$type = new ArrayType($inputArrayKeyType ?? $mixedType, $type);
- if (!$hasThrowOnFailureFlag->yes() && !$inputIsArray->yes()) {
+ if ($hasThrowOnFailureFlag->no() && !$inputIsArray->yes()) {
$type = TypeCombinator::union($type, $defaultType);
}
}
|
|
Run infection:
src/Type/Php/FilterFunctionReturnTypeHelper.php#L201
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
}
}
- if ($hasThrowOnFailureFlag->yes()) {
+ if (!$hasThrowOnFailureFlag->no()) {
$type = TypeCombinator::remove($type, $defaultType);
}
|
|
Run infection:
src/Type/Php/FilterFunctionReturnTypeHelper.php#L156
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
$hasRequireArrayFlag = $this->hasFlag('FILTER_REQUIRE_ARRAY', $flagsType);
$hasThrowOnFailureFlag = $this->hasFlag('FILTER_THROW_ON_FAILURE', $flagsType);
if ($inputIsArray->no() && $hasRequireArrayFlag->yes()) {
- if ($hasThrowOnFailureFlag->yes()) {
+ if (!$hasThrowOnFailureFlag->no()) {
return new ErrorType();
}
|
|
Run infection:
src/Analyser/TypeSpecifier.php#L2247
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
}
if ($isPure !== null) {
- if ($isPure->no()) {
+ if (!$isPure->yes()) {
return new SpecifiedTypes([], []);
}
|
|
Run infection:
src/Analyser/TypeSpecifier.php#L2239
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
&& !$expr->name instanceof Name
) {
$nameType = $scope->getType($expr->name);
- if ($nameType->isCallable()->yes()) {
+ if (!$nameType->isCallable()->no()) {
$isPure = null;
foreach ($nameType->getCallableParametersAcceptors($scope) as $variant) {
$variantIsPure = $variant->isPure();
|
|
Run infection:
src/Analyser/MutatingScope.php#L3523
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
$otherType = $otherExpressionTypes[$guardExprString]->getType();
$guardType = $guardTypeHolder->getType();
- if ($otherType->isSuperTypeOf($guardType)->no()) {
+ if (!$otherType->isSuperTypeOf($guardType)->yes()) {
$currentConditionalExpressions[$exprString][$key] = $holder;
break;
}
|
|
Run infection:
src/Analyser/MutatingScope.php#L3511
Escaped Mutant for Mutator "PHPStan\Infection\TrinaryLogicMutator":
@@ @@
}
$typeHolder = $holder->getTypeHolder();
- if ($typeHolder->getCertainty()->no() && !$typeHolder->getExpr() instanceof Variable) {
+ if (!$typeHolder->getCertainty()->yes() && !$typeHolder->getExpr() instanceof Variable) {
continue;
}
|
Loading