annotate vendor/nikic/php-parser/test/PhpParser/ConstExprEvaluatorTest.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 PhpParser\Node\Scalar;
Chris@13 7 use PHPUnit\Framework\TestCase;
Chris@13 8
Chris@13 9 class ConstExprEvaluatorTest extends TestCase
Chris@13 10 {
Chris@13 11 /** @dataProvider provideTestEvaluate */
Chris@13 12 public function testEvaluate($exprString, $expected) {
Chris@13 13 $parser = new Parser\Php7(new Lexer());
Chris@13 14 $expr = $parser->parse('<?php ' . $exprString . ';')[0]->expr;
Chris@13 15 $evaluator = new ConstExprEvaluator();
Chris@13 16 $this->assertSame($expected, $evaluator->evaluateDirectly($expr));
Chris@13 17 }
Chris@13 18
Chris@13 19 public function provideTestEvaluate() {
Chris@13 20 return [
Chris@13 21 ['1', 1],
Chris@13 22 ['1.0', 1.0],
Chris@13 23 ['"foo"', "foo"],
Chris@13 24 ['[0, 1]', [0, 1]],
Chris@13 25 ['["foo" => "bar"]', ["foo" => "bar"]],
Chris@13 26 ['NULL', null],
Chris@13 27 ['False', false],
Chris@13 28 ['true', true],
Chris@13 29 ['+1', 1],
Chris@13 30 ['-1', -1],
Chris@13 31 ['~0', -1],
Chris@13 32 ['!true', false],
Chris@13 33 ['[0][0]', 0],
Chris@13 34 ['"a"[0]', "a"],
Chris@13 35 ['true ? 1 : (1/0)', 1],
Chris@13 36 ['false ? (1/0) : 1', 1],
Chris@13 37 ['42 ?: (1/0)', 42],
Chris@13 38 ['false ?: 42', 42],
Chris@13 39 ['false ?? 42', false],
Chris@13 40 ['null ?? 42', 42],
Chris@13 41 ['[0][0] ?? 42', 0],
Chris@13 42 ['[][0] ?? 42', 42],
Chris@13 43 ['0b11 & 0b10', 0b10],
Chris@13 44 ['0b11 | 0b10', 0b11],
Chris@13 45 ['0b11 ^ 0b10', 0b01],
Chris@13 46 ['1 << 2', 4],
Chris@13 47 ['4 >> 2', 1],
Chris@13 48 ['"a" . "b"', "ab"],
Chris@13 49 ['4 + 2', 6],
Chris@13 50 ['4 - 2', 2],
Chris@13 51 ['4 * 2', 8],
Chris@13 52 ['4 / 2', 2],
Chris@13 53 ['4 % 2', 0],
Chris@13 54 ['4 ** 2', 16],
Chris@13 55 ['1 == 1.0', true],
Chris@13 56 ['1 != 1.0', false],
Chris@13 57 ['1 < 2.0', true],
Chris@13 58 ['1 <= 2.0', true],
Chris@13 59 ['1 > 2.0', false],
Chris@13 60 ['1 >= 2.0', false],
Chris@13 61 ['1 <=> 2.0', -1],
Chris@13 62 ['1 === 1.0', false],
Chris@13 63 ['1 !== 1.0', true],
Chris@13 64 ['true && true', true],
Chris@13 65 ['true and true', true],
Chris@13 66 ['false && (1/0)', false],
Chris@13 67 ['false and (1/0)', false],
Chris@13 68 ['false || false', false],
Chris@13 69 ['false or false', false],
Chris@13 70 ['true || (1/0)', true],
Chris@13 71 ['true or (1/0)', true],
Chris@13 72 ['true xor false', true],
Chris@13 73 ];
Chris@13 74 }
Chris@13 75
Chris@13 76 /**
Chris@13 77 * @expectedException \PhpParser\ConstExprEvaluationException
Chris@13 78 * @expectedExceptionMessage Expression of type Expr_Variable cannot be evaluated
Chris@13 79 */
Chris@13 80 public function testEvaluateFails() {
Chris@13 81 $evaluator = new ConstExprEvaluator();
Chris@13 82 $evaluator->evaluateDirectly(new Expr\Variable('a'));
Chris@13 83 }
Chris@13 84
Chris@13 85 public function testEvaluateFallback() {
Chris@13 86 $evaluator = new ConstExprEvaluator(function(Expr $expr) {
Chris@13 87 if ($expr instanceof Scalar\MagicConst\Line) {
Chris@13 88 return 42;
Chris@13 89 }
Chris@13 90 throw new ConstExprEvaluationException();
Chris@13 91 });
Chris@13 92 $expr = new Expr\BinaryOp\Plus(
Chris@13 93 new Scalar\LNumber(8),
Chris@13 94 new Scalar\MagicConst\Line()
Chris@13 95 );
Chris@13 96 $this->assertSame(50, $evaluator->evaluateDirectly($expr));
Chris@13 97 }
Chris@13 98
Chris@13 99 /**
Chris@13 100 * @dataProvider provideTestEvaluateSilently
Chris@13 101 */
Chris@13 102 public function testEvaluateSilently($expr, $exception, $msg) {
Chris@13 103 $evaluator = new ConstExprEvaluator();
Chris@13 104
Chris@13 105 try {
Chris@13 106 $evaluator->evaluateSilently($expr);
Chris@13 107 } catch (ConstExprEvaluationException $e) {
Chris@13 108 $this->assertSame(
Chris@13 109 'An error occurred during constant expression evaluation',
Chris@13 110 $e->getMessage()
Chris@13 111 );
Chris@13 112
Chris@13 113 $prev = $e->getPrevious();
Chris@13 114 $this->assertInstanceOf($exception, $prev);
Chris@13 115 $this->assertSame($msg, $prev->getMessage());
Chris@13 116 }
Chris@13 117 }
Chris@13 118
Chris@13 119 public function provideTestEvaluateSilently() {
Chris@13 120 return [
Chris@13 121 [
Chris@13 122 new Expr\BinaryOp\Mod(new Scalar\LNumber(42), new Scalar\LNumber(0)),
Chris@13 123 \Error::class,
Chris@13 124 'Modulo by zero'
Chris@13 125 ],
Chris@13 126 [
Chris@13 127 new Expr\BinaryOp\Div(new Scalar\LNumber(42), new Scalar\LNumber(0)),
Chris@13 128 \ErrorException::class,
Chris@13 129 'Division by zero'
Chris@13 130 ],
Chris@13 131 ];
Chris@13 132 }
Chris@13 133 }