123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- <?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\DocBlock;
- use PhpCsFixer\DocBlock\DocBlock;
- use PhpCsFixer\DocBlock\Line;
- use PhpCsFixer\Tests\TestCase;
- /**
- * @author Graham Campbell <hello@gjcampbell.co.uk>
- *
- * @internal
- *
- * @covers \PhpCsFixer\DocBlock\Line
- */
- final class LineTest extends TestCase
- {
- /**
- * This represents the content an entire docblock.
- */
- private static string $sample = '/**
- * Test docblock.
- *
- * @param string $hello
- * @param bool $test Description
- * extends over many lines
- *
- * @param adkjbadjasbdand $asdnjkasd
- *
- * @throws \Exception asdnjkasd
- * asdasdasdasdasdasdasdasd
- * kasdkasdkbasdasdasdjhbasdhbasjdbjasbdjhb
- *
- * @return void
- */';
- /**
- * This represents the content of each line.
- *
- * @var list<string>
- */
- private static array $content = [
- "/**\n",
- " * Test docblock.\n",
- " *\n",
- " * @param string \$hello\n",
- " * @param bool \$test Description\n",
- " * extends over many lines\n",
- " *\n",
- " * @param adkjbadjasbdand \$asdnjkasd\n",
- " *\n",
- " * @throws \\Exception asdnjkasd\n",
- " * asdasdasdasdasdasdasdasd\n",
- " * kasdkasdkbasdasdasdjhbasdhbasjdbjasbdjhb\n",
- " *\n",
- " * @return void\n",
- ' */',
- ];
- /**
- * This represents the if each line is "useful".
- *
- * @var list<bool>
- */
- private static array $useful = [
- false,
- true,
- false,
- true,
- true,
- true,
- false,
- true,
- false,
- true,
- true,
- true,
- false,
- true,
- false,
- ];
- /**
- * This represents the if each line "contains a tag".
- *
- * @var list<bool>
- */
- private static array $tag = [
- false,
- false,
- false,
- true,
- true,
- false,
- false,
- true,
- false,
- true,
- false,
- false,
- false,
- true,
- false,
- ];
- /**
- * @dataProvider provideLinesCases
- */
- public function testPosAndContent(int $pos, string $content): void
- {
- $doc = new DocBlock(self::$sample);
- $line = $doc->getLine($pos);
- self::assertSame($content, $line->getContent());
- self::assertSame($content, (string) $line);
- }
- /**
- * @dataProvider provideLinesCases
- */
- public function testStartOrEndPos(int $pos): void
- {
- $doc = new DocBlock(self::$sample);
- $line = $doc->getLine($pos);
- self::assertSame(0 === $pos, $line->isTheStart());
- self::assertSame(14 === $pos, $line->isTheEnd());
- }
- /**
- * @return iterable<array{int, string}>
- */
- public static function provideLinesCases(): iterable
- {
- foreach (self::$content as $index => $content) {
- yield [$index, $content];
- }
- }
- /**
- * @dataProvider provideUsefulCases
- */
- public function testUseful(int $pos, bool $useful): void
- {
- $doc = new DocBlock(self::$sample);
- $line = $doc->getLine($pos);
- self::assertSame($useful, $line->containsUsefulContent());
- }
- /**
- * @return iterable<array{int, bool}>
- */
- public static function provideUsefulCases(): iterable
- {
- foreach (self::$useful as $index => $useful) {
- yield [$index, $useful];
- }
- }
- /**
- * @dataProvider provideTagCases
- */
- public function testTag(int $pos, bool $tag): void
- {
- $doc = new DocBlock(self::$sample);
- $line = $doc->getLine($pos);
- self::assertSame($tag, $line->containsATag());
- }
- /**
- * @return iterable<array{int, bool}>
- */
- public static function provideTagCases(): iterable
- {
- foreach (self::$tag as $index => $tag) {
- yield [$index, $tag];
- }
- }
- public function testSetContent(): void
- {
- $line = new Line(" * @param \$foo Hi!\n");
- self::assertSame(" * @param \$foo Hi!\n", $line->getContent());
- $line->addBlank();
- self::assertSame(" * @param \$foo Hi!\n *\n", $line->getContent());
- $line->setContent("\t * test\r\n");
- self::assertSame("\t * test\r\n", $line->getContent());
- $line->addBlank();
- self::assertSame("\t * test\r\n\t *\r\n", $line->getContent());
- $line->remove();
- self::assertSame('', $line->getContent());
- }
- }
|