1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 22:01:48 +01:00
Marco Pivetta 45f743f851 Adjusted assertDifferentTypeOfArray test to avoid intersecting incompatible string arrays
Getting one interesting failure caused by the `lowercase-string` refinement done before:

```
  There was 1 error:

  1) Psalm\Tests\AssertAnnotationTest::testValidCode with data set "assertDifferentTypeOfArray" ('<?php\n                    /*...ts[1];')
  Psalm\Exception\CodeException: DocblockTypeContradiction - src/somefile.php:21:21 - Cannot resolve types for $parts - docblock-defined type list{0: lowercase-string, 1?: lowercase-string} does not contain list{string, string}
```

Happens on this bit:

```php
           'assertDifferentTypeOfArray' => [
                'code' => '<?php
                    /**
                     * @psalm-assert list{string, string} $value
                     * @param mixed $value
                     */
                    function isStringTuple($value): void {
                        if (!is_array($value)
                            || !isset($value[0])
                            || !isset($value[1])
                            || !is_string($value[0])
                            || !is_string($value[1])
                        ) {
                            throw new \Exception("bad");
                        }
                    }

                    $s = "";

                    $parts = explode(":", $s, 2);

                    isStringTuple($parts);

                    echo $parts[0];
                    echo $parts[1];',
            ],
```

If I change this to:

```
@psalm-assert list{lowercase-string, lowercase-string} $value
```

Then everything works: I'm wondering if this error has to do with array intersections, and whether suppressing it suffices.

For now, changing the input string, so it is not a `lowercase-string`, is sufficient.
2022-12-28 17:57:33 +01:00
..
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 14:35:41 -06:00
2021-12-15 04:42:37 +01:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-19 12:29:27 +01:00
Fix
2022-12-19 21:25:06 +01:00
2022-12-19 22:23:31 +01:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-21 06:45:45 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
Fix
2022-12-19 13:10:17 +01:00
2022-12-20 17:18:50 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-19 19:24:03 +01:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-23 16:13:46 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00
2022-12-18 13:20:31 -06:00