feeds_parser_sitemap.test in Feeds 7
Same filename and directory in other branches
Tests for plugins/FeedsSitemapParser.inc
File
tests/feeds_parser_sitemap.testView source
<?php
/**
* @file
* Tests for plugins/FeedsSitemapParser.inc
*/
// Require FeedsWebTestCase class definition.
require_once dirname(__FILE__) . '/feeds.test.inc';
/**
* Test Sitemap parser.
*/
class FeedsSitemapParserTestCase extends FeedsWebTestCase {
/**
* Describe this test.
*/
public function getInfo() {
return array(
'name' => t('Sitemap parser'),
'description' => t('Regression tests for Sitemap XML format parser.'),
'group' => t('Feeds'),
);
}
/**
* Set up test.
*/
public function setUp() {
parent::setUp('feeds', 'feeds_ui', 'ctools', 'job_scheduler');
$this
->drupalLogin($this
->drupalCreateUser(array(
'administer feeds',
'administer nodes',
)));
}
/**
* Run tests.
*/
public function test() {
$this
->createImporterConfiguration('Sitemap', 'sitemap');
$this
->setPlugin('sitemap', 'FeedsSitemapParser');
$this
->addMappings('sitemap', array(
array(
'source' => 'changefreq',
'target' => 'title',
'unique' => FALSE,
),
array(
'source' => 'priority',
'target' => 'body',
'unique' => FALSE,
),
array(
'source' => 'lastmod',
'target' => 'created',
'unique' => FALSE,
),
array(
'source' => 'url',
'target' => 'url',
'unique' => TRUE,
),
array(
'source' => 'url',
'target' => 'guid',
'unique' => TRUE,
),
));
$path = $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'feeds') . '/tests/feeds/';
$nid = $this
->createFeedNode('sitemap', $path . 'sitemap-example.xml', 'Testing Sitemap Parser');
$this
->assertText('Created 5 Article nodes.');
// Assert DB status.
$count = db_query("SELECT COUNT(*) FROM {feeds_node_item}")
->fetchField();
$this
->assertEqual($count, 5, 'Accurate number of items in database.');
// Check items against known content of feed.
$items = db_query('SELECT * FROM {feeds_node_item} WHERE feed_nid = :nid ORDER BY nid', array(
':nid' => $nid,
));
// Check first item.
date_default_timezone_set('GMT');
$item = $items
->fetch();
$node = node_load($item->nid);
$this
->assertEqual($node->title, 'monthly', 'Feed item 1 changefreq is correct.');
$this
->assertEqual($node->body, '0.8', 'Feed item 1 priority is correct.');
$this
->assertEqual($node->created, strtotime('2005-01-01'), 'Feed item 1 lastmod is correct.');
$this
->assertEqual($node->feeds_node_item->url, 'http://www.example.com/', 'Feed item 1 url is correct.');
$this
->assertEqual($node->feeds_node_item->url, $node->feeds_node_item->guid, 'Feed item 1 guid is correct.');
// Check second item.
$item = $items
->fetch();
$node = node_load($item->nid);
$this
->assertEqual($node->title, 'weekly', 'Feed item 2 changefreq is correct.');
$this
->assertEqual($node->body, '', 'Feed item 2 priority is correct.');
// $node->created is... recently
$this
->assertEqual($node->feeds_node_item->url, 'http://www.example.com/catalog?item=12&desc=vacation_hawaii', 'Feed item 2 url is correct.');
$this
->assertEqual($node->feeds_node_item->url, $node->feeds_node_item->guid, 'Feed item 2 guid is correct.');
// Check third item.
$item = $items
->fetch();
$node = node_load($item->nid);
$this
->assertEqual($node->title, 'weekly', 'Feed item 3 changefreq is correct.');
$this
->assertEqual($node->body, '', 'Feed item 3 priority is correct.');
$this
->assertEqual($node->created, strtotime('2004-12-23'), 'Feed item 3 lastmod is correct.');
$this
->assertEqual($node->feeds_node_item->url, 'http://www.example.com/catalog?item=73&desc=vacation_new_zealand', 'Feed item 3 url is correct.');
$this
->assertEqual($node->feeds_node_item->url, $node->feeds_node_item->guid, 'Feed item 3 guid is correct.');
// Check fourth item.
$item = $items
->fetch();
$node = node_load($item->nid);
$this
->assertEqual($node->title, '', 'Feed item 4 changefreq is correct.');
$this
->assertEqual($node->body, '0.3', 'Feed item 4 priority is correct.');
$this
->assertEqual($node->created, strtotime('2004-12-23T18:00:15+00:00'), 'Feed item 4 lastmod is correct.');
$this
->assertEqual($node->feeds_node_item->url, 'http://www.example.com/catalog?item=74&desc=vacation_newfoundland', 'Feed item 4 url is correct.');
$this
->assertEqual($node->feeds_node_item->url, $node->feeds_node_item->guid, 'Feed item 1 guid is correct.');
// Check fifth item.
$item = $items
->fetch();
$node = node_load($item->nid);
$this
->assertEqual($node->title, '', 'Feed item 5 changefreq is correct.');
$this
->assertEqual($node->body, '', 'Feed item 5 priority is correct.');
$this
->assertEqual($node->created, strtotime('2004-11-23'), 'Feed item 5 lastmod is correct.');
$this
->assertEqual($node->feeds_node_item->url, 'http://www.example.com/catalog?item=83&desc=vacation_usa', 'Feed item 5 url is correct.');
$this
->assertEqual($node->feeds_node_item->url, $node->feeds_node_item->guid, 'Feed item 5 guid is correct.');
// Check for more items.
$item = $items
->fetch();
$this
->assertFalse($item, 'Correct number of feed items recorded.');
}
}
Classes
Name![]() |
Description |
---|---|
FeedsSitemapParserTestCase | Test Sitemap parser. |