Mercurial > hg > isophonics-drupal-site
diff vendor/psy/psysh/test/CodeCleaner/CalledClassPassTest.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 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/psy/psysh/test/CodeCleaner/CalledClassPassTest.php Mon Apr 23 09:33:26 2018 +0100 @@ -0,0 +1,90 @@ +<?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\CodeCleaner; + +use Psy\CodeCleaner\CalledClassPass; + +class CalledClassPassTest extends CodeCleanerTestCase +{ + public function setUp() + { + $this->setPass(new CalledClassPass()); + } + + /** + * @dataProvider invalidStatements + * @expectedException \Psy\Exception\ErrorException + */ + public function testProcessStatementFails($code) + { + $this->parseAndTraverse($code); + } + + public function invalidStatements() + { + return [ + ['get_class()'], + ['get_class(null)'], + ['get_called_class()'], + ['get_called_class(null)'], + ['function foo() { return get_class(); }'], + ['function foo() { return get_class(null); }'], + ['function foo() { return get_called_class(); }'], + ['function foo() { return get_called_class(null); }'], + ]; + } + + /** + * @dataProvider validStatements + */ + public function testProcessStatementPasses($code) + { + $this->parseAndTraverse($code); + $this->assertTrue(true); + } + + public function validStatements() + { + return [ + ['get_class($foo)'], + ['get_class(bar())'], + ['get_called_class($foo)'], + ['get_called_class(bar())'], + ['function foo($bar) { return get_class($bar); }'], + ['function foo($bar) { return get_called_class($bar); }'], + ['class Foo { function bar() { return get_class(); } }'], + ['class Foo { function bar() { return get_class(null); } }'], + ['class Foo { function bar() { return get_called_class(); } }'], + ['class Foo { function bar() { return get_called_class(null); } }'], + ['$foo = function () {}; $foo()'], + ]; + } + + /** + * @dataProvider validTraitStatements + */ + public function testProcessTraitStatementPasses($code) + { + $this->parseAndTraverse($code); + $this->assertTrue(true); + } + + public function validTraitStatements() + { + return [ + ['trait Foo { function bar() { return get_class(); } }'], + ['trait Foo { function bar() { return get_class(null); } }'], + ['trait Foo { function bar() { return get_called_class(); } }'], + ['trait Foo { function bar() { return get_called_class(null); } }'], + ]; + } +}