mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
Added ability to specify cdata blocks and ignore special character stripping in RssHelper. Tests updated as well. Closes #4491
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@7051 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
parent
027a90fab3
commit
ca48055ddb
2 changed files with 97 additions and 6 deletions
|
@ -32,7 +32,8 @@
|
|||
* @package cake
|
||||
* @subpackage cake.cake.libs.view.helpers
|
||||
*/
|
||||
uses('view' . DS . 'helpers' . DS . 'xml');
|
||||
App::import('Helper', 'Xml');
|
||||
//uses('view' . DS . 'helpers' . DS . 'xml');
|
||||
|
||||
class RssHelper extends XmlHelper {
|
||||
|
||||
|
@ -186,6 +187,9 @@ class RssHelper extends XmlHelper {
|
|||
|
||||
foreach ($elements as $key => $val) {
|
||||
$attrib = array();
|
||||
$cdata = false;
|
||||
$strip = true;
|
||||
|
||||
switch ($key) {
|
||||
case 'pubDate' :
|
||||
$val = $this->time($val);
|
||||
|
@ -223,9 +227,23 @@ class RssHelper extends XmlHelper {
|
|||
$val = null;
|
||||
break;
|
||||
}
|
||||
if ($val != null) {
|
||||
|
||||
if (is_array($val)) {
|
||||
$_keys = array('cdata', 'strip');
|
||||
foreach($_keys as $index) {
|
||||
if (isset($val[$index])){
|
||||
$$index = $val[$index];
|
||||
unset($val[$index]);
|
||||
}
|
||||
}
|
||||
$val = $val['value'];
|
||||
}
|
||||
if ($val != null && $strip) {
|
||||
$val = h($val);
|
||||
}
|
||||
if ($cdata) {
|
||||
$val = '<![CDATA['. $val. ']]>';
|
||||
}
|
||||
$elements[$key] = $this->elem($key, $attrib, $val);
|
||||
}
|
||||
|
||||
|
|
|
@ -29,7 +29,7 @@
|
|||
if (!defined('CAKEPHP_UNIT_TEST_EXECUTION')) {
|
||||
define('CAKEPHP_UNIT_TEST_EXECUTION', 1);
|
||||
}
|
||||
uses('view'.DS.'helpers'.DS.'app_helper', 'controller'.DS.'controller', 'model'.DS.'model', 'view'.DS.'helper', 'view'.DS.'helpers'.DS.'rss');
|
||||
App::import('Helper', array('Rss', 'Time'));
|
||||
|
||||
/**
|
||||
* Short description for class.
|
||||
|
@ -37,10 +37,11 @@ uses('view'.DS.'helpers'.DS.'app_helper', 'controller'.DS.'controller', 'model'.
|
|||
* @package cake.tests
|
||||
* @subpackage cake.tests.cases.libs.view.helpers
|
||||
*/
|
||||
class RssTest extends UnitTestCase {
|
||||
class RssTest extends CakeTestCase {
|
||||
|
||||
function setUp() {
|
||||
$this->Rss =& new RssHelper();
|
||||
$this->Rss->Time = new TimeHelper();
|
||||
}
|
||||
|
||||
function tearDown() {
|
||||
|
@ -121,6 +122,73 @@ class RssTest extends UnitTestCase {
|
|||
$result = $this->Rss->item(null, array("title"=>"My title","description"=>"My description","link"=>"http://www.google.com/"));
|
||||
$expecting = '<item><title>My title</title><description>My description</description><link>http://www.google.com/</link><guid>http://www.google.com/</guid></item>';
|
||||
$this->assertEqual($result, $expecting);
|
||||
|
||||
$item = array(
|
||||
'title' => array(
|
||||
'value' => 'My Title',
|
||||
'cdata' => true,
|
||||
),
|
||||
'link' => 'http://www.example.com/1',
|
||||
'description' => array(
|
||||
'value' => 'descriptive words',
|
||||
'cdata' => true,
|
||||
),
|
||||
'pubDate' => '2008-05-31 12:00:00',
|
||||
'guid' => 'http://www.example.com/1'
|
||||
);
|
||||
$result = $this->Rss->item(null, $item);
|
||||
$expected = array(
|
||||
'<item',
|
||||
'<title',
|
||||
'<![CDATA[My Title]]',
|
||||
'/title',
|
||||
'<link',
|
||||
'http://www.example.com/1',
|
||||
'/link',
|
||||
'<description',
|
||||
'<![CDATA[descriptive words]]',
|
||||
'/description',
|
||||
'<pubDate',
|
||||
'Sat, 31 May 2008 12:00:00 -0400',
|
||||
'/pubDate',
|
||||
'<guid',
|
||||
'http://www.example.com/1',
|
||||
'/guid',
|
||||
'/item'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
|
||||
$item = array(
|
||||
'title' => array(
|
||||
'value' => 'My Title & more',
|
||||
'cdata' => true
|
||||
)
|
||||
);
|
||||
$result = $this->Rss->item(null, $item);
|
||||
$expected = array(
|
||||
'<item',
|
||||
'<title',
|
||||
'<![CDATA[My Title & more]]',
|
||||
'/title',
|
||||
'/item'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
|
||||
$item = array(
|
||||
'title' => array(
|
||||
'value' => 'My Title & more',
|
||||
'strip' => false
|
||||
)
|
||||
);
|
||||
$result = $this->Rss->item(null, $item);
|
||||
$expected = array(
|
||||
'<item',
|
||||
'<title',
|
||||
'My Title & more',
|
||||
'/title',
|
||||
'/item'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
}
|
||||
|
||||
function testTime() {
|
||||
|
@ -128,10 +196,15 @@ class RssTest extends UnitTestCase {
|
|||
|
||||
function testElementAttrNotInParent() {
|
||||
$attributes = array('title' => 'Some Title', 'link' => 'http://link.com', 'description' => 'description');
|
||||
$elements = array('enclosure' => array('url' => 'http://somewhere.com'));
|
||||
$elements = array('enclosure' => array('url' => 'http://test.com'));
|
||||
|
||||
$result = $this->Rss->item($attributes, $elements);
|
||||
$this->assertPattern('/^<item title="Some Title" link="http:\/\/link.com" description="description"><enclosure url="http:\/\/somewhere.com" \/><\/item>$/', $result);
|
||||
$expected = array(
|
||||
'item' => array('title' => 'Some Title', 'link' => 'http://link.com', 'description' => 'description'),
|
||||
'enclosure' => array('url' => 'http://test.com'),
|
||||
'/item'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
}
|
||||
}
|
||||
?>
|
Loading…
Add table
Reference in a new issue