123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- <?php
- /*
- * This file is part of php-token-stream.
- *
- * (c) Sebastian Bergmann <sebastian@phpunit.de>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- use PHPUnit\Framework\TestCase;
- class PHP_Token_ClassTest extends TestCase
- {
- /**
- * @var PHP_Token_CLASS
- */
- private $class;
- /**
- * @var PHP_Token_FUNCTION
- */
- private $function;
- protected function setUp()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'source2.php');
- foreach ($ts as $token) {
- if ($token instanceof PHP_Token_CLASS) {
- $this->class = $token;
- }
- if ($token instanceof PHP_Token_FUNCTION) {
- $this->function = $token;
- break;
- }
- }
- }
- /**
- * @covers PHP_Token_CLASS::getKeywords
- */
- public function testGetClassKeywords()
- {
- $this->assertEquals('abstract', $this->class->getKeywords());
- }
- /**
- * @covers PHP_Token_FUNCTION::getKeywords
- */
- public function testGetFunctionKeywords()
- {
- $this->assertEquals('abstract,static', $this->function->getKeywords());
- }
- /**
- * @covers PHP_Token_FUNCTION::getVisibility
- */
- public function testGetFunctionVisibility()
- {
- $this->assertEquals('public', $this->function->getVisibility());
- }
- public function testIssue19()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'issue19.php');
- foreach ($ts as $token) {
- if ($token instanceof PHP_Token_CLASS) {
- $this->assertFalse($token->hasInterfaces());
- }
- }
- }
- public function testIssue30()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'issue30.php');
- $this->assertCount(1, $ts->getClasses());
- }
- public function testAnonymousClassesAreHandledCorrectly()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'class_with_method_that_declares_anonymous_class.php');
- $classes = $ts->getClasses();
- $this->assertEquals(
- [
- 'class_with_method_that_declares_anonymous_class',
- 'AnonymousClass:9#31',
- 'AnonymousClass:10#55',
- 'AnonymousClass:11#75',
- 'AnonymousClass:12#91',
- 'AnonymousClass:13#107'
- ],
- array_keys($classes)
- );
- }
- /**
- * @ticket https://github.com/sebastianbergmann/php-token-stream/issues/52
- */
- public function testAnonymousClassesAreHandledCorrectly2()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'class_with_method_that_declares_anonymous_class2.php');
- $classes = $ts->getClasses();
- $this->assertEquals(['Test', 'AnonymousClass:4#23'], array_keys($classes));
- $this->assertEquals(['methodOne', 'methodTwo'], array_keys($classes['Test']['methods']));
- $this->assertEmpty($ts->getFunctions());
- }
- public function testImportedFunctionsAreHandledCorrectly()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'classUsesNamespacedFunction.php');
- $this->assertEmpty($ts->getFunctions());
- $this->assertCount(1, $ts->getClasses());
- }
- /**
- * @ticket https://github.com/sebastianbergmann/php-code-coverage/issues/543
- */
- public function testClassWithMultipleAnonymousClassesAndFunctionsIsHandledCorrectly()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'class_with_multiple_anonymous_classes_and_functions.php');
- $classes = $ts->getClasses();
- $this->assertArrayHasKey('class_with_multiple_anonymous_classes_and_functions', $classes);
- $this->assertArrayHasKey('AnonymousClass:6#23', $classes);
- $this->assertArrayHasKey('AnonymousClass:12#53', $classes);
- $this->assertArrayHasKey('m', $classes['class_with_multiple_anonymous_classes_and_functions']['methods']);
- $this->assertArrayHasKey('anonymousFunction:18#81', $classes['class_with_multiple_anonymous_classes_and_functions']['methods']);
- $this->assertArrayHasKey('anonymousFunction:22#108', $classes['class_with_multiple_anonymous_classes_and_functions']['methods']);
- }
- /**
- * @ticket https://github.com/sebastianbergmann/php-token-stream/issues/68
- */
- public function testClassWithMethodNamedEmptyIsHandledCorrectly()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'class_with_method_named_empty.php');
- $classes = $ts->getClasses();
- $this->assertArrayHasKey('class_with_method_named_empty', $classes);
- $this->assertArrayHasKey('empty', $classes['class_with_method_named_empty']['methods']);
- }
- /**
- * @ticket https://github.com/sebastianbergmann/php-code-coverage/issues/424
- */
- public function testAnonymousFunctionDoesNotAffectStartAndEndLineOfMethod()
- {
- $ts = new PHP_Token_Stream(TEST_FILES_PATH . 'php-code-coverage-issue-424.php');
- $classes = $ts->getClasses();
- $this->assertSame(5, $classes['Example']['methods']['even']['startLine']);
- $this->assertSame(12, $classes['Example']['methods']['even']['endLine']);
- $this->assertSame(7, $classes['Example']['methods']['anonymousFunction:7#28']['startLine']);
- $this->assertSame(9, $classes['Example']['methods']['anonymousFunction:7#28']['endLine']);
- }
- }
|