public function FeedsMapperDateTestCase::testTimezoneMappingOption in Feeds 7.2
Tests importing dates using the timezone mapping option.
File
- tests/
feeds_mapper_date.test, line 140 - Contains FeedsMapperDateTestCase.
Class
- FeedsMapperDateTestCase
- Test case for CCK date field mapper mappers/date.inc.
Code
public function testTimezoneMappingOption() {
// 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,
'instance[settings][default_value]' => 'blank',
);
$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,
));
$this
->addMappings('csv', array(
0 => array(
'source' => 'title',
'target' => 'title',
'unique' => TRUE,
),
// Los Angeles == UTC-08:00.
1 => array(
'source' => 'datetime_start',
'target' => 'field_date:start',
'timezone' => 'America/Los_Angeles',
),
2 => array(
'source' => 'datetime_end',
'target' => 'field_date:end',
'timezone' => 'America/Los_Angeles',
),
// Amsterdam == UTC+01:00.
3 => array(
'source' => 'datetime_start',
'target' => 'field_datestamp:start',
'timezone' => 'Europe/Amsterdam',
),
4 => array(
'source' => 'datetime_end',
'target' => 'field_datestamp:end',
'timezone' => 'Europe/Amsterdam',
),
// Sydney == UTC+10:00.
5 => array(
'source' => 'datetime_start',
'target' => 'field_datetime:start',
'timezone' => 'Australia/Sydney',
),
6 => array(
'source' => 'datetime_end',
'target' => 'field_datetime:end',
'timezone' => 'Australia/Sydney',
),
));
// Import CSV file.
$this
->importFile('csv', $this
->absolutePath() . '/tests/feeds/content_date.csv');
$this
->assertText('Created 3 nodes');
// Check the imported nodes.
$date_values = array(
// Wintertime.
// (Hear me calling).
1 => array(
'field_date_start' => '11/05/1955 - 20:00',
'field_date_end' => '11/05/1955 - 23:00',
'field_datestamp_start' => '11/05/1955 - 11:00',
'field_datestamp_end' => '11/05/1955 - 14:00',
'field_datetime_start' => '11/05/1955 - 02:00',
'field_datetime_end' => '11/05/1955 - 05:00',
),
// Summertime =+0100.
// (Dee dee dee).
2 => array(
'field_date_start' => '10/22/2015 - 06:29',
'field_date_end' => '10/22/2015 - 09:29',
'field_datestamp_start' => '10/21/2015 - 21:29',
'field_datestamp_end' => '10/22/2015 - 00:29',
'field_datetime_start' => '10/21/2015 - 12:29',
'field_datetime_end' => '10/21/2015 - 15:29',
),
// Timezone is specified in string, all UTC time.
3 => array(
'field_date_start' => '02/09/2018 - 00:00',
'field_date_end' => '02/10/2018 - 22:00',
'field_datestamp_start' => '02/09/2018 - 00:00',
'field_datestamp_end' => '02/10/2018 - 22:00',
'field_datetime_start' => '02/09/2018 - 00:00',
'field_datetime_end' => '02/10/2018 - 22:00',
),
);
for ($i = 1; $i <= 3; $i++) {
$this
->drupalGet("node/{$i}/edit");
$this
->assertFieldByName('field_date[und][0][value][date]', $date_values[$i]['field_date_start']);
$this
->assertFieldByName('field_date[und][0][value2][date]', $date_values[$i]['field_date_end']);
$this
->assertFieldByName('field_datestamp[und][0][value][date]', $date_values[$i]['field_datestamp_start']);
$this
->assertFieldByName('field_datestamp[und][0][value2][date]', $date_values[$i]['field_datestamp_end']);
$this
->assertFieldByName('field_datetime[und][0][value][date]', $date_values[$i]['field_datetime_start']);
$this
->assertFieldByName('field_datetime[und][0][value2][date]', $date_values[$i]['field_datetime_end']);
}
}