Mercurial > hg > isophonics-drupal-site
diff vendor/psy/psysh/test/Psy/Test/Util/DocblockTest.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/psy/psysh/test/Psy/Test/Util/DocblockTest.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,100 @@ +<?php + +/* + * This file is part of Psy Shell. + * + * (c) 2012-2017 Justin Hileman + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Psy\Test\Util; + +use Psy\Util\Docblock; + +class DocblockTest extends \PHPUnit\Framework\TestCase +{ + /** + * @dataProvider comments + */ + public function testDocblockParsing($comment, $body, $tags) + { + $reflector = $this + ->getMockBuilder('ReflectionClass') + ->disableOriginalConstructor() + ->getMock(); + + $reflector->expects($this->once()) + ->method('getDocComment') + ->will($this->returnValue($comment)); + + $docblock = new Docblock($reflector); + + $this->assertEquals($body, $docblock->desc); + + foreach ($tags as $tag => $value) { + $this->assertTrue($docblock->hasTag($tag)); + $this->assertEquals($value, $docblock->tag($tag)); + } + } + + public function comments() + { + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('We have issues with PHPUnit mocks on HHVM.'); + } + + return array( + array('', '', array()), + array( + '/** + * This is a docblock + * + * @throws \Exception with a description + */', + 'This is a docblock', + array( + 'throws' => array(array('type' => '\Exception', 'desc' => 'with a description')), + ), + ), + array( + '/** + * This is a slightly longer docblock + * + * @param int $foo Is a Foo + * @param string $bar With some sort of description + * @param \ClassName $baz is cool too + * + * @return int At least it isn\'t a string + */', + 'This is a slightly longer docblock', + array( + 'param' => array( + array('type' => 'int', 'desc' => 'Is a Foo', 'var' => '$foo'), + array('type' => 'string', 'desc' => 'With some sort of description', 'var' => '$bar'), + array('type' => '\ClassName', 'desc' => 'is cool too', 'var' => '$baz'), + ), + 'return' => array( + array('type' => 'int', 'desc' => 'At least it isn\'t a string'), + ), + ), + ), + array( + '/** + * This is a docblock! + * + * It spans lines, too! + * + * @tagname plus a description + * + * @return + */', + "This is a docblock!\n\nIt spans lines, too!", + array( + 'tagname' => array('plus a description'), + ), + ), + ); + } +}