123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598 |
- <?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\DoctrineAnnotation;
- use PhpCsFixer\Tests\AbstractDoctrineAnnotationFixerTestCase;
- /**
- * @internal
- *
- * @covers \PhpCsFixer\AbstractDoctrineAnnotationFixer
- * @covers \PhpCsFixer\Doctrine\Annotation\DocLexer
- * @covers \PhpCsFixer\Fixer\DoctrineAnnotation\DoctrineAnnotationBracesFixer
- *
- * @extends AbstractDoctrineAnnotationFixerTestCase<\PhpCsFixer\Fixer\DoctrineAnnotation\DoctrineAnnotationBracesFixer>
- *
- * @phpstan-import-type _AutogeneratedInputConfiguration from \PhpCsFixer\Fixer\DoctrineAnnotation\DoctrineAnnotationBracesFixer
- */
- final class DoctrineAnnotationBracesFixerTest extends AbstractDoctrineAnnotationFixerTestCase
- {
- /**
- * @dataProvider provideFixWithBracesCases
- */
- public function testFixWithBraces(string $expected, ?string $input = null): void
- {
- $this->fixer->configure(['syntax' => 'with_braces']);
- $this->doTest($expected, $input);
- }
- /**
- * @return iterable<array{0: string, 1?: null|string}>
- */
- public static function provideFixWithBracesCases(): iterable
- {
- yield from self::createTestCases([
- ['
- /**
- * @Foo()
- */'],
- ['
- /**
- * @Foo ()
- */'],
- ['
- /**
- * @Foo
- * (
- * )
- */'],
- ['
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo()
- */', '
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo
- */'],
- [
- '/** @Foo() */',
- '/** @Foo */',
- ],
- ['
- /**
- * @Foo(@Bar())
- */', '
- /**
- * @Foo(@Bar)
- */'],
- ['
- /**
- * @Foo(
- * @Bar()
- * )
- */', '
- /**
- * @Foo(
- * @Bar
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar(),
- * "baz"
- * )
- */', '
- /**
- * @Foo(
- * @Bar,
- * "baz"
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar\Baz()
- * )
- */', '
- /**
- * @Foo(
- * @Bar\Baz
- * )
- */'],
- ['
- /**
- * @Foo() @Bar\Baz()
- */', '
- /**
- * @Foo @Bar\Baz
- */'],
- ['
- /**
- * @Foo("@Bar")
- */'],
- ['
- /**
- * Description with a single " character.
- *
- * @Foo("string "" with inner quote")
- *
- * @param mixed description with a single " character.
- */'],
- ['
- /**
- * @Foo(@Bar
- */'],
- ['
- /**
- * @Foo())@Bar)
- */', '
- /**
- * @Foo)@Bar)
- */'],
- ['
- /**
- * See {@link https://help Help} or {@see BarClass} for details.
- */'],
- ['
- /**
- * @var int
- */'],
- ['
- /**
- * // PHPDocumentor 1
- * @abstract
- * @access
- * @code
- * @deprec
- * @encode
- * @exception
- * @final
- * @ingroup
- * @inheritdoc
- * @inheritDoc
- * @magic
- * @name
- * @toc
- * @tutorial
- * @private
- * @static
- * @staticvar
- * @staticVar
- * @throw
- *
- * // PHPDocumentor 2
- * @api
- * @author
- * @category
- * @copyright
- * @deprecated
- * @example
- * @filesource
- * @global
- * @ignore
- * @internal
- * @license
- * @link
- * @method
- * @package
- * @param
- * @property
- * @property-read
- * @property-write
- * @return
- * @see
- * @since
- * @source
- * @subpackage
- * @throws
- * @todo
- * @TODO
- * @usedBy
- * @uses
- * @var
- * @version
- *
- * // PHPUnit
- * @after
- * @afterClass
- * @backupGlobals
- * @backupStaticAttributes
- * @before
- * @beforeClass
- * @codeCoverageIgnore
- * @codeCoverageIgnoreStart
- * @codeCoverageIgnoreEnd
- * @covers
- * @coversDefaultClass
- * @coversNothing
- * @dataProvider
- * @depends
- * @expectedException
- * @expectedExceptionCode
- * @expectedExceptionMessage
- * @expectedExceptionMessageRegExp
- * @group
- * @large
- * @medium
- * @preserveGlobalState
- * @requires
- * @runTestsInSeparateProcesses
- * @runInSeparateProcess
- * @small
- * @test
- * @testdox
- * @ticket
- * @uses
- *
- * // PHPCheckStyle
- * @SuppressWarnings
- *
- * // PHPStorm
- * @noinspection
- *
- * // PEAR
- * @package_version
- *
- * // PlantUML
- * @enduml
- * @startuml
- *
- * // Psalm
- * @psalm
- * @psalm-param
- *
- * // PHPStan
- * @phpstan
- * @phpstan-param
- *
- * // other
- * @fix
- * @FIXME
- * @fixme
- * @fixme: foo
- * @override
- * @todo: foo
- */'],
- ]);
- yield [
- '<?php
- /**
- * @see \User getId()
- */
- ',
- ];
- }
- /**
- * @dataProvider provideFixWithoutBracesCases
- */
- public function testFixWithoutBraces(string $expected, ?string $input = null): void
- {
- $this->doTest($expected, $input);
- $this->fixer->configure(['syntax' => 'without_braces']);
- $this->doTest($expected, $input);
- }
- /**
- * @return iterable<array{0: string, 1?: null|string}>
- */
- public static function provideFixWithoutBracesCases(): iterable
- {
- yield from self::createTestCases([
- ['
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Baz\Bar
- */', '
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Baz\Bar ( )
- */'],
- [
- '/** @Foo */',
- '/** @Foo () */',
- ],
- ['
- /**
- * @Foo("bar")
- */'],
- ['
- /**
- * @Foo
- */', '
- /**
- * @Foo
- * (
- * )
- */'],
- ['
- /**
- * @Foo(@Bar)
- */', '
- /**
- * @Foo(@Bar())
- */'],
- ['
- /**
- * @Foo(
- * @Bar
- * )
- */', '
- /**
- * @Foo(
- * @Bar()
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar,
- * "baz"
- * )
- */', '
- /**
- * @Foo(
- * @Bar(),
- * "baz"
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar\Baz
- * )
- */', '
- /**
- * @Foo(
- * @Bar\Baz()
- * )
- */'],
- ['
- /**
- * @Foo @Bar\Baz
- */', '
- /**
- * @Foo() @Bar\Baz()
- */'],
- ['
- /**
- * @\Foo @\Bar\Baz
- */', '
- /**
- * @\Foo() @\Bar\Baz()
- */'],
- ['
- /**
- * @Foo("@Bar()")
- */'],
- ['
- /**
- * Description with a single " character.
- *
- * @Foo("string "" with inner quote")
- *
- * @param mixed description with a single " character.
- */'],
- ['
- /**
- * @Foo(
- */'],
- ['
- /**
- * @Foo)
- */'],
- ['
- /**
- * @Foo(@Bar()
- */'],
- ['
- /**
- * @Foo
- * @Bar
- * @Baz
- */', '
- /**
- * @Foo()
- * @Bar()
- * @Baz()
- */'],
- ['
- /**
- * @FIXME ()
- * @fixme ()
- * @TODO ()
- * @todo ()
- */'],
- ['
- /**
- * // PHPDocumentor 1
- * @abstract()
- * @access()
- * @code()
- * @deprec()
- * @encode()
- * @exception()
- * @final()
- * @ingroup()
- * @inheritdoc()
- * @inheritDoc()
- * @magic()
- * @name()
- * @toc()
- * @tutorial()
- * @private()
- * @static()
- * @staticvar()
- * @staticVar()
- * @throw()
- *
- * // PHPDocumentor 2
- * @api()
- * @author()
- * @category()
- * @copyright()
- * @deprecated()
- * @example()
- * @filesource()
- * @global()
- * @ignore()
- * @internal()
- * @license()
- * @link()
- * @method()
- * @package()
- * @param()
- * @property()
- * @property-read()
- * @property-write()
- * @return()
- * @see()
- * @since()
- * @source()
- * @subpackage()
- * @throws()
- * @todo()
- * @TODO()
- * @usedBy()
- * @uses()
- * @var()
- * @version()
- *
- * // PHPUnit
- * @after()
- * @afterClass()
- * @backupGlobals()
- * @backupStaticAttributes()
- * @before()
- * @beforeClass()
- * @codeCoverageIgnore()
- * @codeCoverageIgnoreStart()
- * @codeCoverageIgnoreEnd()
- * @covers()
- * @coversDefaultClass()
- * @coversNothing()
- * @dataProvider()
- * @depends()
- * @expectedException()
- * @expectedExceptionCode()
- * @expectedExceptionMessage()
- * @expectedExceptionMessageRegExp()
- * @group()
- * @large()
- * @medium()
- * @preserveGlobalState()
- * @requires()
- * @runTestsInSeparateProcesses()
- * @runInSeparateProcess()
- * @small()
- * @test()
- * @testdox()
- * @ticket()
- * @uses()
- *
- * // PHPCheckStyle
- * @SuppressWarnings()
- *
- * // PHPStorm
- * @noinspection()
- *
- * // PEAR
- * @package_version()
- *
- * // PlantUML
- * @enduml()
- * @startuml()
- *
- * // Psalm
- * @psalm()
- * @psalm-param()
- *
- * // PHPStan
- * @phpstan()
- * @psalm-param()
- *
- *
- * // other
- * @fix()
- * @FIXME()
- * @fixme()
- * @fixme: foo()
- * @override()
- * @todo: foo()
- */'],
- ]);
- yield [
- '<?php
- /**
- * @see \User getId()
- */
- ',
- ];
- }
- /**
- * @dataProvider provideFix82Cases
- *
- * @requires PHP 8.2
- */
- public function testFix82(string $expected, string $input): void
- {
- $this->doTest($expected, $input);
- }
- /**
- * @return iterable<array{string, string}>
- */
- public static function provideFix82Cases(): iterable
- {
- yield [
- '<?php
- /**
- * @author John Doe
- *
- * @Baz\Bar
- */
- readonly class FooClass{}',
- '<?php
- /**
- * @author John Doe
- *
- * @Baz\Bar ( )
- */
- readonly class FooClass{}',
- ];
- }
- }
|