You are here

class ThemeTest in Drupal 10

Same name in this branch
  1. 10 core/modules/taxonomy/tests/src/Functional/ThemeTest.php \Drupal\Tests\taxonomy\Functional\ThemeTest
  2. 10 core/modules/system/tests/src/Functional/Theme/ThemeTest.php \Drupal\Tests\system\Functional\Theme\ThemeTest
  3. 10 core/modules/system/tests/src/Kernel/Theme/ThemeTest.php \Drupal\Tests\system\Kernel\Theme\ThemeTest
Same name and namespace in other branches
  1. 8 core/modules/taxonomy/tests/src/Functional/ThemeTest.php \Drupal\Tests\taxonomy\Functional\ThemeTest
  2. 9 core/modules/taxonomy/tests/src/Functional/ThemeTest.php \Drupal\Tests\taxonomy\Functional\ThemeTest

Verifies that various taxonomy pages use the expected theme.

@group taxonomy

Hierarchy

Expanded class hierarchy of ThemeTest

File

core/modules/taxonomy/tests/src/Functional/ThemeTest.php, line 10

Namespace

Drupal\Tests\taxonomy\Functional
View source
class ThemeTest extends TaxonomyTestBase {

  /**
   * {@inheritdoc}
   */
  protected $defaultTheme = 'stark';
  protected function setUp() : void {
    parent::setUp();

    // Make sure we are using distinct default and administrative themes for
    // the duration of these tests.
    \Drupal::service('theme_installer')
      ->install([
      'olivero',
      'claro',
    ]);
    $this
      ->config('system.theme')
      ->set('default', 'olivero')
      ->set('admin', 'claro')
      ->save();

    // Create and log in as a user who has permission to add and edit taxonomy
    // terms and view the administrative theme.
    $admin_user = $this
      ->drupalCreateUser([
      'administer taxonomy',
      'view the administration theme',
    ]);
    $this
      ->drupalLogin($admin_user);
  }

  /**
   * Tests the theme used when adding, viewing and editing taxonomy terms.
   */
  public function testTaxonomyTermThemes() {

    // Adding a term to a vocabulary is considered an administrative action and
    // should use the administrative theme.
    $vocabulary = $this
      ->createVocabulary();
    $this
      ->drupalGet('admin/structure/taxonomy/manage/' . $vocabulary
      ->id() . '/add');

    // Check that the administrative theme's CSS appears on the page for adding
    // a taxonomy term.
    $this
      ->assertSession()
      ->responseContains('claro/css/base/elements.css');

    // Viewing a taxonomy term should use the default theme.
    $term = $this
      ->createTerm($vocabulary);
    $this
      ->drupalGet('taxonomy/term/' . $term
      ->id());

    // Check that the default theme's CSS appears on the page for viewing
    // a taxonomy term.
    $this
      ->assertSession()
      ->responseContains('olivero/css/base/base.css');

    // Editing a taxonomy term should use the same theme as adding one.
    $this
      ->drupalGet('taxonomy/term/' . $term
      ->id() . '/edit');

    // Check that the administrative theme's CSS appears on the page for editing
    // a taxonomy term.
    $this
      ->assertSession()
      ->responseContains('claro/css/base/elements.css');
  }

}

Members