Mercurial > hg > isophonics-drupal-site
diff vendor/psy/psysh/test/Util/DocblockTest.php @ 13:5fb285c0d0e3
Update Drupal core to 8.4.7 via Composer. Security update; I *think* we've
been lucky to get away with this so far, as we don't support self-registration
which seems to be used by the so-called "drupalgeddon 2" attack that 8.4.5
was vulnerable to.
author | Chris Cannam |
---|---|
date | Mon, 23 Apr 2018 09:33:26 +0100 |
parents | |
children | 129ea1e6d783 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/psy/psysh/test/Util/DocblockTest.php Mon Apr 23 09:33:26 2018 +0100 @@ -0,0 +1,100 @@ +<?php + +/* + * This file is part of Psy Shell. + * + * (c) 2012-2018 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->assertSame($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 [ + ['', '', []], + [ + '/** + * This is a docblock + * + * @throws \Exception with a description + */', + 'This is a docblock', + [ + 'throws' => [['type' => '\Exception', 'desc' => 'with a description']], + ], + ], + [ + '/** + * 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', + [ + 'param' => [ + ['type' => 'int', 'desc' => 'Is a Foo', 'var' => '$foo'], + ['type' => 'string', 'desc' => 'With some sort of description', 'var' => '$bar'], + ['type' => '\ClassName', 'desc' => 'is cool too', 'var' => '$baz'], + ], + 'return' => [ + ['type' => 'int', 'desc' => 'At least it isn\'t a string'], + ], + ], + ], + [ + '/** + * This is a docblock! + * + * It spans lines, too! + * + * @tagname plus a description + * + * @return + */', + "This is a docblock!\n\nIt spans lines, too!", + [ + 'tagname' => ['plus a description'], + ], + ], + ]; + } +}