HelpTopicTranslatedTestBase.php

Same filename in other branches
  1. 9 core/modules/help_topics/tests/src/Functional/HelpTopicTranslatedTestBase.php
  2. 8.9.x core/modules/help_topics/tests/src/Functional/HelpTopicTranslatedTestBase.php
  3. 11.x core/modules/help/tests/src/Functional/HelpTopicTranslatedTestBase.php

Namespace

Drupal\Tests\help\Functional

File

core/modules/help/tests/src/Functional/HelpTopicTranslatedTestBase.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\help\Functional;

use Drupal\Tests\BrowserTestBase;
// cspell:ignore hilfetestmodul übersetzung

/**
 * Provides a base class for functional help topic tests that use translation.
 *
 * Installs in German, with a small PO file, and sets up the task, help, and
 * page title blocks.
 */
abstract class HelpTopicTranslatedTestBase extends BrowserTestBase {
    
    /**
     * {@inheritdoc}
     */
    protected static $modules = [
        'help_topics_test',
        'help',
        'block',
    ];
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() : void {
        parent::setUp();
        // These tests rely on some markup from the 'Claro' theme, as well as an
        // optional block added when Claro is enabled.
        \Drupal::service('theme_installer')->install([
            'claro',
        ]);
        \Drupal::configFactory()->getEditable('system.theme')
            ->set('admin', 'claro')
            ->save(TRUE);
        // Place various blocks.
        $settings = [
            'theme' => 'claro',
            'region' => 'help',
        ];
        $this->placeBlock('help_block', $settings);
        $this->placeBlock('local_tasks_block', $settings);
        $this->placeBlock('local_actions_block', $settings);
        $this->placeBlock('page_title_block', $settings);
        // Create user.
        $this->drupalLogin($this->createUser([
            'access help pages',
            'view the administration theme',
            'administer permissions',
        ]));
    }
    
    /**
     * {@inheritdoc}
     */
    protected function installParameters() {
        $parameters = parent::installParameters();
        // Install in German. This will ensure the language and locale modules are
        // installed.
        $parameters['parameters']['langcode'] = 'de';
        // Create a po file so we don't attempt to download one from
        // localize.drupal.org and to have a test translation that will not change.
        \Drupal::service('file_system')->mkdir($this->publicFilesDirectory . '/translations', NULL, TRUE);
        $contents = <<<PO
msgid ""
msgstr ""

msgid "ABC Help Test module"
msgstr "ABC-Hilfetestmodul"

msgid "Test translation."
msgstr "Übersetzung testen."

msgid "Non-word-item to translate."
msgstr "Non-word-german sdfwedrsdf."

PO;
        $version = explode('.', \Drupal::VERSION)[0] . '.0.0';
        file_put_contents($this->publicFilesDirectory . "/translations/drupal-{$version}.de.po", $contents);
        return $parameters;
    }

}

Classes

Title Deprecated Summary
HelpTopicTranslatedTestBase Provides a base class for functional help topic tests that use translation.

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