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 }
|