2009-10-13 01:44:41 +00:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\View\Tests\Parsers;
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2016-09-09 18:43:05 +12:00
|
|
|
use SilverStripe\View\Parsers\HTML4Value;
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
class HTML4ValueTest extends SapphireTest
|
|
|
|
{
|
|
|
|
public function testInvalidHTMLSaving()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
2013-03-12 09:06:20 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$invalid = [
|
|
|
|
'<p>Enclosed Value</p></p>'
|
|
|
|
=> '<p>Enclosed Value</p>',
|
|
|
|
'<meta content="text/html"></meta>'
|
|
|
|
=> '<meta content="text/html">',
|
|
|
|
'<p><div class="example"></div></p>'
|
|
|
|
=> '<p></p><div class="example"></div>',
|
|
|
|
'<html><html><body><falsetag "attribute=""attribute""">'
|
|
|
|
=> '<falsetag></falsetag>',
|
|
|
|
'<body<body<body>/bodu>/body>'
|
|
|
|
=> '/bodu>/body>'
|
|
|
|
];
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
foreach ($invalid as $input => $expected) {
|
|
|
|
$value->setContent($input);
|
|
|
|
$this->assertEquals($expected, $value->getContent(), 'Invalid HTML can be saved');
|
|
|
|
}
|
|
|
|
}
|
2012-10-16 11:59:30 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testUtf8Saving()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
2013-03-12 09:06:20 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$value->setContent('<p>ö ß ā い 家</p>');
|
|
|
|
$this->assertEquals('<p>ö ß ā い 家</p>', $value->getContent());
|
|
|
|
}
|
2012-10-16 11:59:30 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testInvalidHTMLTagNames()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
2013-03-12 09:06:20 +13:00
|
|
|
|
2020-04-20 18:58:09 +01:00
|
|
|
$invalid = [
|
2016-12-16 17:34:21 +13:00
|
|
|
'<p><div><a href="test-link"></p></div>',
|
|
|
|
'<html><div><a href="test-link"></a></a></html_>',
|
|
|
|
'""\'\'\'"""\'""<<<>/</<htmlbody><a href="test-link"<<>'
|
2020-04-20 18:58:09 +01:00
|
|
|
];
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
foreach ($invalid as $input) {
|
|
|
|
$value->setContent($input);
|
|
|
|
$this->assertEquals(
|
|
|
|
'test-link',
|
|
|
|
$value->getElementsByTagName('a')->item(0)->getAttribute('href'),
|
2021-12-13 09:05:33 +01:00
|
|
|
'Link data can be extracted from malformed HTML'
|
2016-12-16 17:34:21 +13:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testMixedNewlines()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
2013-03-12 09:06:20 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$value->setContent("<p>paragraph</p>\n<ul><li>1</li>\r\n</ul>");
|
|
|
|
$this->assertEquals(
|
|
|
|
"<p>paragraph</p>\n<ul><li>1</li>\n</ul>",
|
|
|
|
$value->getContent(),
|
|
|
|
'Newlines get converted'
|
|
|
|
);
|
|
|
|
}
|
2012-10-16 11:59:30 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testAttributeEscaping()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
2013-04-18 09:13:24 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$value->setContent('<a href="[]"></a>');
|
|
|
|
$this->assertEquals('<a href="[]"></a>', $value->getContent(), "'[' character isn't escaped");
|
2013-04-18 09:13:24 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
$value->setContent('<a href="""></a>');
|
|
|
|
$this->assertEquals('<a href="""></a>', $value->getContent(), "'\"' character is escaped");
|
|
|
|
}
|
2019-01-25 15:55:03 +13:00
|
|
|
|
|
|
|
public function testGetContent()
|
|
|
|
{
|
|
|
|
$value = new HTML4Value();
|
|
|
|
|
|
|
|
$value->setContent('<p>This is valid</p>');
|
|
|
|
$this->assertEquals('<p>This is valid</p>', $value->getContent(), "Valid content is returned");
|
|
|
|
|
|
|
|
$value->setContent('<p?< This is not really valid but it will get parsed into something valid');
|
|
|
|
// can sometimes get a this state where HTMLValue->valid is false
|
|
|
|
// for instance if a content editor saves something really weird in a LiteralField
|
|
|
|
// we can manually get to this state via ->setInvalid()
|
|
|
|
$value->setInvalid();
|
|
|
|
$this->assertEquals('', $value->getContent(), "Blank string is returned when invalid");
|
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|