123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647 |
- <?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\DoctrineAnnotationIndentationFixer
- *
- * @extends AbstractDoctrineAnnotationFixerTestCase<\PhpCsFixer\Fixer\DoctrineAnnotation\DoctrineAnnotationIndentationFixer>
- *
- * @phpstan-import-type _AutogeneratedInputConfiguration from \PhpCsFixer\Fixer\DoctrineAnnotation\DoctrineAnnotationIndentationFixer
- */
- final class DoctrineAnnotationIndentationFixerTest extends AbstractDoctrineAnnotationFixerTestCase
- {
- /**
- * @dataProvider provideFixCases
- */
- public function testFix(string $expected, ?string $input = null): void
- {
- $this->doTest($expected, $input);
- }
- /**
- * @dataProvider provideFixCases
- */
- public function testFixWithUnindentedMixedLines(string $expected, ?string $input = null): void
- {
- $this->fixer->configure([
- 'indent_mixed_lines' => false,
- ]);
- $this->doTest($expected, $input);
- }
- /**
- * @return iterable<array{0: string, 1?: null|string}>
- */
- public static function provideFixCases(): iterable
- {
- yield from self::createTestCases([
- ['
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo
- * @Bar
- */', '
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo
- * @Bar
- */'],
- ['
- /**
- * @Foo(
- * foo="foo"
- * )
- */', '
- /**
- * @Foo(
- * foo="foo"
- * )
- */'],
- ['
- /**
- * @Foo(foo="foo", bar={
- * "foo": 1,
- * "foobar": 2,
- * "foobarbaz": 3
- * })
- */', '
- /**
- * @Foo(foo="foo", bar={
- * "foo": 1,
- * "foobar": 2,
- * "foobarbaz": 3
- * })
- */'],
- ['
- /**
- * @Foo(@Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * }))
- */', '
- /**
- * @Foo(@Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * }))
- */'],
- ['
- /**
- * @Foo(
- * @Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * })
- * )
- */', '
- /**
- * @Foo(
- * @Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * })
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar(
- * "baz"
- * )
- */'],
- ['
- /**
- * Foo(
- * Bar()
- * "baz"
- * )
- */'],
- ['
- /**
- * @Foo( @Bar(
- * "baz"
- * ) )
- */', '
- /**
- * @Foo( @Bar(
- * "baz"
- * ) )
- */'],
- ['
- /**
- * @Foo(x={
- * @Bar
- * })
- * @Foo\z
- */', '
- /**
- * @Foo(x={
- * @Bar
- * })
- * @Foo\z
- */'],
- ['
- /**
- * Description with a single " character.
- *
- * @Foo(
- * "string "" with inner quote"
- * )
- *
- * @param mixed description with a single " character.
- */', '
- /**
- * Description with a single " character.
- *
- * @Foo(
- * "string "" with inner quote"
- * )
- *
- * @param mixed description with a single " character.
- */'],
- ['
- /**
- * @Foo(@Bar,
- * @Baz)
- * @Qux
- */', '
- /**
- * @Foo(@Bar,
- * @Baz)
- * @Qux
- */'],
- ['
- /**
- * @Foo({"bar",
- * "baz"})
- * @Qux
- */', '
- /**
- * @Foo({"bar",
- * "baz"})
- * @Qux
- */'],
- ['
- /**
- * // 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
- *
- * // other
- * @fix
- * @FIXME
- * @fixme
- * @override
- */'],
- ['
- /**
- * @Foo({
- * @Bar()}
- * )
- */', '
- /**
- * @Foo({
- * @Bar()}
- * )
- */'],
- ['
- /**
- * @Foo(foo={
- * "bar": 1,
- * }, baz={
- * "qux": 2,
- * })
- */
- '],
- ['
- /**
- * @Foo(foo={
- * "foo",
- * }, bar={ "bar" }, baz={
- * "baz"
- * })
- */
- '],
- ]);
- yield [
- '<?php
- /**
- * @see \User getId()
- */
- ',
- ];
- }
- /**
- * @dataProvider provideFixWithIndentedMixedLinesCases
- */
- public function testFixWithIndentedMixedLines(string $expected, ?string $input = null): void
- {
- $this->fixer->configure([
- 'indent_mixed_lines' => true,
- ]);
- $this->doTest($expected, $input);
- }
- /**
- * @return iterable<array{0: string, 1?: null|string}>
- */
- public static function provideFixWithIndentedMixedLinesCases(): iterable
- {
- yield from self::createTestCases([
- ['
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo
- * @Bar
- */', '
- /**
- * Foo.
- *
- * @author John Doe
- *
- * @Foo
- * @Bar
- */'],
- ['
- /**
- * @Foo(
- * foo="foo"
- * )
- */', '
- /**
- * @Foo(
- * foo="foo"
- * )
- */'],
- ['
- /**
- * @Foo(foo="foo", bar={
- * "foo": 1,
- * "foobar": 2,
- * "foobarbaz": 3
- * })
- */', '
- /**
- * @Foo(foo="foo", bar={
- * "foo": 1,
- * "foobar": 2,
- * "foobarbaz": 3
- * })
- */'],
- ['
- /**
- * @Foo(@Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * }))
- */', '
- /**
- * @Foo(@Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * }))
- */'],
- ['
- /**
- * @Foo(
- * @Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * })
- * )
- */', '
- /**
- * @Foo(
- * @Bar({
- * "FOO": 1,
- * "BAR": 2,
- * "BAZ": 3
- * })
- * )
- */'],
- ['
- /**
- * @Foo(
- * @Bar(
- * "baz"
- * )
- */'],
- ['
- /**
- * Foo(
- * Bar()
- * "baz"
- * )
- */'],
- ['
- /**
- * @Foo( @Bar(
- * "baz"
- * ) )
- */', '
- /**
- * @Foo( @Bar(
- * "baz"
- * ) )
- */'],
- ['
- /**
- * @Foo(x={
- * @Bar
- * })
- * @Foo\z
- */', '
- /**
- * @Foo(x={
- * @Bar
- * })
- * @Foo\z
- */'],
- ['
- /**
- * Description with a single " character.
- *
- * @Foo(
- * "string "" with inner quote"
- * )
- *
- * @param mixed description with a single " character.
- */', '
- /**
- * Description with a single " character.
- *
- * @Foo(
- * "string "" with inner quote"
- * )
- *
- * @param mixed description with a single " character.
- */'],
- ['
- /**
- * @Foo(@Bar,
- * @Baz)
- * @Qux
- */', '
- /**
- * @Foo(@Bar,
- * @Baz)
- * @Qux
- */'],
- ['
- /**
- * @Foo({"bar",
- * "baz"})
- * @Qux
- */', '
- /**
- * @Foo({"bar",
- * "baz"})
- * @Qux
- */'],
- ['
- /**
- * // 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
- *
- * // other
- * @fix
- * @FIXME
- * @fixme
- * @override
- */'],
- ['
- /**
- * @Foo({
- * @Bar()}
- * )
- */'],
- ]);
- }
- }
|