ModuleConfigureRouteTest.php

Same filename in other branches
  1. 8.9.x core/tests/Drupal/KernelTests/Core/Extension/ModuleConfigureRouteTest.php
  2. 10 core/tests/Drupal/KernelTests/Core/Extension/ModuleConfigureRouteTest.php
  3. 11.x core/tests/Drupal/KernelTests/Core/Extension/ModuleConfigureRouteTest.php

Namespace

Drupal\KernelTests\Core\Extension

File

core/tests/Drupal/KernelTests/Core/Extension/ModuleConfigureRouteTest.php

View source
<?php

namespace Drupal\KernelTests\Core\Extension;

use Drupal\Core\Extension\ExtensionLifecycle;
use Drupal\KernelTests\FileSystemModuleDiscoveryDataProviderTrait;
use Drupal\KernelTests\KernelTestBase;

/**
 * Tests the configure route for core modules.
 *
 * @group #slow
 * @group Module
 */
class ModuleConfigureRouteTest extends KernelTestBase {
    use FileSystemModuleDiscoveryDataProviderTrait;
    
    /**
     * {@inheritdoc}
     */
    protected static $modules = [
        'system',
        'user',
        'path_alias',
    ];
    
    /**
     * @var \Drupal\Core\Routing\RouteProviderInterface
     */
    protected $routeProvider;
    
    /**
     * An array of module info.
     *
     * @var array
     */
    protected $moduleInfo;
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() : void {
        parent::setUp();
        $this->routeProvider = \Drupal::service('router.route_provider');
        $this->moduleInfo = \Drupal::service('extension.list.module')->getList();
    }
    
    /**
     * Tests if the module configure routes exists.
     *
     * @dataProvider coreModuleListDataProvider
     */
    public function testModuleConfigureRoutes(string $module_name) : void {
        $module_info = $this->moduleInfo[$module_name]->info;
        if (!isset($module_info['configure'])) {
            $this->markTestSkipped("{$module_name} has no configure route");
        }
        $module_lifecycle = $module_info[ExtensionLifecycle::LIFECYCLE_IDENTIFIER];
        if (isset($module_lifecycle) && $module_lifecycle === ExtensionLifecycle::DEPRECATED) {
            $this->markTestSkipped("{$module_name} is {$module_lifecycle}");
        }
        $this->container
            ->get('module_installer')
            ->install([
            $module_name,
        ]);
        $this->assertModuleConfigureRoutesExist($module_name, $module_info);
    }
    
    /**
     * Tests if the module with lifecycle deprecated configure routes exists.
     *
     * Note: This test is part of group legacy, to make sure installing the
     * deprecated module doesn't trigger a deprecation notice.
     *
     * @group legacy
     *
     * @dataProvider coreModuleListDataProvider
     */
    public function testDeprecatedModuleConfigureRoutes(string $module_name) : void {
        $module_info = $this->moduleInfo[$module_name]->info;
        if (!isset($module_info['configure'])) {
            $this->markTestSkipped("{$module_name} has no configure route");
        }
        $module_lifecycle = $module_info[ExtensionLifecycle::LIFECYCLE_IDENTIFIER];
        if (isset($module_lifecycle) && $module_lifecycle !== ExtensionLifecycle::DEPRECATED) {
            $this->markTestSkipped("{$module_name} is not {$module_lifecycle}");
        }
        $this->container
            ->get('module_installer')
            ->install([
            $module_name,
        ]);
        $this->assertModuleConfigureRoutesExist($module_name, $module_info);
    }
    
    /**
     * Asserts the configure routes of a module exist.
     *
     * @param string $module_name
     *   The name of the module.
     * @param array $module_info
     *   An array module info.
     *
     * @internal
     */
    protected function assertModuleConfigureRoutesExist(string $module_name, array $module_info) : void {
        $route = $this->routeProvider
            ->getRouteByName($module_info['configure']);
        $this->assertNotEmpty($route, sprintf('The configure route for the "%s" module was found.', $module_name));
    }

}

Classes

Title Deprecated Summary
ModuleConfigureRouteTest Tests the configure route for core modules.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.