MNT Update unit test to handle HTML5Value

This commit is contained in:
Steve Boyd 2022-12-20 14:41:32 +13:00
parent 0b6ee121e3
commit 4a5e22cc60

View File

@ -39,6 +39,8 @@ use SilverStripe\View\Parsers\URLSegmentFilter;
use SilverStripe\View\Shortcodes\EmbedShortcodeProvider; use SilverStripe\View\Shortcodes\EmbedShortcodeProvider;
use TractorCow\Fluent\Extension\FluentSiteTreeExtension; use TractorCow\Fluent\Extension\FluentSiteTreeExtension;
use const RESOURCES_DIR; use const RESOURCES_DIR;
use SilverStripe\View\Parsers\HTMLValue;
use SilverStripe\HTML5\HTML5Value;
class SiteTreeTest extends SapphireTest class SiteTreeTest extends SapphireTest
{ {
@ -2023,11 +2025,21 @@ class SiteTreeTest extends SapphireTest
*/ */
public function testSanitiseExtraMeta(string $extraMeta, string $expected, string $message): void public function testSanitiseExtraMeta(string $extraMeta, string $expected, string $message): void
{ {
// If using HTML5Value then the 'somethingdodgy' test won't be converted to valid html
// However if using the default HTMLValue, then it will be converted to valid html
$isDodgyAndUsingHTML5 = strpos($expected, 'somethingdodgy') !== false &&
(HTMLValue::create() instanceof HTML5Value);
if ($isDodgyAndUsingHTML5) {
$this->expectException(ValidationException::class);
$this->expectExceptionMessage('Custom Meta Tags does not contain valid HTML');
}
$siteTree = new SiteTree(); $siteTree = new SiteTree();
$siteTree->ExtraMeta = $extraMeta; $siteTree->ExtraMeta = $extraMeta;
$siteTree->write(); $siteTree->write();
if (!$isDodgyAndUsingHTML5) {
$this->assertSame($expected, $siteTree->ExtraMeta, $message); $this->assertSame($expected, $siteTree->ExtraMeta, $message);
} }
}
public function provideSanitiseExtraMeta(): array public function provideSanitiseExtraMeta(): array
{ {