From 829953dba9299bfa25961865c70b50cab6a32cf6 Mon Sep 17 00:00:00 2001 From: Guy Sartorelli Date: Fri, 9 Feb 2024 14:30:52 +1300 Subject: [PATCH] FIX Don't bootstrap when running `behat -h` or `behat --help` --- src/Extension.php | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/src/Extension.php b/src/Extension.php index 7658b2b4..e2283e57 100644 --- a/src/Extension.php +++ b/src/Extension.php @@ -16,6 +16,7 @@ use Behat\Testwork\ServiceContainer\ExtensionManager; use Behat\Testwork\ServiceContainer\Extension as ExtensionInterface; use RuntimeException; +use Symfony\Component\Console\Input\ArgvInput; use Symfony\Component\DependencyInjection\Definition; use Symfony\Component\DependencyInjection\Reference; @@ -42,7 +43,6 @@ class Extension implements ExtensionInterface */ const SILVERSTRIPE_ID = 'silverstripe_extension'; - /** * {@inheritDoc} */ @@ -78,8 +78,10 @@ public function initialize(ExtensionManager $extensionManager) public function load(ContainerBuilder $container, array $config) { // Load yml config - $loader = new YamlFileLoader($container, new FileLocator(__DIR__ . '/../config')); - $loader->load('silverstripe.yml'); + if ($this->getShouldBootstrap($container)) { + $loader = new YamlFileLoader($container, new FileLocator(__DIR__ . '/../config')); + $loader->load('silverstripe.yml'); + } // Add CLI substitutions $this->loadSuiteLocator($container); @@ -105,8 +107,10 @@ public function load(ContainerBuilder $container, array $config) */ public function process(ContainerBuilder $container) { - $corePass = new Compiler\CoreInitializationPass(); - $corePass->process($container); + if ($this->getShouldBootstrap($container)) { + $corePass = new Compiler\CoreInitializationPass(); + $corePass->process($container); + } } public function configure(ArrayNodeDefinition $builder) @@ -203,4 +207,20 @@ protected function loadCallHandlers(ContainerBuilder $container, $errorReporting $definition->addTag(CallExtension::CALL_HANDLER_TAG, ['priority' => 50]); $container->setDefinition(CallExtension::CALL_HANDLER_TAG . '.runtime', $definition); } + + /** + * Check whether the extension should bootstrap or not. + * The extension should always bootstrap unless the `-h` or `--help` option is passed. + */ + private function getShouldBootstrap(ContainerBuilder $container): bool + { + if (!$container->has('cli.input')) { + // If the input isn't there for some bizarre reason, just assume we should bootstrap. + return true; + } + + /** @var ArgvInput $input */ + $input = $container->get('cli.input'); + return !$input->hasParameterOption(['--help', '-h']); + } }