mirror of
https://github.com/silverstripe/silverstripe-externallinks.git
synced 2024-10-22 15:05:44 +00:00
38659bac98
PHPUnit had a Functions.php with global methods like any() for a while (3.7 at least), which clashes with similar globals from Hamcrest (used in Phockito). Both PHPUnit and Phockito use 'classmap' composer autoloading, but that's not directly requiring/evaluating the files. The problem is caused by SilverStripe's ClassLoader which does require ALL subclasses of SapphireTest. This in turn causes PHP outside of the class context to execute, which includes Hamcrest. Changing the include_hamcrest() is not strictly necessary here, but makes the code a bit more resilient against any preceding test including Functions.php from PHPUnit. See https://github.com/hafriedlander/phockito/issues/32 for context.
158 lines
3.9 KiB
PHP
158 lines
3.9 KiB
PHP
<?php
|
|
|
|
class ExternalLinksTest extends SapphireTest {
|
|
|
|
protected static $fixture_file = 'ExternalLinksTest.yml';
|
|
|
|
protected $extraDataObjects = array(
|
|
'ExternalLinksTest_Page'
|
|
);
|
|
|
|
public function setUpOnce() {
|
|
if (class_exists('Phockito')) {
|
|
Phockito::include_hamcrest(false);
|
|
}
|
|
|
|
parent::setUpOnce();
|
|
}
|
|
|
|
public function setUp() {
|
|
parent::setUp();
|
|
|
|
Injector::nest();
|
|
|
|
// Check dependencies
|
|
if (!class_exists('Phockito')) {
|
|
$this->skipTest = true;
|
|
return $this->markTestSkipped("These tests need the Phockito module installed to run");
|
|
}
|
|
|
|
// Mock link checker
|
|
$checker = Phockito::mock('LinkChecker');
|
|
Phockito::when($checker)
|
|
->checkLink('http://www.working.com')
|
|
->return(200);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('http://www.broken.com/url/thing') // 404 on working site
|
|
->return(404);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('http://www.broken.com') // 403 on working site
|
|
->return(403);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('http://www.nodomain.com') // no ping
|
|
->return(0);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('/internal/link')
|
|
->return(null);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('[sitetree_link,id=9999]')
|
|
->return(null);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('home')
|
|
->return(null);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('broken-internal')
|
|
->return(null);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink('[sitetree_link,id=1]')
|
|
->return(null);
|
|
|
|
Phockito::when($checker)
|
|
->checkLink(Hamcrest_Matchers::anything()) // anything else is 404
|
|
->return(404);
|
|
|
|
Injector::inst()->registerService($checker, 'LinkChecker');
|
|
}
|
|
|
|
public function tearDown() {
|
|
Injector::unnest();
|
|
parent::tearDown();
|
|
}
|
|
|
|
public function testLinks() {
|
|
// Run link checker
|
|
$task = CheckExternalLinksTask::create();
|
|
$task->setSilent(true); // Be quiet during the test!
|
|
$task->runLinksCheck();
|
|
|
|
// Get all links checked
|
|
$status = BrokenExternalPageTrackStatus::get_latest();
|
|
$this->assertEquals('Completed', $status->Status);
|
|
$this->assertEquals(5, $status->TotalPages);
|
|
$this->assertEquals(5, $status->CompletedPages);
|
|
|
|
// Check all pages have had the correct HTML adjusted
|
|
for($i = 1; $i <= 5; $i++) {
|
|
$page = $this->objFromFixture('ExternalLinksTest_Page', 'page'.$i);
|
|
$this->assertNotEmpty($page->Content);
|
|
$this->assertEquals(
|
|
$page->ExpectedContent,
|
|
$page->Content,
|
|
"Assert that the content of page{$i} has been updated"
|
|
);
|
|
}
|
|
|
|
// Check that the correct report of broken links is generated
|
|
$links = $status
|
|
->BrokenLinks()
|
|
->sort('Link');
|
|
|
|
$this->assertEquals(4, $links->count());
|
|
$this->assertEquals(
|
|
array(
|
|
'http://www.broken.com',
|
|
'http://www.broken.com/url/thing',
|
|
'http://www.broken.com/url/thing',
|
|
'http://www.nodomain.com'
|
|
),
|
|
array_values($links->map('ID', 'Link')->toArray())
|
|
);
|
|
|
|
// Check response codes are correct
|
|
$expected = array(
|
|
'http://www.broken.com' => 403,
|
|
'http://www.broken.com/url/thing' => 404,
|
|
'http://www.nodomain.com' => 0
|
|
);
|
|
$actual = $links->map('Link', 'HTTPCode')->toArray();
|
|
$this->assertEquals($expected, $actual);
|
|
|
|
// Check response descriptions are correct
|
|
i18n::set_locale('en_NZ');
|
|
$expected = array(
|
|
'http://www.broken.com' => '403 (Forbidden)',
|
|
'http://www.broken.com/url/thing' => '404 (Not Found)',
|
|
'http://www.nodomain.com' => '0 (Server Not Available)'
|
|
);
|
|
$actual = $links->map('Link', 'HTTPCodeDescription')->toArray();
|
|
$this->assertEquals($expected, $actual);
|
|
}
|
|
|
|
/**
|
|
* Test that broken links appears in the reports list
|
|
*/
|
|
public function testReportExists() {
|
|
$reports = SS_Report::get_reports();
|
|
$reportNames = array();
|
|
foreach($reports as $report) {
|
|
$reportNames[] = $report->class;
|
|
}
|
|
$this->assertContains('BrokenExternalLinksReport',$reportNames,
|
|
'BrokenExternalLinksReport is in reports list');
|
|
}
|
|
}
|
|
|
|
class ExternalLinksTest_Page extends Page implements TestOnly {
|
|
private static $db = array(
|
|
'ExpectedContent' => 'HTMLText'
|
|
);
|
|
}
|