From b5a25e49f6f9a18b097ca133136d8829d79274f9 Mon Sep 17 00:00:00 2001 From: Steve Boyd Date: Thu, 26 Jan 2023 15:23:46 +1300 Subject: [PATCH] MNT Update unit test to work with both HTML4Value and HTML5Value --- tests/php/Model/SiteTreeTest.php | 49 +++++++++++++++++++++++++++++--- 1 file changed, 45 insertions(+), 4 deletions(-) diff --git a/tests/php/Model/SiteTreeTest.php b/tests/php/Model/SiteTreeTest.php index 9927c95800..007337787e 100644 --- a/tests/php/Model/SiteTreeTest.php +++ b/tests/php/Model/SiteTreeTest.php @@ -40,6 +40,9 @@ use TractorCow\Fluent\Extension\FluentSiteTreeExtension; use const RESOURCES_DIR; use SilverStripe\Dev\Deprecation; +use SilverStripe\HTML5\HTML5Value; +use SilverStripe\View\Parsers\HTMLValue; +use SilverStripe\View\Parsers\HTML4Value; class SiteTreeTest extends SapphireTest { @@ -2060,12 +2063,50 @@ public function provideSanitiseExtraMeta(): array '', '', 'Multiple attributes are removed' - ], + ] + ]; + } + + /** + * @dataProvider provideSanatiseInvalidExtraMeta + */ + public function testSanatiseInvalidExtraMetaHTML4Value(string $extraMeta, string $expected): void + { + Injector::inst()->registerService(HTML4Value::create(), HTMLValue::class); + $siteTree = new SiteTree(); + $siteTree->ExtraMeta = $extraMeta; + $siteTree->write(); + $this->assertSame( + $expected, + $siteTree->ExtraMeta, + 'Invalid HTML is converted to valid HTML and parsed' + ); + } + + /** + * @dataProvider provideSanatiseInvalidExtraMeta + */ + public function testSanatiseInvalidExtraMetaHTML5Value(string $extraMeta): void + { + // HTML5Value comes from the module silverstripe/html5 + if (!class_exists(HTML5Value::class)) { + $this->markTestSkipped('HTML5Value class does not exist'); + } + Injector::inst()->registerService(HTML5Value::create(), HTMLValue::class); + $this->expectException(ValidationException::class); + $this->expectExceptionMessage('Custom Meta Tags does not contain valid HTML'); + $siteTree = new SiteTree(); + $siteTree->ExtraMeta = $extraMeta; + $siteTree->write(); + } + + public function provideSanatiseInvalidExtraMeta(): array + { + return [ [ '', - 'Invalid HTML is converted to valid HTML and parsed' - ], + '' + ] ]; } }