module_test.module

Same filename in other branches
  1. 7.x modules/simpletest/tests/module_test.module
  2. 9 core/modules/system/tests/modules/module_test/module_test.module
  3. 8.9.x core/modules/system/tests/modules/module_test/module_test.module
  4. 10 core/modules/system/tests/modules/module_test/module_test.module

File

core/modules/system/tests/modules/module_test/module_test.module

View source
<?php


/**
 * @file
 * Test module.
 */
declare (strict_types=1);
use Drupal\Core\Extension\Extension;

/**
 * Implements hook_system_info_alter().
 *
 * Manipulate module dependencies to test dependency chains.
 */
function module_test_system_info_alter(&$info, Extension $file, $type) {
    if (\Drupal::state()->get('module_test.dependency') == 'missing dependency') {
        if ($file->getName() == 'dblog') {
            // Make dblog module depend on config.
            $info['dependencies'][] = 'config';
        }
        elseif ($file->getName() == 'config') {
            // Make config module depend on a non-existing module.
            $info['dependencies'][] = 'foo';
        }
    }
    elseif (\Drupal::state()->get('module_test.dependency') == 'dependency') {
        if ($file->getName() == 'dblog') {
            // Make dblog module depend on config.
            $info['dependencies'][] = 'config';
        }
        elseif ($file->getName() == 'config') {
            // Make config module depend on help module.
            $info['dependencies'][] = 'help';
        }
        elseif ($file->getName() == 'entity_test') {
            // Make entity test module depend on help module.
            $info['dependencies'][] = 'help';
        }
    }
    elseif (\Drupal::state()->get('module_test.dependency') == 'version dependency') {
        if ($file->getName() == 'dblog') {
            // Make dblog module depend on config.
            $info['dependencies'][] = 'config';
        }
        elseif ($file->getName() == 'config') {
            // Make config module depend on a specific version of help module.
            $info['dependencies'][] = 'help (1.x)';
        }
        elseif ($file->getName() == 'help') {
            // Set help module to a version compatible with the above.
            $info['version'] = '8.x-1.0';
        }
    }
    if ($file->getName() == 'stark' && $type == 'theme') {
        $info['regions']['test_region'] = 'Test region';
    }
}

/**
 * Implements hook_hook_info().
 */
function module_test_hook_info() {
    $hooks['test_hook'] = [
        'group' => 'file',
    ];
    return $hooks;
}

/**
 * Load function used by module_test_hook_dynamic_loading_invoke_all_during_load().
 *
 * @see module_test_menu()
 */
function module_test_load($param) {
    $result = \Drupal::moduleHandler()->invokeAll('test_hook');
    return $result[$param];
}

/**
 * Implements hook_modules_installed().
 */
function module_test_modules_installed($modules) {
    // Record the ordered list of modules that were passed in to this hook so we
    // can check that the modules were enabled in the correct sequence.
    \Drupal::state()->set('module_test.install_order', $modules);
}

/**
 * Implements hook_modules_uninstalled().
 */
function module_test_modules_uninstalled($modules) {
    // Record the ordered list of modules that were passed in to this hook so we
    // can check that the modules were uninstalled in the correct sequence.
    \Drupal::state()->set('module_test.uninstall_order', $modules);
}

/**
 * Implements hook_module_implements_alter().
 *
 * @see module_test_altered_test_hook()
 * @see \Drupal\system\Tests\Module\ModuleImplementsAlterTest::testModuleImplementsAlter()
 */
function module_test_module_implements_alter(&$implementations, $hook) {
    if ($hook === 'altered_test_hook') {
        // Add a hook implementation, that will be found in
        // module_test.implementation.inc.
        $implementations['module_test'] = 'implementations';
    }
    if ($hook === 'unimplemented_test_hook') {
        // Add the non-existing function module_test_unimplemented_test_hook(). This
        // should cause an exception to be thrown in
        // \Drupal\Core\Extension\ModuleHandler::buildImplementationInfo('unimplemented_test_hook').
        $implementations['module_test'] = FALSE;
    }
}

Functions

Title Deprecated Summary
module_test_hook_info Implements hook_hook_info().
module_test_load Load function used by module_test_hook_dynamic_loading_invoke_all_during_load().
module_test_modules_installed Implements hook_modules_installed().
module_test_modules_uninstalled Implements hook_modules_uninstalled().
module_test_module_implements_alter Implements hook_module_implements_alter().
module_test_system_info_alter Implements hook_system_info_alter().

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