SystemTestHooks.php

Namespace

Drupal\system_test\Hook

File

core/modules/system/tests/modules/system_test/src/Hook/SystemTestHooks.php

View source
<?php

declare (strict_types=1);
namespace Drupal\system_test\Hook;

use Drupal\Core\Extension\Extension;
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\Hook\Attribute\Hook;

/**
 * Hook implementations for system_test.
 */
class SystemTestHooks {
    
    /**
     * Implements hook_help().
     */
    public function help($route_name, RouteMatchInterface $route_match) {
        switch ($route_name) {
            case 'help.page.system_test':
                $output = '';
                $output .= '<h2>' . t('Test Help Page') . '</h2>';
                $output .= '<p>' . t('This is a test help page for the system_test module for the purpose of testing if the "Help" link displays properly.') . '</p>';
                return $output;
        }
    }
    
    /**
     * Implements hook_modules_installed().
     */
    public function modulesInstalled($modules) : void {
        if (\Drupal::state()->get('system_test.verbose_module_hooks')) {
            foreach ($modules as $module) {
                \Drupal::messenger()->addStatus(t('hook_modules_installed fired for @module', [
                    '@module' => $module,
                ]));
            }
        }
    }
    
    /**
     * Implements hook_modules_uninstalled().
     */
    public function modulesUninstalled($modules, $is_syncing) : void {
        if (\Drupal::state()->get('system_test.verbose_module_hooks')) {
            foreach ($modules as $module) {
                \Drupal::messenger()->addStatus(t('hook_modules_uninstalled fired for @module', [
                    '@module' => $module,
                ]));
            }
        }
        // Save the config.installer isSyncing() value to state to check that it is
        // correctly set when installing module during config import.
        \Drupal::state()->set('system_test_modules_uninstalled_config_installer_syncing', \Drupal::service('config.installer')->isSyncing());
        // Save the $is_syncing parameter value to state to check that it is correctly
        // set when installing module during config import.
        \Drupal::state()->set('system_test_modules_uninstalled_syncing_param', $is_syncing);
    }
    
    /**
     * Implements hook_system_info_alter().
     */
    public function systemInfoAlter(&$info, Extension $file, $type) : void {
        // We need a static otherwise the last test will fail to alter common_test.
        static $test;
        if (($dependencies = \Drupal::state()->get('system_test.dependencies')) || $test) {
            if ($file->getName() == 'module_test') {
                $info['hidden'] = FALSE;
                $info['dependencies'][] = array_shift($dependencies);
                \Drupal::state()->set('system_test.dependencies', $dependencies);
                $test = TRUE;
            }
            if ($file->getName() == 'common_test') {
                $info['hidden'] = FALSE;
                $info['version'] = '8.x-2.4-beta3';
            }
        }
        // Make the system_dependencies_test visible by default.
        if ($file->getName() == 'system_dependencies_test') {
            $info['hidden'] = FALSE;
        }
        if (in_array($file->getName(), [
            'system_incompatible_module_version_dependencies_test',
            'system_incompatible_core_version_dependencies_test',
            'system_incompatible_module_version_test',
        ])) {
            $info['hidden'] = FALSE;
        }
        if ($file->getName() == 'requirements1_test' || $file->getName() == 'requirements2_test') {
            $info['hidden'] = FALSE;
        }
        if ($file->getName() == 'system_test') {
            $info['hidden'] = \Drupal::state()->get('system_test.module_hidden', TRUE);
        }
    }
    
    /**
     * Implements hook_page_attachments().
     */
    public function pageAttachments(array &$page) : void {
        // Used by FrontPageTestCase to get the results of
        // \Drupal::service('path.matcher')->isFrontPage().
        $frontpage = \Drupal::state()->get('system_test.front_page_output', 0);
        if ($frontpage && \Drupal::service('path.matcher')->isFrontPage()) {
            \Drupal::messenger()->addStatus(t('On front page.'));
        }
    }
    
    /**
     * Implements hook_filetransfer_info().
     */
    public function filetransferInfo() {
        return [
            'system_test' => [
                'title' => t('System Test FileTransfer'),
                'class' => 'Drupal\\system_test\\MockFileTransfer',
                'weight' => -10,
            ],
        ];
    }
    
    /**
     * Implements hook_module_preinstall().
     */
    public function modulePreinstall($module, bool $is_syncing) : void {
        \Drupal::messenger()->addStatus('system_test_preinstall_module called');
        \Drupal::state()->set('system_test_preinstall_module', $module);
        // Save the config.installer isSyncing() value to state to check that it is
        // correctly set when installing module during config import.
        \Drupal::state()->set('system_test_preinstall_module_config_installer_syncing', \Drupal::service('config.installer')->isSyncing());
        // Save the $is_syncing parameter value to state to check that it is correctly
        // set when installing module during config import.
        \Drupal::state()->set('system_test_preinstall_module_syncing_param', $is_syncing);
    }
    
    /**
     * Implements hook_module_preuninstall().
     */
    public function modulePreuninstall($module, bool $is_syncing) : void {
        \Drupal::state()->set('system_test_preuninstall_module', $module);
        // Save the config.installer isSyncing() value to state to check that it is
        // correctly set when uninstalling module during config import.
        \Drupal::state()->set('system_test_preuninstall_module_config_installer_syncing', \Drupal::service('config.installer')->isSyncing());
        // Save the $is_syncing parameter value to state to check that it is correctly
        // set when installing module during config import.
        \Drupal::state()->set('system_test_preuninstall_module_syncing_param', $is_syncing);
    }

}

Classes

Title Deprecated Summary
SystemTestHooks Hook implementations for system_test.

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