First commit
This commit is contained in:
		
						commit
						c6e2478c40
					
				
					 13918 changed files with 2303184 additions and 0 deletions
				
			
		
							
								
								
									
										100
									
								
								vendor/psy/psysh/test/Psy/Test/Util/DocblockTest.php
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								vendor/psy/psysh/test/Psy/Test/Util/DocblockTest.php
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -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'), | ||||
|                 ), | ||||
|             ), | ||||
|         ); | ||||
|     } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue