ÿØÿà JFIF ÿá Exif MM * ÿÛ C
Server IP : 199.250.214.225 / Your IP : 18.117.98.49 Web Server : Apache System : Linux vps64074.inmotionhosting.com 3.10.0-1160.105.1.vz7.214.3 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : nicngo5 ( 1001) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /home/nicngo5/nicnAdmin/vendor/phpdocumentor/reflection-docblock/tests/unit/DocBlock/ |
Upload File : |
<?php /** * This file is part of phpDocumentor. * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. * * @copyright 2010-2015 Mike van Riel<mike@phpdoc.org> * @license http://www.opensource.org/licenses/mit-license.php MIT * @link http://phpdoc.org */ namespace phpDocumentor\Reflection\DocBlock; use Mockery as m; use phpDocumentor\Reflection\DocBlock\Tags\Link; use phpDocumentor\Reflection\Types\Context; /** * @coversDefaultClass \phpDocumentor\Reflection\DocBlock\DescriptionFactory * @covers ::<private> */ class DescriptionFactoryTest extends \PHPUnit_Framework_TestCase { /** * @covers ::__construct * @covers ::create * @uses phpDocumentor\Reflection\DocBlock\Description * @dataProvider provideSimpleExampleDescriptions */ public function testDescriptionCanParseASimpleString($contents) { $tagFactory = m::mock(TagFactory::class); $tagFactory->shouldReceive('create')->never(); $factory = new DescriptionFactory($tagFactory); $description = $factory->create($contents, new Context('')); $this->assertSame($contents, $description->render()); } /** * @covers ::__construct * @covers ::create * @uses phpDocumentor\Reflection\DocBlock\Description * @dataProvider provideEscapeSequences */ public function testEscapeSequences($contents, $expected) { $tagFactory = m::mock(TagFactory::class); $tagFactory->shouldReceive('create')->never(); $factory = new DescriptionFactory($tagFactory); $description = $factory->create($contents, new Context('')); $this->assertSame($expected, $description->render()); } /** * @covers ::__construct * @covers ::create * @uses phpDocumentor\Reflection\DocBlock\Description * @uses phpDocumentor\Reflection\DocBlock\Tags\Link * @uses phpDocumentor\Reflection\DocBlock\Tags\BaseTag * @uses phpDocumentor\Reflection\DocBlock\Tags\Formatter\PassthroughFormatter * @uses phpDocumentor\Reflection\Types\Context */ public function testDescriptionCanParseAStringWithInlineTag() { $contents = 'This is text for a {@link http://phpdoc.org/ description} that uses an inline tag.'; $context = new Context(''); $tagFactory = m::mock(TagFactory::class); $tagFactory->shouldReceive('create') ->once() ->with('@link http://phpdoc.org/ description', $context) ->andReturn(new Link('http://phpdoc.org/', new Description('description'))) ; $factory = new DescriptionFactory($tagFactory); $description = $factory->create($contents, $context); $this->assertSame($contents, $description->render()); } /** * @covers ::__construct * @covers ::create * @uses phpDocumentor\Reflection\DocBlock\Description * @uses phpDocumentor\Reflection\DocBlock\Tags\Link * @uses phpDocumentor\Reflection\DocBlock\Tags\BaseTag * @uses phpDocumentor\Reflection\DocBlock\Tags\Formatter\PassthroughFormatter * @uses phpDocumentor\Reflection\Types\Context */ public function testDescriptionCanParseAStringStartingWithInlineTag() { $contents = '{@link http://phpdoc.org/ This} is text for a description that starts with an inline tag.'; $context = new Context(''); $tagFactory = m::mock(TagFactory::class); $tagFactory->shouldReceive('create') ->once() ->with('@link http://phpdoc.org/ This', $context) ->andReturn(new Link('http://phpdoc.org/', new Description('This'))) ; $factory = new DescriptionFactory($tagFactory); $description = $factory->create($contents, $context); $this->assertSame($contents, $description->render()); } /** * @covers ::__construct * @covers ::create * @uses phpDocumentor\Reflection\DocBlock\Description */ public function testIfSuperfluousStartingSpacesAreRemoved() { $factory = new DescriptionFactory(m::mock(TagFactory::class)); $descriptionText = <<<DESCRIPTION This is a multiline description that you commonly see with tags. It does have a multiline code sample that should align, no matter what All spaces superfluous spaces on the second and later lines should be removed but the code sample should still be indented. DESCRIPTION; $expectedDescription = <<<DESCRIPTION This is a multiline description that you commonly see with tags. It does have a multiline code sample that should align, no matter what All spaces superfluous spaces on the second and later lines should be removed but the code sample should still be indented. DESCRIPTION; $description = $factory->create($descriptionText, new Context('')); $this->assertSame($expectedDescription, $description->render()); } /** * Provides a series of example strings that the parser should correctly interpret and return. * * @return string[][] */ public function provideSimpleExampleDescriptions() { return [ ['This is text for a description.'], ['This is text for a description containing { that is literal.'], ['This is text for a description containing } that is literal.'], ['This is text for a description with {just a text} that is not a tag.'], ]; } public function provideEscapeSequences() { return [ ['This is text for a description with a {@}.', 'This is text for a description with a @.'], ['This is text for a description with a {}.', 'This is text for a description with a }.'], ]; } }