popsu-d7/sites/all/modules/feeds/tests/feeds_mapper_link.test
2016-10-13 12:10:40 +02:00

355 lines
10 KiB
Plaintext

<?php
/**
* @file
* Contains FeedsMapperLinkTestCase.
*/
/**
* Test case for CCK link mapper mappers/date.inc.
*/
class FeedsMapperLinkTestCase extends FeedsMapperTestCase {
/**
* Title for link fields with a static title.
*
* @var string
*/
private $staticTitle;
/**
* Name of created content type.
*
* @var string
*/
private $contentType;
public static function getInfo() {
return array(
'name' => 'Mapper: Link',
'description' => 'Test Feeds Mapper support for Link fields.',
'group' => 'Feeds',
'dependencies' => array('link'),
);
}
public function setUp() {
parent::setUp(array('link'));
$this->staticTitle = $this->randomName();
// Create content type.
$this->contentType = $this->createContentType(array(), array(
'alpha' => array(
'type' => 'link_field',
'instance_settings' => array(
'instance[settings][title]' => 'required',
),
),
'beta' => array(
'type' => 'link_field',
'instance_settings' => array(
'instance[settings][title]' => 'none',
),
),
'gamma' => array(
'type' => 'link_field',
'instance_settings' => array(
'instance[settings][title]' => 'optional',
),
),
'omega' => array(
'type' => 'link_field',
'instance_settings' => array(
'instance[settings][title]' => 'value',
'instance[settings][title_value]' => $this->staticTitle,
),
),
));
}
/**
* Basic test loading a single entry CSV file.
*/
public function test() {
// Create importer configuration.
$this->createImporterConfiguration(); //Create a default importer configuration
$this->setSettings('syndication', 'FeedsNodeProcessor', array('bundle' => $this->contentType)); //Processor settings
$this->addMappings('syndication', array(
0 => array(
'source' => 'title',
'target' => 'title'
),
1 => array(
'source' => 'timestamp',
'target' => 'created'
),
2 => array(
'source' => 'description',
'target' => 'body'
),
3 => array(
'source' => 'url',
'target' => 'field_alpha:url'
),
4 => array(
'source' => 'title',
'target' => 'field_alpha:title'
),
5 => array(
'source' => 'url',
'target' => 'field_beta:url'
),
6 => array(
'source' => 'url',
'target' => 'field_gamma:url'
),
7 => array(
'source' => 'title',
'target' => 'field_gamma:title'
),
8 => array(
'source' => 'url',
'target' => 'field_omega:url'
),
));
// Import RSS file.
$nid = $this->createFeedNode();
// Assert 10 items aggregated after creation of the node.
$this->assertText('Created 10 nodes');
// Edit the imported node.
$this->drupalGet('node/2/edit');
$url = 'http://developmentseed.org/blog/2009/oct/06/open-atrium-translation-workflow-two-way-updating';
$title = 'Open Atrium Translation Workflow: Two Way Translation Updates';
$this->assertNodeFieldValue('alpha', array('url' => $url, 'static' => $title));
$this->assertNodeFieldValue('beta', array('url' => $url));
$this->assertNodeFieldValue('gamma', array('url' => $url, 'static' => $title));
$this->assertNodeFieldValue('omega', array('url' => $url, 'static' => $this->staticTitle));
// Test the static title.
$this->drupalGet('node/2');
$this->assertText($this->staticTitle, 'Static title link found.');
}
/**
* Tests if values are cleared out when an empty value or no value
* is provided.
*/
public function testClearOutValues() {
// 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' => $this->contentType,
'update_existing' => 1,
));
$this->addMappings('csv', array(
0 => array(
'source' => 'guid',
'target' => 'guid',
'unique' => TRUE,
),
1 => array(
'source' => 'title',
'target' => 'title'
),
2 => array(
'source' => 'url',
'target' => 'field_alpha:url'
),
3 => array(
'source' => 'link_title',
'target' => 'field_alpha:title'
),
4 => array(
'source' => 'url',
'target' => 'field_beta:url'
),
5 => array(
'source' => 'link_title',
'target' => 'field_beta:title'
),
6 => array(
'source' => 'url',
'target' => 'field_gamma:url'
),
7 => array(
'source' => 'link_title',
'target' => 'field_gamma:title'
),
8 => array(
'source' => 'url',
'target' => 'field_omega:url'
),
9 => array(
'source' => 'link_title',
'target' => 'field_omega:title'
),
));
// Import CSV file.
$this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_link.csv');
$this->assertText('Created 2 nodes');
// Check the imported nodes.
$link_values = array(
1 => array(
'title' => 'Feeds',
'url' => 'https://www.drupal.org/project/feeds',
),
2 => array(
'title' => 'Framework for expected behavior when importing empty/blank values',
'url' => 'https://www.drupal.org/node/1107522',
),
);
for ($i = 1; $i <= 2; $i++) {
$this->drupalGet("node/$i/edit");
$this->assertNodeFieldValue('alpha', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNodeFieldValue('beta', array(
'url' => $link_values[$i]['url'],
));
$this->assertNodeFieldValue('gamma', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNodeFieldValue('omega', array(
'url' => $link_values[$i]['url'],
));
// Test static title.
$this->drupalGet("node/$i");
$this->assertText($this->staticTitle, 'Static title link found.');
}
// 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('alpha', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNoNodeFieldValue('beta', array(
'url' => $link_values[$i]['url'],
));
$this->assertNoNodeFieldValue('gamma', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNoNodeFieldValue('omega', array(
'url' => $link_values[$i]['url'],
));
// Check labels.
$this->drupalGet('node/' . $i);
$this->assertNoText('alpha_link_field_label');
$this->assertNoText('beta_link_field_label');
$this->assertNoText('gamma_link_field_label');
$this->assertNoText('omega_link_field_label');
// Assert that the static title is no longer shown.
$this->assertNoText($this->staticTitle, 'Static title link not found.');
}
// Re-import the first file again and check if the values returned.
$this->importFile('csv', $this->absolutePath() . '/tests/feeds/content_link.csv');
$this->assertText('Updated 2 nodes');
for ($i = 1; $i <= 2; $i++) {
$this->drupalGet("node/$i/edit");
$this->assertNodeFieldValue('alpha', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNodeFieldValue('beta', array(
'url' => $link_values[$i]['url'],
));
$this->assertNodeFieldValue('gamma', array(
'url' => $link_values[$i]['url'],
'title' => $link_values[$i]['title'],
));
$this->assertNodeFieldValue('omega', array(
'url' => $link_values[$i]['url'],
));
}
// 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('alpha', array(
'url' => $link_values[1]['url'],
'title' => $link_values[1]['title'],
));
$this->assertNoNodeFieldValue('beta', array(
'url' => $link_values[1]['url'],
));
$this->assertNoNodeFieldValue('gamma', array(
'url' => $link_values[1]['url'],
'title' => $link_values[1]['title'],
));
$this->assertNoNodeFieldValue('omega', array(
'url' => $link_values[1]['url'],
));
$this->drupalGet('node/1');
$this->assertNoText('alpha_link_field_label');
$this->assertNoText('beta_link_field_label');
$this->assertNoText('gamma_link_field_label');
$this->assertNoText('omega_link_field_label');
// Assert that the static title is no longer shown.
$this->assertNoText($this->staticTitle, 'Static title link not found.');
}
/**
* Override parent::getFormFieldsNames().
*/
protected function getFormFieldsNames($field_name, $index) {
if (in_array($field_name, array('alpha', 'beta', 'gamma', 'omega'))) {
$fields = array("field_{$field_name}[und][{$index}][url]");
if (in_array($field_name, array('alpha', 'gamma'))) {
$fields[] = "field_{$field_name}[und][{$index}][title]";
}
return $fields;
}
else {
return parent::getFormFieldsNames($field_name, $index);
}
}
/**
* Override parent::getFormFieldsValues().
*/
protected function getFormFieldsValues($field_name, $value) {
if (in_array($field_name, array('alpha', 'beta', 'gamma', 'omega'))) {
if (!is_array($value)) {
$value = array('url' => $value);
}
$values = array($value['url']);
if (in_array($field_name, array('alpha', 'gamma'))) {
$values[] = isset($value['title']) ? $value['title'] : '';
}
return $values;
}
else {
return parent::getFormFieldsValues($field_name, $index);
}
}
}