diff --git a/src/Automatic/Automatic.php b/src/Automatic/Automatic.php index b432e06c..2451cf46 100644 --- a/src/Automatic/Automatic.php +++ b/src/Automatic/Automatic.php @@ -676,36 +676,42 @@ public function onPostUpdate(Event $event, array $operations = []): void */ public function executeAutoScripts(Event $event): void { - $event->stopPropagation(); - // force reloading scripts as we might have added and removed during this run $json = new JsonFile(Factory::getComposerFile()); $jsonContents = $json->read(); - if (isset($jsonContents['scripts'][ScriptEvents::AUTO_SCRIPTS])) { - /** @var \Narrowspark\Automatic\ScriptExecutor $scriptExecutor */ - $scriptExecutor = $this->container->get(ScriptExecutor::class); + if (! isset($jsonContents['scripts'][ScriptEvents::AUTO_SCRIPTS])) { + $this->container->get(IOInterface::class)->write('No auto-scripts section was found under scripts', true, IOInterface::VERBOSE); - foreach ((array) $this->container->get(Lock::class)->get(ScriptExecutor::TYPE) as $extenders) { - foreach ($extenders as $class => $path) { - if (! \class_exists($class)) { - require_once $path; - } + return; + } - /** @var \Narrowspark\Automatic\Common\Contract\ScriptExtender $class */ - $reflectionClass = new ReflectionClass($class); + if (\in_array(true, \array_map('\is_numeric', \array_keys($jsonContents['scripts'][ScriptEvents::AUTO_SCRIPTS])), true)) { + return; + } - if ($reflectionClass->isInstantiable() && $reflectionClass->hasMethod('getType')) { - $scriptExecutor->add($class::getType(), $class); - } + $event->stopPropagation(); + + /** @var \Narrowspark\Automatic\ScriptExecutor $scriptExecutor */ + $scriptExecutor = $this->container->get(ScriptExecutor::class); + + foreach ((array) $this->container->get(Lock::class)->get(ScriptExecutor::TYPE) as $extenders) { + foreach ($extenders as $class => $path) { + if (! \class_exists($class)) { + require_once $path; } - } - foreach ($jsonContents['scripts'][ScriptEvents::AUTO_SCRIPTS] as $cmd => $type) { - $scriptExecutor->execute($type, $cmd); + /** @var \Narrowspark\Automatic\Common\Contract\ScriptExtender $class */ + $reflectionClass = new ReflectionClass($class); + + if ($reflectionClass->isInstantiable() && $reflectionClass->hasMethod('getType')) { + $scriptExecutor->add($class::getType(), $class); + } } - } else { - $this->container->get(IOInterface::class)->write('No auto-scripts section was found under scripts', true, IOInterface::VERBOSE); + } + + foreach ($jsonContents['scripts'][ScriptEvents::AUTO_SCRIPTS] as $cmd => $type) { + $scriptExecutor->execute($type, $cmd); } } diff --git a/tests/Automatic/AutomaticTest.php b/tests/Automatic/AutomaticTest.php index ab639e84..722b24a8 100644 --- a/tests/Automatic/AutomaticTest.php +++ b/tests/Automatic/AutomaticTest.php @@ -424,11 +424,34 @@ public function testExecuteAutoScripts(): void \putenv('COMPOSER'); } + public function testExecuteAutoScriptsWithNumericArray(): void + { + \putenv('COMPOSER=' . __DIR__ . '/Fixture/composer-with-numeric-scripts.json'); + + $eventMock = $this->mock(Event::class); + $eventMock->shouldReceive('stopPropagation') + ->never(); + + $containerMock = $this->mock(ContainerContract::class); + $containerMock->shouldReceive('get') + ->never() + ->with(ScriptExecutor::class); + $containerMock->shouldReceive('get') + ->never() + ->with(Lock::class); + + $this->automatic->setContainer($containerMock); + $this->automatic->executeAutoScripts($eventMock); + + \putenv('COMPOSER='); + \putenv('COMPOSER'); + } + public function testExecuteAutoScriptsWithoutScripts(): void { $eventMock = $this->mock(Event::class); $eventMock->shouldReceive('stopPropagation') - ->once(); + ->never(); $this->ioMock->shouldReceive('write') ->once() diff --git a/tests/Automatic/Fixture/composer-with-numeric-scripts.json b/tests/Automatic/Fixture/composer-with-numeric-scripts.json new file mode 100644 index 00000000..a53291fc --- /dev/null +++ b/tests/Automatic/Fixture/composer-with-numeric-scripts.json @@ -0,0 +1,21 @@ +{ + "name": "narrowspark/automatic", + "type": "composer-plugin", + "description": "Composer plugin for automatically project configuration and creation.", + "license": "MIT", + "config": { + "optimize-autoloader": true, + "preferred-install": "dist" + }, + "scripts": { + "auto-scripts": [ + "@php -r 'echo 1;'" + ], + "post-install-cmd": [ + "@auto-scripts" + ], + "post-update-cmd": [ + "@auto-scripts" + ] + } +}