You are here

feeds_mapper_field.test in Feeds 7.2

Contains FeedsMapperFieldTestCase.

File

tests/feeds_mapper_field.test
View source
<?php

/**
 * @file
 * Contains FeedsMapperFieldTestCase.
 */

/**
 * Test case for simple CCK field mapper mappers/content.inc.
 */
class FeedsMapperFieldTestCase extends FeedsMapperTestCase {

  /**
   * {@inheritdoc}
   */
  public static function getInfo() {
    return array(
      'name' => 'Mapper: Fields',
      'description' => 'Test Feeds Mapper support for fields.',
      'group' => 'Feeds',
    );
  }

  /**
   * {@inheritdoc}
   */
  public function setUp() {
    parent::setUp(array(
      'number',
    ));
  }

  /**
   * Basic test loading a double entry CSV file.
   */
  public function test() {

    // Create content type.
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => 'text',
      'beta' => 'number_integer',
      'gamma' => 'number_decimal',
      'delta' => 'number_float',
    ));

    // 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',
      ),
      1 => array(
        'source' => 'created',
        'target' => 'created',
      ),
      2 => array(
        'source' => 'body',
        'target' => 'body',
      ),
      3 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
      4 => array(
        'source' => 'beta',
        'target' => 'field_beta',
      ),
      5 => array(
        'source' => 'gamma',
        'target' => 'field_gamma',
      ),
      6 => array(
        'source' => 'delta',
        'target' => 'field_delta',
      ),
    ));

    // Import CSV file.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 2 nodes');

    // Check the two imported files.
    $this
      ->drupalGet('node/1/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Lorem');
    $this
      ->assertNodeFieldValue('beta', '42');
    $this
      ->assertNodeFieldValue('gamma', '4.20');
    $this
      ->assertNodeFieldValue('delta', '3.14159');
    $this
      ->drupalGet('node/2/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Ut wisi');
    $this
      ->assertNodeFieldValue('beta', '32');
    $this
      ->assertNodeFieldValue('gamma', '1.20');
    $this
      ->assertNodeFieldValue('delta', '5.62951');
  }

  /**
   * Tests if values are cleared out when an empty value is provided.
   */
  public function testClearOutValues() {

    // Create content type.
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => 'text',
      'beta' => 'number_integer',
      'gamma' => 'number_decimal',
      'delta' => 'number_float',
    ));

    // 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(
      array(
        'source' => 'guid',
        'target' => 'guid',
        'unique' => TRUE,
      ),
      array(
        'source' => 'title',
        'target' => 'title',
      ),
      array(
        'source' => 'created',
        'target' => 'created',
      ),
      array(
        'source' => 'body',
        'target' => 'body',
      ),
      array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
      array(
        'source' => 'beta',
        'target' => 'field_beta',
      ),
      array(
        'source' => 'gamma',
        'target' => 'field_gamma',
      ),
      array(
        'source' => 'delta',
        'target' => 'field_delta',
      ),
    ));

    // Import CSV file.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 2 nodes');

    // Check the two imported nodes.
    $this
      ->drupalGet('node/1/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Lorem');
    $this
      ->assertNodeFieldValue('beta', '42');
    $this
      ->assertNodeFieldValue('gamma', '4.20');
    $this
      ->assertNodeFieldValue('delta', '3.14159');
    $this
      ->assertFieldByName('body[und][0][value]', 'Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.');
    $this
      ->drupalGet('node/2/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Ut wisi');
    $this
      ->assertNodeFieldValue('beta', '32');
    $this
      ->assertNodeFieldValue('gamma', '1.20');
    $this
      ->assertNodeFieldValue('delta', '5.62951');
    $this
      ->assertFieldByName('body[und][0][value]', 'Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.');

    // 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 node 1.
    $this
      ->drupalGet('node/1/edit');
    $this
      ->assertNoNodeFieldValue('alpha', 'Lorem');
    $this
      ->assertNoNodeFieldValue('beta', '42');
    $this
      ->assertNoNodeFieldValue('gamma', '4.20');
    $this
      ->assertNoNodeFieldValue('delta', '3.14159');
    $this
      ->assertFieldByName('body[und][0][value]', '');

    // Check if labels for fields that should be cleared out are not shown.
    $this
      ->drupalGet('node/1');
    $this
      ->assertNoText('alpha_text_label');
    $this
      ->assertNoText('beta_number_integer_label');
    $this
      ->assertNoText('gamma_number_decimal_label');
    $this
      ->assertNoText('delta_number_float_label');

    // Check if zero's didn't cleared out values for node 2.
    $this
      ->drupalGet('node/2/edit');
    $this
      ->assertNodeFieldValue('alpha', 0);
    $this
      ->assertNodeFieldValue('beta', 0);
    $this
      ->assertNodeFieldValue('gamma', 0);
    $this
      ->assertNodeFieldValue('delta', 0);
    $this
      ->assertFieldByName('body[und][0][value]', 0);

    // Check if labels for fields of node 2 are still shown.
    $this
      ->drupalGet('node/2');
    $this
      ->assertText('alpha_text_label');
    $this
      ->assertText('beta_number_integer_label');
    $this
      ->assertText('gamma_number_decimal_label');
    $this
      ->assertText('delta_number_float_label');

    // Re-import the first file again.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Updated 2 nodes');

    // Check if the two imported nodes have content again.
    $this
      ->drupalGet('node/1/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Lorem');
    $this
      ->assertNodeFieldValue('beta', '42');
    $this
      ->assertNodeFieldValue('gamma', '4.20');
    $this
      ->assertNodeFieldValue('delta', '3.14159');
    $this
      ->assertFieldByName('body[und][0][value]', 'Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.');
    $this
      ->drupalGet('node/2/edit');
    $this
      ->assertNodeFieldValue('alpha', 'Ut wisi');
    $this
      ->assertNodeFieldValue('beta', '32');
    $this
      ->assertNodeFieldValue('gamma', '1.20');
    $this
      ->assertNodeFieldValue('delta', '5.62951');
    $this
      ->assertFieldByName('body[und][0][value]', 'Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.');

    // 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', 'Lorem');
    $this
      ->assertNoNodeFieldValue('beta', '42');
    $this
      ->assertNoNodeFieldValue('gamma', '4.20');
    $this
      ->assertNoNodeFieldValue('delta', '3.14159');
    $this
      ->assertFieldByName('body[und][0][value]', '');

    // Check if labels for fields that should be cleared out are not shown.
    $this
      ->drupalGet('node/1');
    $this
      ->assertNoText('alpha_text_label');
    $this
      ->assertNoText('beta_number_integer_label');
    $this
      ->assertNoText('gamma_number_decimal_label');
    $this
      ->assertNoText('delta_number_float_label');
  }

  /**
   * Tests text field validation.
   */
  public function testTextFieldValidation() {

    // Create a field with settings to validate.
    $max_length = 5;
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => array(
        'type' => 'text',
        'settings' => array(
          'field[settings][max_length]' => $max_length,
        ),
      ),
    ));

    // 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',
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
    ));

    // Import CSV file.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 1 node');
    $this
      ->assertText('Failed importing 1 node.');
    $this
      ->assertText("Field validation errors in item 'Ut wisi enim ad minim veniam'");
    $this
      ->assertText('alpha_text_label: the text may not be longer than 5 characters.');
  }

  /**
   * Tests integer field validation.
   */
  public function testIntegerFieldValidation() {

    // Create content type with a field with settings to validate.
    $typename = $this
      ->createContentType(array(), array(
      'beta' => array(
        'type' => 'number_integer',
        'instance_settings' => array(
          'instance[settings][min]' => 30,
          'instance[settings][max]' => 40,
        ),
      ),
    ));

    // Create and configure importer.
    $this
      ->createImporterConfiguration('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',
      ),
      1 => array(
        'source' => 'beta',
        'target' => 'field_beta',
      ),
    ));
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 1 node');
    $this
      ->assertText('Failed importing 1 node.');
    $this
      ->assertText("Field validation errors in item 'Lorem ipsum'");
    $this
      ->assertText('beta_number_integer_label: the value may be no greater than 40.');
  }

  /**
   * Tests text field validation for nodes without a title.
   *
   * The error message should refer the GUID of an item if the entity has no
   * label.
   */
  public function testTextFieldValidationWithoutNodeTitle() {

    // Create a field with settings to validate.
    $max_length = 5;
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => array(
        'type' => 'text',
        'settings' => array(
          'field[settings][max_length]' => $max_length,
        ),
      ),
    ));

    // 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' => 'guid',
        'target' => 'guid',
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
    ));

    // Import CSV file.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 1 node');
    $this
      ->assertText('Failed importing 1 node.');
    $this
      ->assertText("Field validation errors in item '2'");
    $this
      ->assertText('alpha_text_label: the text may not be longer than 5 characters.');
  }

  /**
   * Tests text field validation for taxonomy terms.
   */
  public function testTextFieldValidationForTaxonomyTerms() {

    // Create vocabulary.
    $edit = array(
      'name' => 'Addams vocabulary',
      'machine_name' => 'addams',
    );
    $this
      ->drupalPost('admin/structure/taxonomy/add', $edit, t('Save'));

    // Create a field with settings to validate.
    field_create_field(array(
      'field_name' => 'field_alpha',
      'type' => 'text',
      'settings' => array(
        'max_length' => 5,
      ),
    ));
    field_create_instance(array(
      'field_name' => 'field_alpha',
      'entity_type' => 'taxonomy_term',
      'label' => 'alpha_text_label',
      'bundle' => 'addams',
      'widget' => array(
        'type' => 'text_textfield',
      ),
    ));

    // 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
      ->setPlugin('csv', 'FeedsTermProcessor');
    $this
      ->setSettings('csv', 'FeedsTermProcessor', array(
      'bundle' => 'addams',
    ));
    $this
      ->addMappings('csv', array(
      0 => array(
        'source' => 'title',
        'target' => 'name',
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
    ));

    // Import CSV file.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Created 1 taxonomy term.');
    $this
      ->assertText('Failed importing 1 taxonomy term.');
    $this
      ->assertText("Field validation errors in item 'Ut wisi enim ad minim veniam'");
    $this
      ->assertText('alpha_text_label: the text may not be longer than 5 characters.');
  }

  /**
   * Tests text field validation for users.
   */
  public function testTextFieldValidationForUsers() {

    // Create a field with settings to validate.
    field_create_field(array(
      'field_name' => 'field_alpha',
      'type' => 'text',
      'settings' => array(
        'max_length' => 5,
      ),
    ));
    field_create_instance(array(
      'field_name' => 'field_alpha',
      'entity_type' => 'user',
      'label' => 'alpha_text_label',
      'bundle' => 'user',
      'widget' => array(
        'type' => 'text_textfield',
      ),
    ));

    // 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
      ->setPlugin('csv', 'FeedsUserProcessor');
    $this
      ->addMappings('csv', array(
      0 => array(
        'source' => 'title',
        'target' => 'name',
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
    ));

    // Import CSV file. Users should fail to import because mail address is
    // missing.
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Failed importing 2 users.');
    $this
      ->assertText('User name missing or email not valid.');
    $this
      ->assertText("Field validation errors in item 'Ut wisi enim ad minim veniam'");
    $this
      ->assertText('alpha_text_label: the text may not be longer than 5 characters.');
  }

  /**
   * Tests cardinality validation.
   */
  public function testCardinalityValidation() {

    // Create a field with settings to validate.
    $cardinality = 6;
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => array(
        'type' => 'text',
        'instance_settings' => array(
          'field[cardinality]' => $cardinality,
        ),
      ),
    ));

    // Create and configure importer.
    $this
      ->createImporterConfiguration('Syndication', 'syndication');
    $this
      ->setSettings('syndication', NULL, array(
      'content_type' => '',
      'import_period' => FEEDS_SCHEDULE_NEVER,
    ));
    $this
      ->setPlugin('syndication', 'FeedsHTTPFetcher');
    $this
      ->setPlugin('syndication', 'FeedsSyndicationParser');
    $this
      ->setSettings('syndication', 'FeedsNodeProcessor', array(
      'bundle' => $typename,
    ));
    $this
      ->addMappings('syndication', array(
      0 => array(
        'source' => 'title',
        'target' => 'title',
      ),
      1 => array(
        'source' => 'tags',
        'target' => 'field_alpha',
      ),
    ));

    // Import RSS.
    // Three items of the RSS contain more than 6 categories. Because categories
    // are mapped to field_alpha and field_alpha may only hold 6 values, they
    // should fail to import.
    $edit = array(
      'feeds[FeedsHTTPFetcher][source]' => $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'feeds') . '/tests/feeds/developmentseed.rss2',
    );
    $this
      ->drupalPost('import/syndication', $edit, 'Import');
    $this
      ->assertText('Created 7 nodes');
    $this
      ->assertText('Failed importing 3 nodes.');
    $this
      ->assertText("Field validation errors in item 'Open Atrium Translation Workflow: Two Way Translation Updates'");
    $this
      ->assertText("Field validation errors in item 'Mapping Innovation at the World Bank with Open Atrium'");
    $this
      ->assertText("Field validation errors in item 'Open Data for Microfinance: The New MIXMarket.org'");
    $this
      ->assertText('alpha_text_label: this field cannot hold more than 6 values.');
  }

  /**
   * Tests that Feeds ignores validation of fields not mapped to.
   */
  public function testIgnoreUnmappedFieldsValidation() {

    // Include FeedsProcessor.inc so processor related constants are available.
    module_load_include('inc', 'feeds', 'plugins/FeedsProcessor');

    // Create content type with a field with settings to validate.
    $typename = $this
      ->createContentType(array(), array(
      'alpha' => 'text',
      'beta' => array(
        'type' => 'number_integer',
        'instance_settings' => array(
          'instance[settings][min]' => 30,
          'instance[settings][max]' => 50,
        ),
      ),
    ));

    // Create a node of this type with an out of range integer value.
    $this
      ->drupalCreateNode(array(
      'type' => $typename,
      'title' => 'Lorem ipsum',
      'field_beta' => array(
        LANGUAGE_NONE => array(
          0 => array(
            'value' => 25,
          ),
        ),
      ),
    ));

    // Create and configure importer.
    $this
      ->createImporterConfiguration('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' => FEEDS_UPDATE_EXISTING,
    ));
    $this
      ->addMappings('csv', array(
      0 => array(
        'source' => 'title',
        'target' => 'title',
        'unique' => TRUE,
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha',
      ),
    ));
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Updated 1 node');
    $this
      ->assertNoText('Field validation errors');
  }

}

Classes

Namesort descending Description
FeedsMapperFieldTestCase Test case for simple CCK field mapper mappers/content.inc.