1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- <?php
- /*
- * This file is part of Psy Shell.
- *
- * (c) 2012-2023 Justin Hileman
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Psy\Test\Formatter;
- use Psy\Formatter\DocblockFormatter;
- use Symfony\Component\Console\Formatter\OutputFormatter;
- /**
- * @group isolation-fail
- */
- class DocblockFormatterTest extends \Psy\Test\TestCase
- {
- /**
- * This is a docblock!
- *
- * @author Justin Hileman <justin@justinhileman.info>
- *
- * @throws \InvalidArgumentException if $foo is empty
- *
- * @param mixed $foo It's a foo thing
- * @param int $bar
- *
- * @return string A string of no consequence
- */
- private function methodWithDocblock($foo, $bar = 1)
- {
- if (empty($foo)) {
- throw new \InvalidArgumentException();
- }
- return 'method called';
- }
- public function testFormat()
- {
- $escapedEmail = OutputFormatter::escape('<justin@justinhileman.info>');
- $expected = <<<EOS
- <comment>Description:</comment>
- This is a docblock!
- <comment>Throws:</comment>
- <info>\\InvalidArgumentException </info> if \$foo is empty
- <comment>Param:</comment>
- <info>mixed </info> <strong>\$foo </strong> It's a foo thing
- <info>int </info> <strong>\$bar </strong>
- <comment>Return:</comment>
- <info>string </info> A string of no consequence
- <comment>Author:</comment> Justin Hileman $escapedEmail
- EOS;
- $this->assertSame(
- $expected,
- DocblockFormatter::format(new \ReflectionMethod($this, 'methodWithDocblock'))
- );
- }
- }
|