annotate core/modules/field/src/Tests/FieldImportDeleteUninstallUiTest.php @ 0:4c8ae668cc8c

Initial import (non-working)
author Chris Cannam
date Wed, 29 Nov 2017 16:09:58 +0000
parents
children
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\field\Tests;
Chris@0 4
Chris@0 5 use Drupal\entity_test\Entity\EntityTest;
Chris@0 6 use Drupal\field\Entity\FieldConfig;
Chris@0 7 use Drupal\field\Entity\FieldStorageConfig;
Chris@0 8
Chris@0 9 /**
Chris@0 10 * Delete field storages and fields during config synchronization and uninstall
Chris@0 11 * module that provides the field type through the UI.
Chris@0 12 *
Chris@0 13 * @group field
Chris@0 14 * @see \Drupal\field\ConfigImporterFieldPurger
Chris@0 15 * @see field_config_import_steps_alter()
Chris@0 16 * @see field_form_config_admin_import_form_alter()
Chris@0 17 */
Chris@0 18 class FieldImportDeleteUninstallUiTest extends FieldTestBase {
Chris@0 19
Chris@0 20 /**
Chris@0 21 * Modules to enable.
Chris@0 22 *
Chris@0 23 * @var array
Chris@0 24 */
Chris@0 25 public static $modules = ['entity_test', 'telephone', 'config', 'filter', 'datetime'];
Chris@0 26
Chris@0 27 protected function setUp() {
Chris@0 28 parent::setUp();
Chris@0 29
Chris@0 30 $this->drupalLogin($this->drupalCreateUser(['synchronize configuration']));
Chris@0 31 }
Chris@0 32
Chris@0 33 /**
Chris@0 34 * Tests deleting field storages and fields as part of config import.
Chris@0 35 */
Chris@0 36 public function testImportDeleteUninstall() {
Chris@0 37 // Create a telephone field.
Chris@0 38 $field_storage = FieldStorageConfig::create([
Chris@0 39 'field_name' => 'field_tel',
Chris@0 40 'entity_type' => 'entity_test',
Chris@0 41 'type' => 'telephone',
Chris@0 42 ]);
Chris@0 43 $field_storage->save();
Chris@0 44 FieldConfig::create([
Chris@0 45 'field_storage' => $field_storage,
Chris@0 46 'bundle' => 'entity_test',
Chris@0 47 ])->save();
Chris@0 48
Chris@0 49 // Create a text field.
Chris@0 50 $date_field_storage = FieldStorageConfig::create([
Chris@0 51 'field_name' => 'field_date',
Chris@0 52 'entity_type' => 'entity_test',
Chris@0 53 'type' => 'datetime',
Chris@0 54 ]);
Chris@0 55 $date_field_storage->save();
Chris@0 56 FieldConfig::create([
Chris@0 57 'field_storage' => $date_field_storage,
Chris@0 58 'bundle' => 'entity_test',
Chris@0 59 ])->save();
Chris@0 60
Chris@0 61 // Create an entity which has values for the telephone and text field.
Chris@0 62 $entity = EntityTest::create();
Chris@0 63 $value = '+0123456789';
Chris@0 64 $entity->field_tel = $value;
Chris@0 65 $entity->field_date = time();
Chris@0 66 $entity->name->value = $this->randomMachineName();
Chris@0 67 $entity->save();
Chris@0 68
Chris@0 69 // Delete the text field before exporting configuration so that we can test
Chris@0 70 // that deleted fields that are provided by modules that will be uninstalled
Chris@0 71 // are also purged and that the UI message includes such fields.
Chris@0 72 $date_field_storage->delete();
Chris@0 73
Chris@0 74 // Verify entity has been created properly.
Chris@0 75 $id = $entity->id();
Chris@0 76 $entity = EntityTest::load($id);
Chris@0 77 $this->assertEqual($entity->field_tel->value, $value);
Chris@0 78 $this->assertEqual($entity->field_tel[0]->value, $value);
Chris@0 79
Chris@0 80 $active = $this->container->get('config.storage');
Chris@0 81 $sync = $this->container->get('config.storage.sync');
Chris@0 82 $this->copyConfig($active, $sync);
Chris@0 83
Chris@0 84 // Stage uninstall of the Telephone module.
Chris@0 85 $core_extension = $this->config('core.extension')->get();
Chris@0 86 unset($core_extension['module']['telephone']);
Chris@0 87 $sync->write('core.extension', $core_extension);
Chris@0 88
Chris@0 89 // Stage the field deletion
Chris@0 90 $sync->delete('field.storage.entity_test.field_tel');
Chris@0 91 $sync->delete('field.field.entity_test.entity_test.field_tel');
Chris@0 92 $this->drupalGet('admin/config/development/configuration');
Chris@0 93 // Test that the message for one field being purged during a configuration
Chris@0 94 // synchronization is correct.
Chris@0 95 $this->assertText('This synchronization will delete data from the field entity_test.field_tel.');
Chris@0 96
Chris@0 97 // Stage an uninstall of the datetime module to test the message for
Chris@0 98 // multiple fields.
Chris@0 99 unset($core_extension['module']['datetime']);
Chris@0 100 $sync->write('core.extension', $core_extension);
Chris@0 101
Chris@0 102 $this->drupalGet('admin/config/development/configuration');
Chris@0 103 $this->assertText('This synchronization will delete data from the fields: entity_test.field_tel, entity_test.field_date.');
Chris@0 104
Chris@0 105 // This will purge all the data, delete the field and uninstall the
Chris@0 106 // Telephone and Text modules.
Chris@0 107 $this->drupalPostForm(NULL, [], t('Import all'));
Chris@0 108 $this->assertNoText('Field data will be deleted by this synchronization.');
Chris@0 109 $this->rebuildContainer();
Chris@0 110 $this->assertFalse(\Drupal::moduleHandler()->moduleExists('telephone'));
Chris@0 111 $this->assertFalse(\Drupal::entityManager()->loadEntityByUuid('field_storage_config', $field_storage->uuid()), 'The telephone field has been deleted by the configuration synchronization');
Chris@0 112 $deleted_storages = \Drupal::state()->get('field.storage.deleted') ?: [];
Chris@0 113 $this->assertFalse(isset($deleted_storages[$field_storage->uuid()]), 'Telephone field has been completed removed from the system.');
Chris@0 114 $this->assertFalse(isset($deleted_storages[$field_storage->uuid()]), 'Text field has been completed removed from the system.');
Chris@0 115 }
Chris@0 116
Chris@0 117 }