annotate core/tests/Drupal/Tests/Component/Render/PlainTextOutputTest.php @ 19:fa3358dc1485 tip

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