diff vendor/nikic/php-parser/test/PhpParser/JsonDecoderTest.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
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/vendor/nikic/php-parser/test/PhpParser/JsonDecoderTest.php	Mon Apr 23 09:33:26 2018 +0100
@@ -0,0 +1,45 @@
+<?php declare(strict_types=1);
+
+namespace PhpParser;
+
+use PHPUnit\Framework\TestCase;
+
+class JsonDecoderTest extends TestCase
+{
+    public function testRoundTrip() {
+        $code = <<<'PHP'
+<?php
+// comment
+/** doc comment */
+function functionName(&$a = 0, $b = 1.0) {
+    echo 'Foo';
+}
+PHP;
+
+        $parser = new Parser\Php7(new Lexer());
+        $stmts = $parser->parse($code);
+        $json = json_encode($stmts);
+
+        $jsonDecoder = new JsonDecoder();
+        $decodedStmts = $jsonDecoder->decode($json);
+        $this->assertEquals($stmts, $decodedStmts);
+    }
+
+    /** @dataProvider provideTestDecodingError */
+    public function testDecodingError($json, $expectedMessage) {
+        $jsonDecoder = new JsonDecoder();
+        $this->expectException(\RuntimeException::class);
+        $this->expectExceptionMessage($expectedMessage);
+        $jsonDecoder->decode($json);
+    }
+
+    public function provideTestDecodingError() {
+        return [
+            ['???', 'JSON decoding error: Syntax error'],
+            ['{"nodeType":123}', 'Node type must be a string'],
+            ['{"nodeType":"Name","attributes":123}', 'Attributes must be an array'],
+            ['{"nodeType":"Comment"}', 'Comment must have text'],
+            ['{"nodeType":"xxx"}', 'Unknown node type "xxx"'],
+        ];
+    }
+}