From 8008d4519f74703fc7fe4a55ca1df4e9256b0c81 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20FIDRY?= Date: Tue, 6 Feb 2018 23:58:09 +0100 Subject: [PATCH] Properly parse binaries (#147) As now we have access to the content of the file, we can also check if a file is a PHP file based on its content. This ensure binary PHP files are scoped. Also did a small refactoring regarding the order of the scopers registered for a micro-optimisation. --- src/Scoper/PhpScoper.php | 5 +++++ src/functions.php | 16 +++++++++------- tests/Scoper/PhpScoperTest.php | 27 +++++++++++++++++++++++++++ 3 files changed, 41 insertions(+), 7 deletions(-) diff --git a/src/Scoper/PhpScoper.php b/src/Scoper/PhpScoper.php index cab5f9df..66afa1a8 100644 --- a/src/Scoper/PhpScoper.php +++ b/src/Scoper/PhpScoper.php @@ -23,6 +23,7 @@ final class PhpScoper implements Scoper { private const FILE_PATH_PATTERN = '/.*\.php$/'; private const NOT_FILE_BINARY = '/\..+?$/'; + private const PHP_TAG = '/^<\?php/'; private const PHP_BINARY = '/^#!.+?php.*\n{1,}<\?php/'; private $parser; @@ -70,6 +71,10 @@ private function isPhpFile(string $filePath, string $contents): bool return false; } + if (1 === preg_match(self::PHP_TAG, ltrim($contents))) { + return true; + } + return 1 === preg_match(self::PHP_BINARY, $contents); } } diff --git a/src/functions.php b/src/functions.php index ffcc2d4c..a205a85f 100644 --- a/src/functions.php +++ b/src/functions.php @@ -37,6 +37,8 @@ use Symfony\Component\Console\Application as SymfonyApplication; use Symfony\Component\Filesystem\Filesystem; +// TODO: register this file to the list of functions if possible to be autoloaded + /** * @private */ @@ -87,14 +89,14 @@ function get_version(): string function create_scoper(): Scoper { return new PatchScoper( - new JsonFileScoper( - new InstalledPackagesScoper( - new PhpScoper( - create_parser(), - new NullScoper(), - new TraverserFactory() + new PhpScoper( + create_parser(), + new JsonFileScoper( + new InstalledPackagesScoper( + new NullScoper() ) - ) + ), + new TraverserFactory() ) ); } diff --git a/tests/Scoper/PhpScoperTest.php b/tests/Scoper/PhpScoperTest.php index 1fd0f5f1..a983715e 100644 --- a/tests/Scoper/PhpScoperTest.php +++ b/tests/Scoper/PhpScoperTest.php @@ -177,6 +177,33 @@ public function test_does_not_scope_file_if_is_not_a_PHP_file() $this->decoratedScoperProphecy->scope(Argument::cetera())->shouldHaveBeenCalledTimes(1); } + public function test_can_scope_a_PHP_file_with_the_wrong_extension() + { + $prefix = 'Humbug'; + $filePath = escape_path($this->tmp.'/file'); + $patchers = [create_fake_patcher()]; + $whitelist = ['Foo']; + $whitelister = create_fake_whitelister(); + + $contents = <<<'PHP' +scoper->scope($filePath, $contents, $prefix, $patchers, $whitelist, $whitelister); + + $this->assertSame($expected, $actual); + } + public function test_can_scope_PHP_binary_files() { $prefix = 'Humbug';