EngineTwigTest.php

Same filename and directory in other branches
  1. 8.9.x core/modules/system/tests/src/Functional/Theme/EngineTwigTest.php
  2. 10 core/modules/system/tests/src/Functional/Theme/EngineTwigTest.php
  3. 11.x core/modules/system/tests/src/Functional/Theme/EngineTwigTest.php

Namespace

Drupal\Tests\system\Functional\Theme

File

core/modules/system/tests/src/Functional/Theme/EngineTwigTest.php

View source
<?php

namespace Drupal\Tests\system\Functional\Theme;

use Drupal\Core\Render\Markup;
use Drupal\Core\Url;
use Drupal\Tests\BrowserTestBase;
use Drupal\Tests\system\Functional\Cache\AssertPageCacheContextsAndTagsTrait;

/**
 * Tests Twig-specific theme functionality.
 *
 * @group Theme
 */
class EngineTwigTest extends BrowserTestBase {
  use AssertPageCacheContextsAndTagsTrait;
  
  /**
   * Modules to enable.
   *
   * @var array
   */
  protected static $modules = [
    'theme_test',
    'twig_theme_test',
  ];
  
  /**
   * {@inheritdoc}
   */
  protected $defaultTheme = 'stark';
  
  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    parent::setUp();
    \Drupal::service('theme_installer')->install([
      'test_theme',
    ]);
  }
  
  /**
   * Tests that the Twig engine handles PHP data correctly.
   */
  public function testTwigVariableDataTypes() {
    $this->config('system.theme')
      ->set('default', 'test_theme')
      ->save();
    $this->drupalGet('twig-theme-test/php-variables');
    foreach (_test_theme_twig_php_values() as $type => $value) {
      $this->assertSession()
        ->responseContains('<li>' . $type . ': ' . $value['expected'] . '</li>');
    }
  }
  
  /**
   * Tests the url and url_generate Twig functions.
   */
  public function testTwigUrlGenerator() {
    $this->drupalGet('twig-theme-test/url-generator');
    // Find the absolute URL of the current site.
    $url_generator = $this->container
      ->get('url_generator');
    $expected = [
      'path (as route) not absolute: ' . $url_generator->generateFromRoute('user.register'),
      'url (as route) absolute: ' . $url_generator->generateFromRoute('user.register', [], [
        'absolute' => TRUE,
      ]),
      'path (as route) not absolute with fragment: ' . $url_generator->generateFromRoute('user.register', [], [
        'fragment' => 'bottom',
      ]),
      'url (as route) absolute despite option: ' . $url_generator->generateFromRoute('user.register', [], [
        'absolute' => TRUE,
      ]),
      'url (as route) absolute with fragment: ' . $url_generator->generateFromRoute('user.register', [], [
        'absolute' => TRUE,
        'fragment' => 'bottom',
      ]),
    ];
    // Verify that url() has the ability to bubble cacheability metadata:
    // absolute URLs should bubble the 'url.site' cache context. (This only
    // needs to test that cacheability metadata is bubbled *at all*; detailed
    // tests for *which* cacheability metadata is bubbled live elsewhere.)
    $this->assertCacheContext('url.site');
    // Make sure we got something.
    $content = $this->getSession()
      ->getPage()
      ->getContent();
    $this->assertNotEmpty($content, 'Page content is not empty');
    foreach ($expected as $string) {
      $this->assertSession()
        ->responseContains('<div>' . $string . '</div>');
    }
  }
  
  /**
   * Tests the link_generator Twig functions.
   */
  public function testTwigLinkGenerator() {
    $this->drupalGet('twig-theme-test/link-generator');
    /** @var \Drupal\Core\Utility\LinkGenerator $link_generator */
    $link_generator = $this->container
      ->get('link_generator');
    $generated_url = Url::fromRoute('user.register', [], [
      'absolute' => TRUE,
    ])->toString(TRUE)
      ->getGeneratedUrl();
    $expected = [
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'absolute' => TRUE,
      ])),
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'absolute' => TRUE,
        'attributes' => [
          'foo' => 'bar',
        ],
      ])),
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'attributes' => [
          'foo' => 'bar',
          'id' => 'kitten',
        ],
      ])),
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'attributes' => [
          'id' => 'kitten',
        ],
      ])),
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'attributes' => [
          'class' => [
            'llama',
            'kitten',
            'panda',
          ],
        ],
      ])),
      'link via the linkgenerator: ' . $link_generator->generate(Markup::create('<span>register</span>'), new Url('user.register', [], [
        'absolute' => TRUE,
      ])),
      'link via the linkgenerator: <a href="' . $generated_url . '"><span>register</span><svg></svg></a>',
      'link via the linkgenerator: ' . $link_generator->generate('register', new Url('user.register', [], [
        'attributes' => [
          'foo' => 'bar',
        ],
      ])) . ' ' . $link_generator->generate('register', new Url('user.register', [], [
        'attributes' => [
          'foo' => 'bar',
        ],
      ])),
    ];
    // Verify that link() has the ability to bubble cacheability metadata:
    // absolute URLs should bubble the 'url.site' cache context. (This only
    // needs to test that cacheability metadata is bubbled *at all*; detailed
    // tests for *which* cacheability metadata is bubbled live elsewhere.)
    $this->assertCacheContext('url.site');
    $content = $this->getSession()
      ->getPage()
      ->getContent();
    $this->assertNotEmpty($content, 'Page content is not empty');
    foreach ($expected as $string) {
      $this->assertSession()
        ->responseContains('<div>' . $string . '</div>');
    }
  }
  
  /**
   * Tests the magic url to string Twig functions.
   *
   * @see \Drupal\Core\Url
   */
  public function testTwigUrlToString() {
    $this->drupalGet('twig-theme-test/url-to-string');
    $expected = [
      'rendered url: ' . Url::fromRoute('user.register')->toString(),
    ];
    $content = $this->getSession()
      ->getPage()
      ->getContent();
    $this->assertNotEmpty($content, 'Page content is not empty');
    foreach ($expected as $string) {
      $this->assertSession()
        ->responseContains('<div>' . $string . '</div>');
    }
  }
  
  /**
   * Tests the automatic/magic calling of toString() on objects, if exists.
   */
  public function testTwigFileUrls() {
    $this->drupalGet('/twig-theme-test/file-url');
    /** @var \Drupal\Core\File\FileUrlGeneratorInterface $file_url_generator */
    $file_url_generator = \Drupal::service('file_url_generator');
    $filepath = $file_url_generator->generateString('core/modules/system/tests/modules/twig_theme_test/twig_theme_test.js');
    $this->assertSession()
      ->responseContains('<div>file_url: ' . $filepath . '</div>');
  }
  
  /**
   * Tests the attach of asset libraries.
   */
  public function testTwigAttachLibrary() {
    $this->drupalGet('/twig-theme-test/attach-library');
    $this->assertSession()
      ->responseContains('ckeditor5-dll.js');
  }
  
  /**
   * Tests the rendering of renderables.
   */
  public function testRenderable() {
    $this->drupalGet('/twig-theme-test/renderable');
    $this->assertSession()
      ->responseContains('<div>Example markup</div>');
  }

}

Classes

Title Deprecated Summary
EngineTwigTest Tests Twig-specific theme functionality.

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