mirror of
https://github.com/danog/psalm.git
synced 2025-01-22 05:41:20 +01:00
Fix return type checks
This commit is contained in:
parent
202fb7026a
commit
952045e2ba
@ -2016,22 +2016,15 @@ class AssertionFinder
|
||||
return;
|
||||
}
|
||||
|
||||
$always_contains = TypeAnalyzer::isContainedBy(
|
||||
$codebase,
|
||||
$expected_type,
|
||||
$first_var_type
|
||||
);
|
||||
|
||||
$never_contains = !TypeAnalyzer::isContainedBy(
|
||||
if (!TypeAnalyzer::isContainedBy(
|
||||
$codebase,
|
||||
$first_var_type,
|
||||
$expected_type
|
||||
);
|
||||
)) {
|
||||
return;
|
||||
}
|
||||
|
||||
/** @psalm-suppress ParadoxicalCondition */
|
||||
if (($always_contains && !$negate)
|
||||
|| ($never_contains && $negate)
|
||||
) {
|
||||
if (!$negate) {
|
||||
if ($first_var_type->from_docblock) {
|
||||
if (IssueBuffer::accepts(
|
||||
new RedundantConditionGivenDocblockType(
|
||||
@ -2053,9 +2046,7 @@ class AssertionFinder
|
||||
// fall through
|
||||
}
|
||||
}
|
||||
} elseif (($always_contains && $negate)
|
||||
|| ($never_contains && !$negate)
|
||||
) {
|
||||
} else {
|
||||
if ($first_var_type->from_docblock) {
|
||||
if (IssueBuffer::accepts(
|
||||
new DocblockTypeContradiction(
|
||||
|
@ -1047,7 +1047,7 @@ class TypeAnalyzer
|
||||
}
|
||||
|
||||
if ($container_type_part instanceof TNumeric &&
|
||||
($input_type_part->isNumericType() || $input_type_part instanceof TString)
|
||||
$input_type_part->isNumericType()
|
||||
) {
|
||||
return true;
|
||||
}
|
||||
|
@ -188,7 +188,7 @@ class TypeCombinationTest extends TestCase
|
||||
],
|
||||
],
|
||||
'arrayMixedOrStringKeys' => [
|
||||
'array<int|mixed|string, string>',
|
||||
'array<array-key, string>',
|
||||
[
|
||||
'array<int|string,string>',
|
||||
'array<mixed,string>',
|
||||
|
@ -816,7 +816,7 @@ class TypeParseTest extends TestCase
|
||||
*/
|
||||
public function testVeryLargeType()
|
||||
{
|
||||
$very_large_type = 'array{a: Closure():(array<mixed, mixed>|null), b?: Closure():array<mixed, mixed>, c?: Closure():array<mixed, mixed>, d?: Closure():array<mixed, mixed>, e?: Closure():(array{f: null|string, g: null|string, h: null|string, i: string, j: mixed, k: mixed, l: mixed, m: mixed, n: bool, o?: array{0: string}}|null), p?: Closure():(array{f: null|string, g: null|string, h: null|string, i: string, j: mixed, k: mixed, l: mixed, m: mixed, n: bool, o?: array{0: string}}|null), q: string, r?: Closure():(array<mixed, mixed>|null), s: array<mixed, mixed>}|null';
|
||||
$very_large_type = 'array{a: Closure():(array<array-key, mixed>|null), b?: Closure():array<array-key, mixed>, c?: Closure():array<array-key, mixed>, d?: Closure():array<array-key, mixed>, e?: Closure():(array{f: null|string, g: null|string, h: null|string, i: string, j: mixed, k: mixed, l: mixed, m: mixed, n: bool, o?: array{0: string}}|null), p?: Closure():(array{f: null|string, g: null|string, h: null|string, i: string, j: mixed, k: mixed, l: mixed, m: mixed, n: bool, o?: array{0: string}}|null), q: string, r?: Closure():(array<array-key, mixed>|null), s: array<array-key, mixed>}|null';
|
||||
|
||||
$this->assertSame(
|
||||
$very_large_type,
|
||||
|
@ -59,10 +59,8 @@ class ReconcilerTest extends \Psalm\Tests\TestCase
|
||||
$reconciled->getId()
|
||||
);
|
||||
|
||||
if (is_array($reconciled->getAtomicTypes())) {
|
||||
$this->assertContainsOnlyInstancesOf('Psalm\Type\Atomic', $reconciled->getAtomicTypes());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider providerTestTypeIsContainedBy
|
||||
|
@ -773,6 +773,16 @@ class RedundantConditionTest extends \Psalm\Tests\TestCase
|
||||
'$fp' => 'closed-resource',
|
||||
]
|
||||
],
|
||||
'allowCheckOnReturnTypeUnion' => [
|
||||
'<?php
|
||||
/** @return int|string */
|
||||
function returnsInt() {
|
||||
return rand(0, 1) ? 1 : "hello";
|
||||
}
|
||||
|
||||
if (is_int(returnsInt())) {}
|
||||
if (!is_int(returnsInt())) {}',
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
@ -1260,6 +1270,27 @@ class RedundantConditionTest extends \Psalm\Tests\TestCase
|
||||
if (is_int(returnsInt())) {}',
|
||||
'error_message' => 'RedundantCondition',
|
||||
],
|
||||
'preventAlwaysReturningSpecificInt' => [
|
||||
'<?php
|
||||
/**
|
||||
* @return 3|4
|
||||
*/
|
||||
function returnsInt(): int {
|
||||
return rand(0, 1) ? 3 : 4;
|
||||
}
|
||||
|
||||
if (is_int(returnsInt())) {}',
|
||||
'error_message' => 'RedundantConditionGivenDocblockType',
|
||||
],
|
||||
'preventNotAlwaysReturningInt' => [
|
||||
'<?php
|
||||
function returnsInt(): int {
|
||||
return 3;
|
||||
}
|
||||
|
||||
if (!is_int(returnsInt())) {}',
|
||||
'error_message' => 'TypeDoesNotContainType',
|
||||
],
|
||||
];
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user