Merge pull request #23 from robbieaverill/pulls/translatable-conflict-in-test

FIX Ensure that translatable cannot break tests. Separate page stub class. Remove injector nesting.
This commit is contained in:
Damian Mooyman 2017-05-12 11:50:43 +12:00 committed by GitHub
commit ded3b7cd82
3 changed files with 16 additions and 17 deletions

View File

@ -5,9 +5,13 @@ class ExternalLinksTest extends SapphireTest {
protected static $fixture_file = 'ExternalLinksTest.yml';
protected $extraDataObjects = array(
'ExternalLinksTest_Page'
'ExternalLinksTestPage'
);
protected $illegalExtensions = array(
'SiteTree' => array('Translatable')
);
public function setUpOnce() {
if (class_exists('Phockito')) {
Phockito::include_hamcrest(false);
@ -19,8 +23,6 @@ class ExternalLinksTest extends SapphireTest {
public function setUp() {
parent::setUp();
Injector::nest();
// Check dependencies
if (!class_exists('Phockito')) {
$this->skipTest = true;
@ -72,11 +74,6 @@ class ExternalLinksTest extends SapphireTest {
Injector::inst()->registerService($checker, 'LinkChecker');
}
public function tearDown() {
Injector::unnest();
parent::tearDown();
}
public function testLinks() {
// Run link checker
$task = CheckExternalLinksTask::create();
@ -91,7 +88,7 @@ class ExternalLinksTest extends SapphireTest {
// Check all pages have had the correct HTML adjusted
for($i = 1; $i <= 5; $i++) {
$page = $this->objFromFixture('ExternalLinksTest_Page', 'page'.$i);
$page = $this->objFromFixture('ExternalLinksTestPage', 'page'.$i);
$this->assertNotEmpty($page->Content);
$this->assertEquals(
$page->ExpectedContent,
@ -149,9 +146,3 @@ class ExternalLinksTest extends SapphireTest {
'BrokenExternalLinksReport is in reports list');
}
}
class ExternalLinksTest_Page extends Page implements TestOnly {
private static $db = array(
'ExpectedContent' => 'HTMLText'
);
}

View File

@ -1,4 +1,4 @@
ExternalLinksTest_Page:
ExternalLinksTestPage:
# Tests mix of broken and working external links
page1:
Title: 'Page 1'

View File

@ -0,0 +1,8 @@
<?php
class ExternalLinksTestPage extends Page implements TestOnly
{
private static $db = array(
'ExpectedContent' => 'HTMLText'
);
}