2011-03-18 04:23:47 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class RedirectorPageTest extends FunctionalTest {
|
2013-03-18 11:47:15 +01:00
|
|
|
protected static $fixture_file = 'RedirectorPageTest.yml';
|
|
|
|
protected static $use_draft_site = true;
|
2011-03-18 04:23:47 +01:00
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
public function testGoodRedirectors() {
|
2011-03-18 04:23:47 +01:00
|
|
|
/* For good redirectors, the final destination URL will be returned */
|
|
|
|
$this->assertEquals("http://www.google.com", $this->objFromFixture('RedirectorPage','goodexternal')->Link());
|
|
|
|
$this->assertEquals(Director::baseURL() . "redirection-dest/", $this->objFromFixture('RedirectorPage','goodinternal')->redirectionLink());
|
|
|
|
$this->assertEquals(Director::baseURL() . "redirection-dest/", $this->objFromFixture('RedirectorPage','goodinternal')->Link());
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
public function testEmptyRedirectors() {
|
2011-03-18 04:23:47 +01:00
|
|
|
/* If a redirector page is misconfigured, then its link method will just return the usual URLSegment-generated value */
|
|
|
|
$page1 = $this->objFromFixture('RedirectorPage','badexternal');
|
|
|
|
$this->assertEquals(Director::baseURL() . 'bad-external/', $page1->Link());
|
|
|
|
|
|
|
|
/* An error message will be shown if you visit it */
|
|
|
|
$content = $this->get(Director::makeRelative($page1->Link()))->getBody();
|
|
|
|
$this->assertContains('message-setupWithoutRedirect', $content);
|
|
|
|
|
|
|
|
/* This also applies for internal links */
|
|
|
|
$page2 = $this->objFromFixture('RedirectorPage','badinternal');
|
|
|
|
$this->assertEquals(Director::baseURL() . 'bad-internal/', $page2->Link());
|
|
|
|
$content = $this->get(Director::makeRelative($page2->Link()))->getBody();
|
|
|
|
$this->assertContains('message-setupWithoutRedirect', $content);
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
public function testReflexiveAndTransitiveInternalRedirectors() {
|
2011-03-18 04:23:47 +01:00
|
|
|
/* Reflexive redirectors are those that point to themselves. They should behave the same as an empty redirector */
|
|
|
|
$page = $this->objFromFixture('RedirectorPage','reflexive');
|
|
|
|
$this->assertEquals(Director::baseURL() . 'reflexive/', $page->Link());
|
|
|
|
$content = $this->get(Director::makeRelative($page->Link()))->getBody();
|
|
|
|
$this->assertContains('message-setupWithoutRedirect', $content);
|
|
|
|
|
|
|
|
/* Transitive redirectors are those that point to another redirector page. They should send people to the URLSegment
|
|
|
|
* of the destination page - the middle-stop, so to speak. That should redirect to the final destination */
|
|
|
|
$page = $this->objFromFixture('RedirectorPage','transitive');
|
|
|
|
$this->assertEquals(Director::baseURL() . 'good-internal/', $page->Link());
|
|
|
|
|
|
|
|
$this->autoFollowRedirection = false;
|
|
|
|
$response = $this->get(Director::makeRelative($page->Link()));
|
|
|
|
$this->assertEquals(Director::baseURL() . "redirection-dest/", $response->getHeader("Location"));
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:46 +02:00
|
|
|
public function testExternalURLGetsPrefixIfNotSet() {
|
2011-03-18 04:23:47 +01:00
|
|
|
$page = $this->objFromFixture('RedirectorPage', 'externalnoprefix');
|
|
|
|
$this->assertEquals($page->ExternalURL, 'http://google.com', 'onBeforeWrite has prefixed with http');
|
|
|
|
$page->write();
|
|
|
|
$this->assertEquals($page->ExternalURL, 'http://google.com', 'onBeforeWrite will not double prefix if written again!');
|
|
|
|
}
|
2012-04-12 09:23:20 +02:00
|
|
|
}
|