You are here

public function FieldImportDeleteUninstallTest::testImportDeleteUninstall in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 core/modules/field/src/Tests/FieldImportDeleteUninstallTest.php \Drupal\field\Tests\FieldImportDeleteUninstallTest::testImportDeleteUninstall()

Tests deleting field storages and fields as part of config import.

File

core/modules/field/src/Tests/FieldImportDeleteUninstallTest.php, line 38
Contains \Drupal\field\Tests\FieldImportDeleteUninstallTest.

Class

FieldImportDeleteUninstallTest
Delete field storages and fields during config synchronization and uninstall module that provides the field type.

Namespace

Drupal\field\Tests

Code

public function testImportDeleteUninstall() {

  // Create a field to delete to prove that
  // \Drupal\field\ConfigImporterFieldPurger does not purge fields that are
  // not related to the configuration synchronization.
  $unrelated_field_storage = entity_create('field_storage_config', array(
    'field_name' => 'field_int',
    'entity_type' => 'entity_test',
    'type' => 'integer',
  ));
  $unrelated_field_storage
    ->save();
  entity_create('field_config', array(
    'field_storage' => $unrelated_field_storage,
    'bundle' => 'entity_test',
  ))
    ->save();

  // Create a telephone field for validation.
  $field_storage = entity_create('field_storage_config', array(
    'field_name' => 'field_test',
    'entity_type' => 'entity_test',
    'type' => 'telephone',
  ));
  $field_storage
    ->save();
  entity_create('field_config', array(
    'field_storage' => $field_storage,
    'bundle' => 'entity_test',
  ))
    ->save();
  $entity = entity_create('entity_test');
  $value = '+0123456789';
  $entity->field_test = $value;
  $entity->field_int = '99';
  $entity->name->value = $this
    ->randomMachineName();
  $entity
    ->save();

  // Verify entity has been created properly.
  $id = $entity
    ->id();
  $entity = entity_load('entity_test', $id);
  $this
    ->assertEqual($entity->field_test->value, $value);
  $this
    ->assertEqual($entity->field_test[0]->value, $value);
  $this
    ->assertEqual($entity->field_int->value, '99');

  // Delete unrelated field before copying configuration and running the
  // synchronization.
  $unrelated_field_storage
    ->delete();
  $active = $this->container
    ->get('config.storage');
  $sync = $this->container
    ->get('config.storage.sync');
  $this
    ->copyConfig($active, $sync);

  // Stage uninstall of the Telephone module.
  $core_extension = $this
    ->config('core.extension')
    ->get();
  unset($core_extension['module']['telephone']);
  $sync
    ->write('core.extension', $core_extension);

  // Stage the field deletion
  $sync
    ->delete('field.storage.entity_test.field_test');
  $sync
    ->delete('field.field.entity_test.entity_test.field_test');
  $steps = $this
    ->configImporter()
    ->initialize();
  $this
    ->assertIdentical($steps[0], array(
    '\\Drupal\\field\\ConfigImporterFieldPurger',
    'process',
  ), 'The additional process configuration synchronization step has been added.');

  // This will purge all the data, delete the field and uninstall the
  // Telephone module.
  $this
    ->configImporter()
    ->import();
  $this
    ->assertFalse(\Drupal::moduleHandler()
    ->moduleExists('telephone'));
  $this
    ->assertFalse(\Drupal::entityManager()
    ->loadEntityByUuid('field_storage_config', $field_storage
    ->uuid()), 'The test field has been deleted by the configuration synchronization');
  $deleted_storages = \Drupal::state()
    ->get('field.storage.deleted') ?: array();
  $this
    ->assertFalse(isset($deleted_storages[$field_storage
    ->uuid()]), 'Telephone field has been completed removed from the system.');
  $this
    ->assertTrue(isset($deleted_storages[$unrelated_field_storage
    ->uuid()]), 'Unrelated field not purged by configuration synchronization.');
}