mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
29ea7e0b98
API CHANGE: Determine default BASE_PATH/BASE_URL from the __FILE__ content, so that the script that initiated the Sapphire process doesn't matter. This means that index.php doesn't need to manipulate those variables. (from r97731) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@102528 467b73ca-7a2a-4603-9d3b-597d59a354a9
111 lines
3.1 KiB
PHP
Executable File
111 lines
3.1 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* @package sapphire
|
|
* @subpackage tests
|
|
*/
|
|
class RSSFeedTest extends SapphireTest {
|
|
|
|
function testRSSFeed() {
|
|
$list = new DataObjectSet();
|
|
$list->push(new RSSFeedTest_ItemA());
|
|
$list->push(new RSSFeedTest_ItemB());
|
|
$list->push(new RSSFeedTest_ItemC());
|
|
|
|
$origServer = $_SERVER;
|
|
$_SERVER['HTTP_HOST'] = 'www.example.org';
|
|
|
|
Director::setBaseURL('/');
|
|
|
|
$rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description");
|
|
$content = $rssFeed->feedContent();
|
|
|
|
//Debug::message($content);
|
|
$this->assertContains('<link>http://www.example.org/item-a/</link>', $content);
|
|
$this->assertContains('<link>http://www.example.com/item-b.html</link>', $content);
|
|
$this->assertContains('<link>http://www.example.com/item-c.html</link>', $content);
|
|
|
|
$this->assertContains('<title>ItemA</title>', $content);
|
|
$this->assertContains('<title>ItemB</title>', $content);
|
|
$this->assertContains('<title>ItemC</title>', $content);
|
|
|
|
$this->assertContains('<description>ItemA Content</description>', $content);
|
|
$this->assertContains('<description>ItemB Content</description>', $content);
|
|
$this->assertContains('<description>ItemC Content</description>', $content);
|
|
|
|
|
|
// Feed #2 - put Content() into <title> and AltContent() into <description>
|
|
$rssFeed = new RSSFeed($list, "http://www.example.com", "Test RSS Feed", "Test RSS Feed Description", "Content", "AltContent");
|
|
$content = $rssFeed->feedContent();
|
|
|
|
$this->assertContains('<title>ItemA Content</title>', $content);
|
|
$this->assertContains('<title>ItemB Content</title>', $content);
|
|
$this->assertContains('<title>ItemC Content</title>', $content);
|
|
|
|
$this->assertContains('<description>ItemA AltContent</description>', $content);
|
|
$this->assertContains('<description>ItemB AltContent</description>', $content);
|
|
$this->assertContains('<description>ItemC AltContent</description>', $content);
|
|
|
|
Director::setBaseURL(null);
|
|
$_SERVER = $origServer;
|
|
}
|
|
|
|
}
|
|
|
|
class RSSFeedTest_ItemA extends ViewableData {
|
|
// RSS-feed items must have $casting/$db information.
|
|
static $casting = array(
|
|
'Title' => 'Varchar',
|
|
'Content' => 'Text',
|
|
'AltContent' => 'Text',
|
|
);
|
|
|
|
function Title() {
|
|
return "ItemA";
|
|
}
|
|
function Content() {
|
|
return "ItemA Content";
|
|
}
|
|
function AltContent() {
|
|
return "ItemA AltContent";
|
|
}
|
|
|
|
function Link($action = null) {
|
|
return Controller::join_links("item-a/", $action);
|
|
}
|
|
}
|
|
|
|
class RSSFeedTest_ItemB extends ViewableData {
|
|
// ItemB tests without $casting
|
|
|
|
function Title() {
|
|
return "ItemB";
|
|
}
|
|
function AbsoluteLink() {
|
|
return "http://www.example.com/item-b.html";
|
|
}
|
|
function Content() {
|
|
return "ItemB Content";
|
|
}
|
|
function AltContent() {
|
|
return "ItemB AltContent";
|
|
}
|
|
}
|
|
|
|
class RSSFeedTest_ItemC extends ViewableData {
|
|
// ItemC tests fields - Title has casting, Content doesn't.
|
|
static $casting = array(
|
|
'Title' => 'Varchar',
|
|
'AltContent' => 'Text',
|
|
);
|
|
|
|
public $Title = "ItemC";
|
|
public $Content = "ItemC Content";
|
|
public $AltContent = "ItemC AltContent";
|
|
|
|
function Link() {
|
|
return "item-c.html";
|
|
}
|
|
function AbsoluteLink() {
|
|
return "http://www.example.com/item-c.html";
|
|
}
|
|
} |