You are here

MigrateFieldTest.php in Zircon Profile 8

File

core/modules/field/src/Tests/Migrate/d7/MigrateFieldTest.php
View source
<?php

/**
 * @file
 * Contains \Drupal\field\Tests\Migrate\d7\MigrateFieldTest.
 */
namespace Drupal\field\Tests\Migrate\d7;

use Drupal\field\Entity\FieldStorageConfig;
use Drupal\field\FieldStorageConfigInterface;
use Drupal\migrate\Entity\Migration;
use Drupal\migrate_drupal\Tests\d7\MigrateDrupal7TestBase;

/**
 * Migrates Drupal 7 fields.
 *
 * @group field
 */
class MigrateFieldTest extends MigrateDrupal7TestBase {

  /**
   * The modules to be enabled during the test.
   *
   * @var array
   */
  static $modules = array(
    'comment',
    'datetime',
    'file',
    'image',
    'link',
    'node',
    'system',
    'taxonomy',
    'telephone',
    'text',
  );

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $this
      ->installConfig(static::$modules);
    $this
      ->executeMigration('d7_field');
  }

  /**
   * Asserts various aspects of a field_storage_config entity.
   *
   * @param string $id
   *   The entity ID in the form ENTITY_TYPE.FIELD_NAME.
   * @param string $expected_type
   *   The expected field type.
   * @param boolean $expected_translatable
   *   Whether or not the field is expected to be translatable.
   * @param integer $expected_cardinality
   *   The expected cardinality of the field.
   */
  protected function assertEntity($id, $expected_type, $expected_translatable, $expected_cardinality) {
    list($expected_entity_type, $expected_name) = explode('.', $id);

    /** @var \Drupal\field\FieldStorageConfigInterface $field */
    $field = FieldStorageConfig::load($id);
    $this
      ->assertTrue($field instanceof FieldStorageConfigInterface);
    $this
      ->assertIdentical($expected_name, $field
      ->getName());
    $this
      ->assertIdentical($expected_type, $field
      ->getType());

    // FieldStorageConfig::$translatable is TRUE by default, so it is useful
    // to test for FALSE here.
    $this
      ->assertEqual($expected_translatable, $field
      ->isTranslatable());
    $this
      ->assertIdentical($expected_entity_type, $field
      ->getTargetEntityTypeId());
    if ($expected_cardinality === 1) {
      $this
        ->assertFalse($field
        ->isMultiple());
    }
    else {
      $this
        ->assertTrue($field
        ->isMultiple());
    }
    $this
      ->assertIdentical($expected_cardinality, $field
      ->getCardinality());
  }

  /**
   * Tests migrating D7 fields to field_storage_config entities.
   */
  public function testFields() {
    $this
      ->assertEntity('node.body', 'text_with_summary', FALSE, 1);
    $this
      ->assertEntity('node.field_long_text', 'text_with_summary', FALSE, 1);
    $this
      ->assertEntity('comment.comment_body', 'text_long', FALSE, 1);
    $this
      ->assertEntity('node.field_file', 'file', FALSE, 1);
    $this
      ->assertEntity('user.field_file', 'file', FALSE, 1);
    $this
      ->assertEntity('node.field_float', 'float', FALSE, 1);
    $this
      ->assertEntity('node.field_image', 'image', FALSE, 1);
    $this
      ->assertEntity('node.field_images', 'image', FALSE, 1);
    $this
      ->assertEntity('node.field_integer', 'integer', FALSE, 1);
    $this
      ->assertEntity('comment.field_integer', 'integer', FALSE, 1);
    $this
      ->assertEntity('node.field_integer_list', 'list_integer', FALSE, 1);
    $this
      ->assertEntity('node.field_link', 'link', FALSE, 1);
    $this
      ->assertEntity('node.field_tags', 'entity_reference', FALSE, -1);
    $this
      ->assertEntity('node.field_term_reference', 'entity_reference', FALSE, 1);
    $this
      ->assertEntity('node.taxonomy_forums', 'entity_reference', FALSE, 1);
    $this
      ->assertEntity('node.field_text', 'text', FALSE, 1);
    $this
      ->assertEntity('node.field_text_list', 'list_string', FALSE, 3);
    $this
      ->assertEntity('node.field_boolean', 'boolean', FALSE, 1);
    $this
      ->assertEntity('node.field_email', 'email', FALSE, -1);
    $this
      ->assertEntity('node.field_phone', 'telephone', FALSE, 1);
    $this
      ->assertEntity('node.field_date', 'datetime', FALSE, 1);
    $this
      ->assertEntity('node.field_date_with_end_time', 'datetime', FALSE, 1);

    // Assert that the taxonomy term reference fields are referencing the
    // correct entity type.
    $field = FieldStorageConfig::load('node.field_term_reference');
    $this
      ->assertIdentical('taxonomy_term', $field
      ->getSetting('target_type'));
    $field = FieldStorageConfig::load('node.taxonomy_forums');
    $this
      ->assertIdentical('taxonomy_term', $field
      ->getSetting('target_type'));

    // Validate that the source count and processed count match up.

    /** @var \Drupal\migrate\Entity\MigrationInterface $migration */
    $migration = Migration::load('d7_field');
    $this
      ->assertIdentical($migration
      ->getSourcePlugin()
      ->count(), $migration
      ->getIdMap()
      ->processedCount());
  }

}

Classes

Namesort descending Description
MigrateFieldTest Migrates Drupal 7 fields.