123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334 |
- <?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\CodeCleaner;
- use Psy\CodeCleaner\ValidClassNamePass;
- use Psy\Exception\Exception;
- class ValidClassNamePassTest extends CodeCleanerTestCase
- {
- public function setUp()
- {
- $this->setPass(new ValidClassNamePass());
- }
- /**
- * @dataProvider getInvalid
- */
- public function testProcessInvalid($code, $php54 = false)
- {
- try {
- $stmts = $this->parse($code);
- $this->traverse($stmts);
- $this->fail();
- } catch (Exception $e) {
- if ($php54 && version_compare(PHP_VERSION, '5.4', '<')) {
- $this->assertInstanceOf('Psy\Exception\ParseErrorException', $e);
- } else {
- $this->assertInstanceOf('Psy\Exception\FatalErrorException', $e);
- }
- }
- }
- public function getInvalid()
- {
- // class declarations
- return array(
- // core class
- array('class stdClass {}'),
- // capitalization
- array('class stdClass {}'),
- // collisions with interfaces and traits
- array('interface stdClass {}'),
- array('trait stdClass {}', true),
- // collisions inside the same code snippet
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- trait Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- ', true),
- array('
- trait Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- ', true),
- array('
- trait Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- interface Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- ', true),
- array('
- interface Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- trait Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- ', true),
- array('
- interface Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- interface Psy_Test_CodeCleaner_ValidClassNamePass_Alpha {}
- '),
- // namespaced collisions
- array('
- namespace Psy\\Test\\CodeCleaner {
- class ValidClassNamePassTest {}
- }
- '),
- array('
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Beta {}
- }
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Beta {}
- }
- '),
- // extends and implements
- array('class ValidClassNamePassTest extends NotAClass {}'),
- array('class ValidClassNamePassTest extends ArrayAccess {}'),
- array('class ValidClassNamePassTest implements stdClass {}'),
- array('class ValidClassNamePassTest implements ArrayAccess, stdClass {}'),
- array('interface ValidClassNamePassTest extends stdClass {}'),
- array('interface ValidClassNamePassTest extends ArrayAccess, stdClass {}'),
- // class instantiations
- array('new Psy_Test_CodeCleaner_ValidClassNamePass_Gamma();'),
- array('
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- new Psy_Test_CodeCleaner_ValidClassNamePass_Delta();
- }
- '),
- // class constant fetch
- array('Psy\\Test\\CodeCleaner\\ValidClassNamePass\\NotAClass::FOO'),
- // static call
- array('Psy\\Test\\CodeCleaner\\ValidClassNamePass\\NotAClass::foo()'),
- array('Psy\\Test\\CodeCleaner\\ValidClassNamePass\\NotAClass::$foo()'),
- );
- }
- /**
- * @dataProvider getValid
- */
- public function testProcessValid($code)
- {
- $stmts = $this->parse($code);
- $this->traverse($stmts);
- }
- public function getValid()
- {
- $valid = array(
- // class declarations
- array('class Psy_Test_CodeCleaner_ValidClassNamePass_Epsilon {}'),
- array('namespace Psy\Test\CodeCleaner\ValidClassNamePass; class Zeta {}'),
- array('
- namespace { class Psy_Test_CodeCleaner_ValidClassNamePass_Eta {}; }
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Psy_Test_CodeCleaner_ValidClassNamePass_Eta {}
- }
- '),
- array('namespace Psy\Test\CodeCleaner\ValidClassNamePass { class stdClass {} }'),
- // class instantiations
- array('new stdClass();'),
- array('new stdClass();'),
- array('
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Theta {}
- }
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- new Theta();
- }
- '),
- array('
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Iota {}
- new Iota();
- }
- '),
- array('
- namespace Psy\\Test\\CodeCleaner\\ValidClassNamePass {
- class Kappa {}
- }
- namespace {
- new \\Psy\\Test\\CodeCleaner\\ValidClassNamePass\\Kappa();
- }
- '),
- // Class constant fetch (ValidConstantPassTest validates the actual constant)
- array('class A {} A::FOO'),
- array('$a = new DateTime; $a::ATOM'),
- array('interface A { const B = 1; } A::B'),
- // static call
- array('DateTime::createFromFormat()'),
- array('DateTime::$someMethod()'),
- array('Psy\Test\CodeCleaner\Fixtures\ClassWithStatic::doStuff()'),
- array('Psy\Test\CodeCleaner\Fixtures\ClassWithCallStatic::doStuff()'),
- // Allow `self` and `static` as class names.
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new self();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new SELF();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new self;
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new static();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new Static();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function getInstance() {
- return new static;
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function foo() {
- return parent::bar();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function foo() {
- return self::bar();
- }
- }
- '),
- array('
- class Psy_Test_CodeCleaner_ValidClassNamePass_ClassWithStatic {
- public static function foo() {
- return static::bar();
- }
- }
- '),
- array('class A { static function b() { return new A; } }'),
- array('
- class A {
- const B = 123;
- function c() {
- return A::B;
- }
- }
- '),
- array('class A {} class B { function c() { return new A; } }'),
- // recursion
- array('class A { function a() { A::a(); } }'),
- // conditionally defined classes
- array('
- class A {}
- if (false) {
- class A {}
- }
- '),
- array('
- class A {}
- if (true) {
- class A {}
- } else if (false) {
- class A {}
- } else {
- class A {}
- }
- '),
- // ewww
- array('
- class A {}
- if (true):
- class A {}
- elseif (false):
- class A {}
- else:
- class A {}
- endif;
- '),
- array('
- class A {}
- while (false) { class A {} }
- '),
- array('
- class A {}
- do { class A {} } while (false);
- '),
- array('
- class A {}
- switch (1) {
- case 0:
- class A {}
- break;
- case 1:
- class A {}
- break;
- case 2:
- class A {}
- break;
- }
- '),
- );
- // Ugh. There's gotta be a better way to test for this.
- if (class_exists('PhpParser\ParserFactory')) {
- // PHP 7.0 anonymous classes, only supported by PHP Parser v2.x
- $valid[] = array('$obj = new class() {}');
- }
- if (version_compare(PHP_VERSION, '5.5', '>=')) {
- $valid[] = array('interface A {} A::class');
- $valid[] = array('interface A {} A::CLASS');
- $valid[] = array('class A {} A::class');
- $valid[] = array('class A {} A::CLASS');
- $valid[] = array('A::class');
- $valid[] = array('A::CLASS');
- }
- return $valid;
- }
- }
|