class PlainTextOutputTest
Same name in other branches
- 9 core/tests/Drupal/Tests/Component/Render/PlainTextOutputTest.php \Drupal\Tests\Component\Render\PlainTextOutputTest
- 8.9.x core/tests/Drupal/Tests/Component/Render/PlainTextOutputTest.php \Drupal\Tests\Component\Render\PlainTextOutputTest
- 11.x core/tests/Drupal/Tests/Component/Render/PlainTextOutputTest.php \Drupal\Tests\Component\Render\PlainTextOutputTest
@coversDefaultClass \Drupal\Component\Render\PlainTextOutput @group Utility
Hierarchy
- class \Drupal\Tests\Component\Render\PlainTextOutputTest extends \PHPUnit\Framework\TestCase
Expanded class hierarchy of PlainTextOutputTest
File
-
core/
tests/ Drupal/ Tests/ Component/ Render/ PlainTextOutputTest.php, line 17
Namespace
Drupal\Tests\Component\RenderView source
class PlainTextOutputTest extends TestCase {
/**
* Tests ::renderFromHtml().
*
* @param $expected
* The expected formatted value.
* @param $string
* A string to be formatted.
* @param array $args
* (optional) An associative array of replacements to make. Defaults to
* none.
*
* @covers ::renderFromHtml
* @dataProvider providerRenderFromHtml
*/
public function testRenderFromHtml($expected, $string, $args = []) : void {
$markup = new FormattableMarkup($string, $args);
$output = PlainTextOutput::renderFromHtml($markup);
$this->assertSame($expected, $output);
}
/**
* Data provider for ::testRenderFromHtml()
*/
public static function providerRenderFromHtml() {
$prophet = new Prophet();
$data = [];
$data['simple-text'] = [
'Giraffes and wombats',
'Giraffes and wombats',
];
$data['simple-html'] = [
'Giraffes and wombats',
'<a href="/muh">Giraffes</a> and <strong>wombats</strong>',
];
$data['html-with-quote'] = [
'Giraffes and quote"s',
'<a href="/muh">Giraffes</a> and <strong>quote"s</strong>',
];
$expected = 'The <em> tag makes your text look like "this".';
$string = 'The <em> tag makes your text look like <em>"this"</em>.';
$data['escaped-html-with-quotes'] = [
$expected,
$string,
];
$safe_string = $prophet->prophesize(MarkupInterface::class);
$safe_string->__toString()
->willReturn('<em>"this"</em>');
$safe_string = $safe_string->reveal();
$data['escaped-html-with-quotes-and-placeholders'] = [
$expected,
'The @tag tag makes your text look like @result.',
[
'@tag' => '<em>',
'@result' => $safe_string,
],
];
$safe_string = $prophet->prophesize(MarkupInterface::class);
$safe_string->__toString()
->willReturn($string);
$safe_string = $safe_string->reveal();
$data['safe-string'] = [
$expected,
$safe_string,
];
return $data;
}
}
Members
Title Sort descending | Modifiers | Object type | Summary |
---|---|---|---|
PlainTextOutputTest::providerRenderFromHtml | public static | function | Data provider for ::testRenderFromHtml() |
PlainTextOutputTest::testRenderFromHtml | public | function | Tests ::renderFromHtml(). |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.