GenericModuleTestBase.php
Same filename and directory in other branches
Namespace
Drupal\Tests\system\Functional\ModuleFile
-
core/
modules/ system/ tests/ src/ Functional/ Module/ GenericModuleTestBase.php
View source
<?php
declare (strict_types=1);
namespace Drupal\Tests\system\Functional\Module;
use Drupal\Core\Database\Database;
use Drupal\Core\Extension\ModuleExtensionList;
use Drupal\Tests\BrowserTestBase;
/**
* Runs a series of generic tests for one module.
*/
abstract class GenericModuleTestBase extends BrowserTestBase {
/**
* {@inheritdoc}
*/
protected static $modules = [
'help',
];
/**
* {@inheritdoc}
*/
protected $defaultTheme = 'stark';
/**
* Get the module name.
*
* @return string
* The module to test.
*/
protected function getModule() : string {
return explode('\\', get_class($this))[2];
}
/**
* Checks some generic things about a module.
*/
public function testModuleGenericIssues() : void {
$module = $this->getModule();
\Drupal::service('module_installer')->install([
$module,
]);
$info = \Drupal::service('extension.list.module')->getExtensionInfo($module);
if (!empty($info['required']) && !empty($info['hidden'])) {
$this->markTestSkipped('Nothing to assert for hidden, required modules.');
}
$this->drupalLogin($this->createUser([
'access help pages',
]));
$this->assertHookHelp($module);
if (empty($info['required'])) {
$connection = Database::getConnection();
// The module that provides the database driver, or is a dependency of
// the database driver, cannot be uninstalled.
$database_module_extension = \Drupal::service(ModuleExtensionList::class)->get($connection->getProvider());
$database_modules_required = $database_module_extension->requires ? array_keys($database_module_extension->requires) : [];
$database_modules_required[] = $connection->getProvider();
if (!in_array($module, $database_modules_required)) {
// Check that the module can be uninstalled and then re-installed again.
$this->preUnInstallSteps();
$this->assertTrue(\Drupal::service('module_installer')->uninstall([
$module,
]), "Failed to uninstall '{$module}' module");
$this->assertTrue(\Drupal::service('module_installer')->install([
$module,
]), "Failed to install '{$module}' module");
}
}
}
/**
* Verifies hook_help() syntax.
*
* @param string $module
* The module.
*/
protected function assertHookHelp(string $module) : void {
$info = \Drupal::service('extension.list.module')->getExtensionInfo($module);
if (empty($info['hidden'])) {
$this->drupalGet('admin/help/' . $module);
$this->assertSession()
->statusCodeEquals(200);
$this->assertSession()
->pageTextContains($info['name'] . ' module');
$this->assertSession()
->linkExists('online documentation for the ' . $info['name'] . ' module', 0, "Correct online documentation link is in the help page for {$module}");
}
}
/**
* Helper to perform any steps required prior to uninstalling a module.
*/
protected function preUnInstallSteps() : void {
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
GenericModuleTestBase | Runs a series of generic tests for one module. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.