GenericModuleTestBase.php

Same filename and directory in other branches
  1. 11.x core/modules/system/tests/src/Functional/Module/GenericModuleTestBase.php

Namespace

Drupal\Tests\system\Functional\Module

File

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\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();
      // When the database driver is provided by a module, then that module
      // cannot be uninstalled.
      if ($module !== $connection->getProvider()) {
        // 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.