You are here

FieldImportCreateTest.php in Zircon Profile 8.0

Same filename and directory in other branches
  1. 8 core/modules/field/src/Tests/FieldImportCreateTest.php

Namespace

Drupal\field\Tests

File

core/modules/field/src/Tests/FieldImportCreateTest.php
View source
<?php

/**
 * @file
 * Contains \Drupal\field\Tests\FieldImportCreateTest.
 */
namespace Drupal\field\Tests;

use Drupal\field\Entity\FieldConfig;
use Drupal\field\Entity\FieldStorageConfig;

/**
 * Create field storages and fields during config create method invocation.
 *
 * @group field
 */
class FieldImportCreateTest extends FieldUnitTestBase {

  /**
   * Tests creating field storages and fields during default config import.
   */
  function testImportCreateDefault() {
    $field_name = 'field_test_import';
    $field_storage_id = "entity_test.{$field_name}";
    $field_id = "entity_test.entity_test.{$field_name}";
    $field_name_2 = 'field_test_import_2';
    $field_storage_id_2 = "entity_test.{$field_name_2}";
    $field_id_2a = "entity_test.entity_test.{$field_name_2}";
    $field_id_2b = "entity_test.test_bundle.{$field_name_2}";

    // Check that the field storages and fields do not exist yet.
    $this
      ->assertFalse(FieldStorageConfig::load($field_storage_id));
    $this
      ->assertFalse(FieldConfig::load($field_id));
    $this
      ->assertFalse(FieldStorageConfig::load($field_storage_id_2));
    $this
      ->assertFalse(FieldConfig::load($field_id_2a));
    $this
      ->assertFalse(FieldConfig::load($field_id_2b));

    // Create a second bundle for the 'Entity test' entity type.
    entity_test_create_bundle('test_bundle');

    // Enable field_test_config module and check that the field and storage
    // shipped in the module's default config were created.
    \Drupal::service('module_installer')
      ->install(array(
      'field_test_config',
    ));

    // A field storage with one single field.
    $field_storage = FieldStorageConfig::load($field_storage_id);
    $this
      ->assertTrue($field_storage, 'The field was created.');
    $field = FieldConfig::load($field_id);
    $this
      ->assertTrue($field, 'The field was deleted.');

    // A field storage with two fields.
    $field_storage_2 = FieldStorageConfig::load($field_storage_id_2);
    $this
      ->assertTrue($field_storage_2, 'The second field was created.');
    $this
      ->assertTrue($field
      ->getTargetBundle(), 'test_bundle', 'The second field was created on bundle test_bundle.');
    $this
      ->assertTrue($field
      ->getTargetBundle(), 'test_bundle_2', 'The second field was created on bundle test_bundle_2.');

    // Tests fields.
    $ids = \Drupal::entityQuery('field_config')
      ->condition('entity_type', 'entity_test')
      ->condition('bundle', 'entity_test')
      ->execute();
    $this
      ->assertEqual(count($ids), 2);
    $this
      ->assertTrue(isset($ids['entity_test.entity_test.field_test_import']));
    $this
      ->assertTrue(isset($ids['entity_test.entity_test.field_test_import_2']));
    $ids = \Drupal::entityQuery('field_config')
      ->condition('entity_type', 'entity_test')
      ->condition('bundle', 'test_bundle')
      ->execute();
    $this
      ->assertEqual(count($ids), 1);
    $this
      ->assertTrue(isset($ids['entity_test.test_bundle.field_test_import_2']));
  }

  /**
   * Tests creating field storages and fields during config import.
   */
  function testImportCreate() {

    // A field storage with one single field.
    $field_name = 'field_test_import_sync';
    $field_storage_id = "entity_test.{$field_name}";
    $field_id = "entity_test.entity_test.{$field_name}";
    $field_storage_config_name = "field.storage.{$field_storage_id}";
    $field_config_name = "field.field.{$field_id}";

    // A field storage with two fields.
    $field_name_2 = 'field_test_import_sync_2';
    $field_storage_id_2 = "entity_test.{$field_name_2}";
    $field_id_2a = "entity_test.test_bundle.{$field_name_2}";
    $field_id_2b = "entity_test.test_bundle_2.{$field_name_2}";
    $field_storage_config_name_2 = "field.storage.{$field_storage_id_2}";
    $field_config_name_2a = "field.field.{$field_id_2a}";
    $field_config_name_2b = "field.field.{$field_id_2b}";
    $active = $this->container
      ->get('config.storage');
    $sync = $this->container
      ->get('config.storage.sync');
    $this
      ->copyConfig($active, $sync);

    // Add the new files to the sync directory.
    $src_dir = drupal_get_path('module', 'field_test_config') . '/sync';
    $target_dir = $this->configDirectories[CONFIG_SYNC_DIRECTORY];
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$field_storage_config_name}.yml", "{$target_dir}/{$field_storage_config_name}.yml"));
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$field_config_name}.yml", "{$target_dir}/{$field_config_name}.yml"));
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$field_storage_config_name_2}.yml", "{$target_dir}/{$field_storage_config_name_2}.yml"));
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$field_config_name_2a}.yml", "{$target_dir}/{$field_config_name_2a}.yml"));
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$field_config_name_2b}.yml", "{$target_dir}/{$field_config_name_2b}.yml"));

    // Import the content of the sync directory.
    $this
      ->configImporter()
      ->import();

    // Check that the field and storage were created.
    $field_storage = FieldStorageConfig::load($field_storage_id);
    $this
      ->assertTrue($field_storage, 'Test import storage field from sync exists');
    $field = FieldConfig::load($field_id);
    $this
      ->assertTrue($field, 'Test import field  from sync exists');
    $field_storage = FieldStorageConfig::load($field_storage_id_2);
    $this
      ->assertTrue($field_storage, 'Test import storage field 2 from sync exists');
    $field = FieldConfig::load($field_id_2a);
    $this
      ->assertTrue($field, 'Test import field 2a from sync exists');
    $field = FieldConfig::load($field_id_2b);
    $this
      ->assertTrue($field, 'Test import field 2b from sync exists');
  }

}

Classes

Namesort descending Description
FieldImportCreateTest Create field storages and fields during config create method invocation.