You are here

public function TwigEnvironmentTest::testInlineTemplate in Drupal 9

Same name and namespace in other branches
  1. 8 core/tests/Drupal/KernelTests/Core/Theme/TwigEnvironmentTest.php \Drupal\KernelTests\Core\Theme\TwigEnvironmentTest::testInlineTemplate()

Tests inline templates.

File

core/tests/Drupal/KernelTests/Core/Theme/TwigEnvironmentTest.php, line 33

Class

TwigEnvironmentTest
Tests the twig environment.

Namespace

Drupal\KernelTests\Core\Theme

Code

public function testInlineTemplate() {

  /** @var \Drupal\Core\Render\RendererInterface $renderer */
  $renderer = $this->container
    ->get('renderer');

  /** @var \Drupal\Core\Template\TwigEnvironment $environment */
  $environment = \Drupal::service('twig');
  $this
    ->assertEquals('test-no-context', $environment
    ->renderInline('test-no-context'));
  $this
    ->assertEquals('test-with-context muuh', $environment
    ->renderInline('test-with-context {{ llama }}', [
    'llama' => 'muuh',
  ]));
  $element = [];
  $unsafe_string = '<script>alert(\'Danger! High voltage!\');</script>';
  $element['test'] = [
    '#type' => 'inline_template',
    '#template' => 'test-with-context <label>{{ unsafe_content }}</label>',
    '#context' => [
      'unsafe_content' => $unsafe_string,
    ],
  ];
  $this
    ->assertEquals('test-with-context <label>' . Html::escape($unsafe_string) . '</label>', $renderer
    ->renderRoot($element));

  // Enable twig_auto_reload and twig_debug.
  $settings = Settings::getAll();
  $settings['twig_debug'] = TRUE;
  $settings['twig_auto_reload'] = TRUE;
  new Settings($settings);
  $this->container = \Drupal::service('kernel')
    ->rebuildContainer();
  \Drupal::setContainer($this->container);
  $element = [];
  $element['test'] = [
    '#type' => 'inline_template',
    '#template' => 'test-with-context {{ llama }}',
    '#context' => [
      'llama' => 'muuh',
    ],
  ];
  $element_copy = $element;

  // Render it twice so that twig caching is triggered.
  $this
    ->assertEquals('test-with-context muuh', $renderer
    ->renderRoot($element));
  $this
    ->assertEquals('test-with-context muuh', $renderer
    ->renderRoot($element_copy));

  // Tests caching of inline templates with long content to ensure the
  // generated cache key can be used as a filename.
  $element = [];
  $element['test'] = [
    '#type' => 'inline_template',
    '#template' => 'Llamas sometimes spit and wrestle with their {{ llama }}. Kittens are soft and fuzzy and they sometimes say {{ kitten }}. Flamingos have long legs and they are usually {{ flamingo }}. Pandas eat bamboo and they are {{ panda }}. Giraffes have long necks and long tongues and they eat {{ giraffe }}.',
    '#context' => [
      'llama' => 'necks',
      'kitten' => 'meow',
      'flamingo' => 'pink',
      'panda' => 'bears',
      'giraffe' => 'leaves',
    ],
  ];
  $expected = 'Llamas sometimes spit and wrestle with their necks. Kittens are soft and fuzzy and they sometimes say meow. Flamingos have long legs and they are usually pink. Pandas eat bamboo and they are bears. Giraffes have long necks and long tongues and they eat leaves.';
  $element_copy = $element;

  // Render it twice so that twig caching is triggered.
  $this
    ->assertEquals($expected, $renderer
    ->renderRoot($element));
  $this
    ->assertEquals($expected, $renderer
    ->renderRoot($element_copy));
  $name = '{# inline_template_start #}' . $element['test']['#template'];
  $prefix = $environment
    ->getTwigCachePrefix();
  $cache = $environment
    ->getCache();
  $class = $environment
    ->getTemplateClass($name);
  $expected = $prefix . '_inline-template_' . substr(Crypt::hashBase64($class), 0, TwigPhpStorageCache::SUFFIX_SUBSTRING_LENGTH);
  $this
    ->assertEquals($expected, $cache
    ->generateKey($name, $class));
}