3 namespace Drupal\Tests\Component\Render;
5 use Drupal\Component\Render\PlainTextOutput;
6 use Drupal\Component\Render\FormattableMarkup;
7 use Drupal\Component\Render\MarkupInterface;
8 use PHPUnit\Framework\TestCase;
11 * @coversDefaultClass \Drupal\Component\Render\PlainTextOutput
14 class PlainTextOutputTest extends TestCase {
17 * Tests ::renderFromHtml().
20 * The expected formatted value.
22 * A string to be formatted.
24 * (optional) An associative array of replacements to make. Defaults to
27 * @covers ::renderFromHtml
28 * @dataProvider providerRenderFromHtml
30 public function testRenderFromHtml($expected, $string, $args = []) {
31 $markup = new FormattableMarkup($string, $args);
32 $output = PlainTextOutput::renderFromHtml($markup);
33 $this->assertSame($expected, $output);
37 * Data provider for ::testRenderFromHtml()
39 public function providerRenderFromHtml() {
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>'];
46 $expected = 'The <em> tag makes your text look like "this".';
47 $string = 'The <em> tag makes your text look like <em>"this"</em>.';
48 $data['escaped-html-with-quotes'] = [$expected, $string];
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]];
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];