You are here

feeds_mapper_link.test in Feeds 7.2

Same filename and directory in other branches
  1. 6 tests/feeds_mapper_link.test
  2. 7 tests/feeds_mapper_link.test

Contains FeedsMapperLinkTestCase.

File

tests/feeds_mapper_link.test
View source
<?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;

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

  /**
   * {@inheritdoc}
   */
  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.
    // Create a default importer configuration.
    $this
      ->createImporterConfiguration();

    // Processor settings.
    $this
      ->setSettings('syndication', 'FeedsNodeProcessor', array(
      'bundle' => $this->contentType,
    ));
    $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.');
  }

  /**
   * Tests link field validation.
   */
  public function testLinkFieldValidation() {

    // 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' => $this->contentType,
    ));
    $this
      ->addMappings('csv', array(
      0 => array(
        'source' => 'title',
        'target' => 'title',
      ),
      1 => array(
        'source' => 'alpha',
        'target' => 'field_alpha:title',
      ),
      2 => array(
        'source' => 'alpha',
        'target' => 'field_alpha:url',
      ),
    ));
    $this
      ->importFile('csv', $this
      ->absolutePath() . '/tests/feeds/content.csv');
    $this
      ->assertText('Failed importing 1 node.');
    $this
      ->assertText("Field validation errors in item 'Ut wisi enim ad minim veniam'");
    $this
      ->assertText('The value Ut wisi provided for alpha_link_field_label is not a valid URL.');
  }

  /**
   * 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);
    }
  }

}

Classes

Namesort descending Description
FeedsMapperLinkTestCase Test case for CCK link mapper mappers/date.inc.