Update meta generator tests to use isolated configuration and better assertions

This commit is contained in:
Robbie Averill 2018-12-02 18:20:44 +00:00
parent 92c0424d73
commit 7554b61325

View File

@ -1227,35 +1227,36 @@ class SiteTreeTest extends SapphireTest
{
$generator = Config::inst()->get(SiteTree::class, 'meta_generator');
// Stub to ensure customisations don't affect the test
Config::modify()->set(SiteTree::class, 'meta_generator', 'SilverStripe - https://www.silverstripe.org');
$page = new SiteTreeTest_PageNode();
$meta = $page->MetaTags();
$this->assertEquals(
1,
preg_match('/.*meta name="generator" content="SilverStripe - http:\/\/silverstripe.org".*/', $meta),
'test default functionality - uses value from Config'
$this->assertContains('meta name="generator"', $meta, 'Should include generator tag');
$this->assertContains(
'content="SilverStripe - https://www.silverstripe.org',
$meta,
'Should contain default meta generator info'
);
// test proper escaping of quotes in attribute value
Config::modify()->set(SiteTree::class, 'meta_generator', 'Generator with "quotes" in it');
$meta = $page->MetaTags();
$this->assertEquals(
1,
preg_match('/.*meta name="generator" content="Generator with "quotes" in it".*/', $meta),
$this->assertContains(
'content="Generator with "quotes" in it',
$meta,
'test proper escaping of values from Config'
);
// test empty generator - no tag should appear at all
Config::modify()->set(SiteTree::class, 'meta_generator', '');
$meta = $page->MetaTags();
$this->assertEquals(
0,
preg_match('/.*meta name=.generator..*/', $meta),
$this->assertNotContains(
'meta name="generator"',
$meta,
'test blank value means no tag generated'
);
// reset original value
Config::modify()->set(SiteTree::class, 'meta_generator', $generator);
}