c73ed8dbb9b7cdeaea5af4c9b2e7411e2fb8685f
[yaffs-website] / web / core / tests / Drupal / Tests / Component / Render / PlainTextOutputTest.php
1 <?php
2
3 namespace Drupal\Tests\Component\Render;
4
5 use Drupal\Component\Render\PlainTextOutput;
6 use Drupal\Component\Render\FormattableMarkup;
7 use Drupal\Component\Render\MarkupInterface;
8 use PHPUnit\Framework\TestCase;
9
10 /**
11  * @coversDefaultClass \Drupal\Component\Render\PlainTextOutput
12  * @group Utility
13  */
14 class PlainTextOutputTest extends TestCase {
15
16   /**
17    * Tests ::renderFromHtml().
18    *
19    * @param $expected
20    *   The expected formatted value.
21    * @param $string
22    *   A string to be formatted.
23    * @param array $args
24    *   (optional) An associative array of replacements to make. Defaults to
25    *   none.
26    *
27    * @covers ::renderFromHtml
28    * @dataProvider providerRenderFromHtml
29    */
30   public function testRenderFromHtml($expected, $string, $args = []) {
31     $markup = new FormattableMarkup($string, $args);
32     $output = PlainTextOutput::renderFromHtml($markup);
33     $this->assertSame($expected, $output);
34   }
35
36   /**
37    * Data provider for ::testRenderFromHtml()
38    */
39   public function providerRenderFromHtml() {
40     $data = [];
41
42     $data['simple-text'] = ['Giraffes and wombats', 'Giraffes and wombats'];
43     $data['simple-html'] = ['Giraffes and wombats', '<a href="/muh">Giraffes</a> and <strong>wombats</strong>'];
44     $data['html-with-quote'] = ['Giraffes and quote"s', '<a href="/muh">Giraffes</a> and <strong>quote"s</strong>'];
45
46     $expected = 'The <em> tag makes your text look like "this".';
47     $string = 'The &lt;em&gt; tag makes your text look like <em>"this"</em>.';
48     $data['escaped-html-with-quotes'] = [$expected, $string];
49
50     $safe_string = $this->prophesize(MarkupInterface::class);
51     $safe_string->__toString()->willReturn('<em>"this"</em>');
52     $safe_string = $safe_string->reveal();
53     $data['escaped-html-with-quotes-and-placeholders'] = [$expected, 'The @tag tag makes your text look like @result.', ['@tag' => '<em>', '@result' => $safe_string]];
54
55     $safe_string = $this->prophesize(MarkupInterface::class);
56     $safe_string->__toString()->willReturn($string);
57     $safe_string = $safe_string->reveal();
58     $data['safe-string'] = [$expected, $safe_string];
59
60     return $data;
61   }
62
63 }