'Mapper: Date', 'description' => 'Test Feeds Mapper support for CCK Date fields.', 'group' => 'Feeds', 'dependencies' => array('date'), ); } public function setUp() { parent::setUp(array('date_api', 'date')); variable_set('date_default_timezone', 'UTC'); } /** * Basic test loading a single entry CSV file. */ public function test() { $this->drupalGet('admin/config/regional/settings'); // Create content type. $typename = $this->createContentType(array(), array( 'date' => 'date', 'datestamp' => 'datestamp', //'datetime' => 'datetime', // REMOVED because the field is broken ATM. )); // Hack to get date fields to not round to every 15 minutes. foreach (array('date', 'datestamp') as $field) { $field = 'field_' . $field; $edit = array( 'widget_type' => 'date_select', ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field . '/widget-type', $edit, 'Continue'); $edit = array( 'instance[widget][settings][increment]' => 1, ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field, $edit, 'Save settings'); $edit = array( 'widget_type' => 'date_text', ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field . '/widget-type', $edit, 'Continue'); } // Create and configure importer. $this->createImporterConfiguration('Date RSS', 'daterss'); $this->setSettings('daterss', NULL, array( 'content_type' => '', 'import_period' => FEEDS_SCHEDULE_NEVER, )); $this->setPlugin('daterss', 'FeedsFileFetcher'); $this->setSettings('daterss', 'FeedsNodeProcessor', array( 'bundle' => $typename, )); $this->addMappings('daterss', array( 0 => array( 'source' => 'title', 'target' => 'title', ), 1 => array( 'source' => 'description', 'target' => 'body', ), 2 => array( 'source' => 'timestamp', 'target' => 'field_date:start', ), 3 => array( 'source' => 'timestamp', 'target' => 'field_datestamp:start', ), )); $edit = array( 'allowed_extensions' => 'rss2', ); $this->drupalPost('admin/structure/feeds/daterss/settings/FeedsFileFetcher', $edit, 'Save'); // Import CSV file. $this->importFile('daterss', $this->absolutePath() . '/tests/feeds/googlenewstz.rss2'); $this->assertText('Created 6 nodes'); // Check the imported nodes. $values = array( '01/06/2010 - 19:26', '01/06/2010 - 10:21', '01/06/2010 - 13:42', '01/06/2010 - 06:05', '01/06/2010 - 11:26', '01/07/2010 - 00:26', ); for ($i = 1; $i <= 6; $i++) { $this->drupalGet("node/$i/edit"); $this->assertNodeFieldValue('date', $values[$i-1]); $this->assertNodeFieldValue('datestamp', $values[$i-1]); } } protected function getFormFieldsNames($field_name, $index) { if (in_array($field_name, array('date', 'datetime', 'datestamp'))) { return array("field_{$field_name}[und][{$index}][value][date]"); } else { return parent::getFormFieldsNames($field_name, $index); } } /** * Tests if values are cleared out when an empty value is provided. */ public function testClearOutValues() { // Create content type. $typename = $this->createContentType(array(), array( 'date' => 'date', 'datestamp' => 'datestamp', 'datetime' => 'datetime', )); // Hack to get date fields to not round to every 15 minutes. foreach (array('date', 'datestamp', 'datetime') as $field) { $field = 'field_' . $field; $edit = array( 'widget_type' => 'date_select', ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field . '/widget-type', $edit, 'Continue'); $edit = array( 'instance[widget][settings][increment]' => 1, 'field[settings][enddate_get]' => 1, ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field, $edit, 'Save settings'); $edit = array( 'widget_type' => 'date_text', ); $this->drupalPost('admin/structure/types/manage/' . $typename . '/fields/' . $field . '/widget-type', $edit, 'Continue'); } // Create and configure importer. $this->createImporterConfiguration('Content CSV', 'csv'); $this->setSettings('csv', NULL, array( 'content_type' => '', 'import_period' => FEEDS_SCHEDULE_NEVER, )); $this->setPlugin('csv', 'FeedsFileFetcher'); $this->setPlugin('csv', 'FeedsCSVParser'); $this->setSettings('csv', 'FeedsNodeProcessor', array( 'bundle' => $typename, 'update_existing' => 1, )); $this->addMappings('csv', array( 0 => array( 'source' => 'title', 'target' => 'title', 'unique' => TRUE, ), 1 => array( 'source' => 'created', 'target' => 'field_date:start', ), 2 => array( 'source' => 'end', 'target' => 'field_date:end', ), 3 => array( 'source' => 'created', 'target' => 'field_datestamp:start', ), 4 => array( 'source' => 'end', 'target' => 'field_datestamp:end', ), 5 => array( 'source' => 'created', 'target' => 'field_datetime:start', ), 6 => array( 'source' => 'end', 'target' => 'field_datetime:end', ), )); // Import CSV file. $this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_date.csv'); $this->assertText('Created 2 nodes'); // Check the imported nodes. $date_values = array( 1 => array( 'created' => '09/03/2009 - 00:12', 'end' => '11/03/2012 - 09:58', ), 2 => array( 'created' => '09/02/2009 - 22:59', 'end' => '11/03/2012 - 08:46', ), ); for ($i = 1; $i <= 2; $i++) { $this->drupalGet("node/$i/edit"); $this->assertNodeFieldValue('date', $date_values[$i]['created']); $this->assertFieldByName('field_date[und][0][value2][date]', $date_values[$i]['end']); $this->assertNodeFieldValue('datestamp', $date_values[$i]['created']); $this->assertFieldByName('field_datestamp[und][0][value2][date]', $date_values[$i]['end']); $this->assertNodeFieldValue('datetime', $date_values[$i]['created']); $this->assertFieldByName('field_datetime[und][0][value2][date]', $date_values[$i]['end']); } // Import CSV file with empty values. $this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_empty.csv'); $this->assertText('Updated 2 nodes'); // Check if all values were cleared out for both nodes. for ($i = 1; $i <= 2; $i++) { $this->drupalGet("node/$i/edit"); $this->assertNoNodeFieldValue('date', $date_values[$i]['created']); $this->assertNoFieldByName('field_date[und][0][value2][date]', $date_values[$i]['end']); $this->assertNoNodeFieldValue('datestamp', $date_values[$i]['created']); $this->assertNoFieldByName('field_datestamp[und][0][value2][date]', $date_values[$i]['end']); $this->assertNoNodeFieldValue('datetime', $date_values[$i]['created']); $this->assertNoFieldByName('field_datetime[und][0][value2][date]', $date_values[$i]['end']); $this->drupalGet("node/$i"); $this->assertNoText('date_label'); $this->assertNoText('datestamp_label'); $this->assertNoText('datetime_label'); } // Re-import the first file again and check if the values returned. $this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_date.csv'); $this->assertText('Updated 2 nodes'); for ($i = 1; $i <= 2; $i++) { $this->drupalGet("node/$i/edit"); $this->assertNodeFieldValue('date', $date_values[$i]['created']); $this->assertFieldByName('field_date[und][0][value2][date]', $date_values[$i]['end']); $this->assertNodeFieldValue('datestamp', $date_values[$i]['created']); $this->assertFieldByName('field_datestamp[und][0][value2][date]', $date_values[$i]['end']); $this->assertNodeFieldValue('datetime', $date_values[$i]['created']); $this->assertFieldByName('field_datetime[und][0][value2][date]', $date_values[$i]['end']); } // Import CSV file with non-existent values. $this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_non_existent.csv'); $this->assertText('Updated 2 nodes'); // Check if all values were cleared out for node 1. $this->drupalGet('node/1/edit'); $this->assertNoNodeFieldValue('date', $date_values[1]['created']); $this->assertNoFieldByName('field_date[und][0][value2][date]', $date_values[1]['end']); $this->assertNoNodeFieldValue('datestamp', $date_values[1]['created']); $this->assertNoFieldByName('field_datestamp[und][0][value2][date]', $date_values[1]['end']); $this->assertNoNodeFieldValue('datetime', $date_values[1]['created']); $this->assertNoFieldByName('field_datetime[und][0][value2][date]', $date_values[1]['end']); // Check if labels for fields that should be cleared out are not shown. $this->drupalGet('node/1'); $this->assertNoText('date_label'); $this->assertNoText('datestamp_label'); $this->assertNoText('datetime_label'); } }