123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- <?php
- declare(strict_types=1);
- /*
- * This file is part of PHP CS Fixer.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- * Dariusz Rumiński <dariusz.ruminski@gmail.com>
- *
- * This source file is subject to the MIT license that is bundled
- * with this source code in the file LICENSE.
- */
- namespace PhpCsFixer\Tests\Fixer\Phpdoc;
- use PhpCsFixer\Tests\Test\AbstractFixerTestCase;
- /**
- * @author Graham Campbell <hello@gjcampbell.co.uk>
- *
- * @internal
- *
- * @covers \PhpCsFixer\AbstractPhpdocTypesFixer
- * @covers \PhpCsFixer\Fixer\Phpdoc\PhpdocScalarFixer
- *
- * @extends AbstractFixerTestCase<\PhpCsFixer\Fixer\Phpdoc\PhpdocScalarFixer>
- *
- * @phpstan-import-type _AutogeneratedInputConfiguration from \PhpCsFixer\Fixer\Phpdoc\PhpdocScalarFixer
- */
- final class PhpdocScalarFixerTest extends AbstractFixerTestCase
- {
- /**
- * @param _AutogeneratedInputConfiguration $config
- *
- * @dataProvider provideFixCases
- */
- public function testFix(string $expected, ?string $input = null, array $config = []): void
- {
- $this->fixer->configure($config);
- $this->doTest($expected, $input);
- }
- public static function provideFixCases(): iterable
- {
- yield 'basic fix' => [
- '<?php
- /**
- * @return int
- */
- ',
- '<?php
- /**
- * @return integer
- */
- ',
- ];
- yield 'property fix' => [
- '<?php
- /**
- * @method int foo()
- * @property int $foo
- * @property callable $foo
- * @property-read bool $bar
- * @property-write float $baz
- */
- ',
- '<?php
- /**
- * @method integer foo()
- * @property integer $foo
- * @property callback $foo
- * @property-read boolean $bar
- * @property-write double $baz
- */
- ',
- ];
- yield 'do not modify variables' => [
- '<?php
- /**
- * @param int $integer
- */
- ',
- '<?php
- /**
- * @param integer $integer
- */
- ',
- ];
- yield 'fix with tabs on one line' => [
- "<?php /**\t@return\tbool\t*/",
- "<?php /**\t@return\tboolean\t*/",
- ];
- yield 'fix more things' => [
- '<?php
- /**
- * Hello there mr integer!
- *
- * @param int|float $integer
- * @param int|int[] $foo
- * @param string|null $bar
- *
- * @return string|bool
- */
- ',
- '<?php
- /**
- * Hello there mr integer!
- *
- * @param integer|real $integer
- * @param int|integer[] $foo
- * @param str|null $bar
- *
- * @return string|boolean
- */
- ',
- ];
- yield 'fix var' => [
- '<?php
- /**
- * @var int Some integer value.
- */
- ',
- '<?php
- /**
- * @var integer Some integer value.
- */
- ',
- ];
- yield 'fix var with more stuff' => [
- '<?php
- /**
- * @var bool|int|Double Booleans, integers and doubles.
- */
- ',
- '<?php
- /**
- * @var boolean|integer|Double Booleans, integers and doubles.
- */
- ',
- ];
- yield 'fix type' => [
- '<?php
- /**
- * @type float
- */
- ',
- '<?php
- /**
- * @type real
- */
- ',
- ];
- yield 'do not fix' => [
- '<?php
- /**
- * @var notaboolean
- */
- ',
- ];
- yield 'complex mix' => [
- '<?php
- /**
- * @var notabooleanthistime|bool|integerr
- */
- ',
- '<?php
- /**
- * @var notabooleanthistime|boolean|integerr
- */
- ',
- ];
- yield 'do not modify complex tag' => [
- '<?php
- /**
- * @Type("boolean")
- */
- ',
- ];
- yield 'do not modify strings' => [
- "<?php
- \$string = '
- /**
- * @var boolean
- */
- ';
- ",
- ];
- yield 'empty DocBlock' => [
- '<?php
- /**
- *
- */
- ',
- ];
- yield 'wrong cased Phpdoc tag is not altered' => [
- '<?php
- /**
- * @Param boolean
- *
- * @Return int
- */
- ',
- ];
- yield 'inline doc' => [
- '<?php
- /**
- * Does stuff with stuffs.
- *
- * @param array $stuffs {
- * @type bool $foo
- * @type int $bar
- * }
- */
- ',
- '<?php
- /**
- * Does stuff with stuffs.
- *
- * @param array $stuffs {
- * @type boolean $foo
- * @type integer $bar
- * }
- */
- ',
- ];
- yield 'fix callback' => [
- '<?php
- /**
- * @method int foo()
- * @property int $foo
- * @property callable $foo
- * @property-read bool $bar
- * @property-write float $baz
- */
- ',
- '<?php
- /**
- * @method integer foo()
- * @property integer $foo
- * @property callback $foo
- * @property-read boolean $bar
- * @property-write double $baz
- */
- ',
- ['types' => ['boolean', 'callback', 'double', 'integer', 'real', 'str']],
- ];
- yield 'fix Windows line endings' => [
- str_replace("\n", "\r\n", '<?php
- /**
- * @return int
- */
- '),
- str_replace("\n", "\r\n", '<?php
- /**
- * @return integer
- */
- '),
- ];
- yield [
- '<?php /** @var array<int, bool> */',
- '<?php /** @var array<integer, boolean> */',
- ];
- yield [
- '<?php /** @var array{bool, int, string} */',
- '<?php /** @var array{boolean, integer, str} */',
- ];
- yield [
- '<?php /** @var array{int, array{string, bool}} */',
- '<?php /** @var array{integer, array{str, boolean}} */',
- ];
- yield [
- '<?php /** @var array{index: int, isRequired: bool} */',
- '<?php /** @var array{index: integer, isRequired: boolean} */',
- ];
- }
- }
|