Skip to content
Snippets Groups Projects
Unverified Commit 326f814f authored by Alex Pott's avatar Alex Pott
Browse files

Issue #3477329 by phenaproxima, thejimbirch, b_sharpe: Recipe validation...

Issue #3477329 by phenaproxima, thejimbirch, b_sharpe: Recipe validation should always treat required modules as installed

(cherry picked from commit 81f055eb)
parent c2ebccf8
No related branches found
No related tags found
2 merge requests!11185Issue #3477324 by andypost, alexpott: Fix usage of str_getcsv() and fgetcsv() for PHP 8.4,!9944Issue #3483353: Consider making the createCopy config action optionally fail...
Pipeline #304128 passed with warnings
Pipeline: drupal

#304174

    Pipeline: drupal

    #304165

      Pipeline: drupal

      #304152

        +1
        ...@@ -383,14 +383,23 @@ private static function validateConfigActions(mixed $value, ExecutionContextInte ...@@ -383,14 +383,23 @@ private static function validateConfigActions(mixed $value, ExecutionContextInte
        $configurator = new RecipeConfigurator($recipe_being_validated['recipes'] ?? [], $include_path); $configurator = new RecipeConfigurator($recipe_being_validated['recipes'] ?? [], $include_path);
        /** @var \Drupal\Core\Extension\ModuleExtensionList $module_list */
        $module_list = \Drupal::service('extension.list.module');
        // The config provider must either be an already-installed module or theme, // The config provider must either be an already-installed module or theme,
        // or an extension being installed by this recipe or a recipe it depends on. // or an extension being installed by this recipe or a recipe it depends on.
        $all_extensions = [ $all_extensions = [
        ...array_keys(\Drupal::service('extension.list.module')->getAllInstalledInfo()), ...array_keys($module_list->getAllInstalledInfo()),
        ...array_keys(\Drupal::service('extension.list.theme')->getAllInstalledInfo()), ...array_keys(\Drupal::service('extension.list.theme')->getAllInstalledInfo()),
        ...$recipe_being_validated['install'] ?? [], ...$recipe_being_validated['install'] ?? [],
        ...$configurator->listAllExtensions(), ...$configurator->listAllExtensions(),
        ]; ];
        // Explicitly treat required modules as installed, even if Drupal isn't
        // installed yet, because we know they WILL be installed.
        foreach ($module_list->getAllAvailableInfo() as $name => $info) {
        if (!empty($info['required'])) {
        $all_extensions[] = $name;
        }
        }
        if (!in_array($config_provider, $all_extensions, TRUE)) { if (!in_array($config_provider, $all_extensions, TRUE)) {
        $context->addViolation('Config actions cannot be applied to %config_name because the %config_provider extension is not installed, and is not installed by this recipe or any of the recipes it depends on.', [ $context->addViolation('Config actions cannot be applied to %config_name because the %config_provider extension is not installed, and is not installed by this recipe or any of the recipes it depends on.', [
        ......
        ...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
        use Drupal\Core\Recipe\RecipeFileException; use Drupal\Core\Recipe\RecipeFileException;
        use Drupal\Core\Recipe\RecipePreExistingConfigException; use Drupal\Core\Recipe\RecipePreExistingConfigException;
        use Drupal\Core\Recipe\RecipeRunner; use Drupal\Core\Recipe\RecipeRunner;
        use Drupal\FunctionalTests\Core\Recipe\RecipeTestTrait;
        use Drupal\KernelTests\KernelTestBase; use Drupal\KernelTests\KernelTestBase;
        /** /**
        ...@@ -16,6 +17,8 @@ ...@@ -16,6 +17,8 @@
        */ */
        class RecipeTest extends KernelTestBase { class RecipeTest extends KernelTestBase {
        use RecipeTestTrait;
        /** /**
        * {@inheritdoc} * {@inheritdoc}
        */ */
        ...@@ -80,4 +83,19 @@ public function testExampleRecipe(): void { ...@@ -80,4 +83,19 @@ public function testExampleRecipe(): void {
        $this->assertSame($this->config('text.settings')->get('default_summary_length'), 700); $this->assertSame($this->config('text.settings')->get('default_summary_length'), 700);
        } }
        public function testImplicitlyRequiredModule(): void {
        $this->disableModules(['user']);
        $recipe = $this->createRecipe([
        'name' => 'Actions on config from required module',
        'config' => [
        'actions' => [
        'user.role.authenticated' => [
        'grantPermission' => 'access administration pages',
        ],
        ],
        ],
        ]);
        $this->assertIsObject($recipe);
        }
        } }
        0% Loading or .
        You are about to add 0 people to the discussion. Proceed with caution.
        Finish editing this message first!
        Please register or to comment