annotate vendor/nikic/php-parser/test/PhpParser/NodeFinderTest.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
rev   line source
Chris@13 1 <?php declare(strict_types=1);
Chris@13 2
Chris@13 3 namespace PhpParser;
Chris@13 4
Chris@13 5 use PhpParser\Node\Expr;
Chris@13 6 use PHPUnit\Framework\TestCase;
Chris@13 7
Chris@13 8 class NodeFinderTest extends TestCase
Chris@13 9 {
Chris@13 10 private function getStmtsAndVars() {
Chris@13 11 $assign = new Expr\Assign(new Expr\Variable('a'), new Expr\BinaryOp\Concat(
Chris@13 12 new Expr\Variable('b'), new Expr\Variable('c')
Chris@13 13 ));
Chris@13 14 $stmts = [new Node\Stmt\Expression($assign)];
Chris@13 15 $vars = [$assign->var, $assign->expr->left, $assign->expr->right];
Chris@13 16 return [$stmts, $vars];
Chris@13 17 }
Chris@13 18
Chris@13 19 public function testFind() {
Chris@13 20 $finder = new NodeFinder;
Chris@13 21 list($stmts, $vars) = $this->getStmtsAndVars();
Chris@13 22 $varFilter = function(Node $node) {
Chris@13 23 return $node instanceof Expr\Variable;
Chris@13 24 };
Chris@13 25 $this->assertSame($vars, $finder->find($stmts, $varFilter));
Chris@13 26 $this->assertSame($vars, $finder->find($stmts[0], $varFilter));
Chris@13 27
Chris@13 28 $noneFilter = function () { return false; };
Chris@13 29 $this->assertSame([], $finder->find($stmts, $noneFilter));
Chris@13 30 }
Chris@13 31
Chris@13 32 public function testFindInstanceOf() {
Chris@13 33 $finder = new NodeFinder;
Chris@13 34 list($stmts, $vars) = $this->getStmtsAndVars();
Chris@13 35 $this->assertSame($vars, $finder->findInstanceOf($stmts, Expr\Variable::class));
Chris@13 36 $this->assertSame($vars, $finder->findInstanceOf($stmts[0], Expr\Variable::class));
Chris@13 37 $this->assertSame([], $finder->findInstanceOf($stmts, Expr\BinaryOp\Mul::class));
Chris@13 38 }
Chris@13 39
Chris@13 40 public function testFindFirst() {
Chris@13 41 $finder = new NodeFinder;
Chris@13 42 list($stmts, $vars) = $this->getStmtsAndVars();
Chris@13 43 $varFilter = function(Node $node) {
Chris@13 44 return $node instanceof Expr\Variable;
Chris@13 45 };
Chris@13 46 $this->assertSame($vars[0], $finder->findFirst($stmts, $varFilter));
Chris@13 47 $this->assertSame($vars[0], $finder->findFirst($stmts[0], $varFilter));
Chris@13 48
Chris@13 49 $noneFilter = function () { return false; };
Chris@13 50 $this->assertNull($finder->findFirst($stmts, $noneFilter));
Chris@13 51 }
Chris@13 52
Chris@13 53 public function testFindFirstInstanceOf() {
Chris@13 54 $finder = new NodeFinder;
Chris@13 55 list($stmts, $vars) = $this->getStmtsAndVars();
Chris@13 56 $this->assertSame($vars[0], $finder->findFirstInstanceOf($stmts, Expr\Variable::class));
Chris@13 57 $this->assertSame($vars[0], $finder->findFirstInstanceOf($stmts[0], Expr\Variable::class));
Chris@13 58 $this->assertNull($finder->findFirstInstanceOf($stmts, Expr\BinaryOp\Mul::class));
Chris@13 59 }
Chris@13 60 }