mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-01-26 22:27:58 -05:00
* PHPStan 2.0 fix https://github.com/FreshRSS/FreshRSS/issues/6989 https://github.com/phpstan/phpstan/releases/tag/2.0.0 https://github.com/phpstan/phpstan/blob/2.0.x/UPGRADING.md * More * More * Done * fix i18n CLI * Restore a PHPStan Next test For work towards PHPStan Level 10 * 4 more on Level 10 * fix getTagsForEntry * API at Level 10 * More Level 10 * Finish Minz at Level 10 * Finish CLI at Level 10 * Finish Controllers at Level 10 * More Level 10 * More * Pass bleedingEdge * Clean PHPStan options and add TODOs * Level 10 for main config * More * Consitency array vs. list * Sanitize themes get_infos * Simplify TagDAO->getTagsForEntries() * Finish reportAnyTypeWideningInVarTag * Prepare checkBenevolentUnionTypes and checkImplicitMixed * Fixes * Refix * Another fix * Casing of __METHOD__ constant
47 lines
1.1 KiB
PHP
47 lines
1.1 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
|
|
class dotNotationUtilTest extends PHPUnit\Framework\TestCase {
|
|
|
|
/**
|
|
* @return Traversable<array{array<string,mixed>,string,string}>
|
|
*/
|
|
public static function provideJsonDots(): Traversable {
|
|
$json = <<<json
|
|
{
|
|
"hello": "world",
|
|
"deeper": {
|
|
"hello": "again"
|
|
},
|
|
"items": [
|
|
{
|
|
"meta": {"title": "first"}
|
|
},
|
|
{
|
|
"meta": {"title": "second"}
|
|
}
|
|
]
|
|
}
|
|
json;
|
|
$array = json_decode($json, true);
|
|
|
|
yield [$array, 'hello', 'world'];
|
|
yield [$array, 'deeper.hello', 'again'];
|
|
yield [$array, 'items.0.meta.title', 'first'];
|
|
yield [$array, 'items[0].meta.title', 'first'];
|
|
yield [$array, 'items.1.meta.title', 'second'];
|
|
yield [$array, 'items[1].meta.title', 'second'];
|
|
}
|
|
|
|
/**
|
|
* @param array<string,mixed> $array
|
|
*/
|
|
#[DataProvider('provideJsonDots')]
|
|
public static function testJsonDots(array $array, string $key, string $expected): void {
|
|
$value = FreshRSS_dotNotation_Util::get($array, $key);
|
|
self::assertSame($expected, $value);
|
|
}
|
|
}
|