public function FieldUIDeleteTest::testDeleteField in Drupal 9
Same name and namespace in other branches
- 8 core/modules/field_ui/tests/src/Functional/FieldUIDeleteTest.php \Drupal\Tests\field_ui\Functional\FieldUIDeleteTest::testDeleteField()
- 10 core/modules/field_ui/tests/src/Functional/FieldUIDeleteTest.php \Drupal\Tests\field_ui\Functional\FieldUIDeleteTest::testDeleteField()
Tests that deletion removes field storages and fields as expected.
File
- core/
modules/ field_ui/ tests/ src/ Functional/ FieldUIDeleteTest.php, line 74
Class
- FieldUIDeleteTest
- Tests deletion of a field and their dependencies in the UI.
Namespace
Drupal\Tests\field_ui\FunctionalCode
public function testDeleteField() {
$field_label = $this
->randomMachineName();
$field_name_input = 'test';
$field_name = 'field_test';
// Create an additional node type.
$type_name1 = strtolower($this
->randomMachineName(8)) . '_test';
$type1 = $this
->drupalCreateContentType([
'name' => $type_name1,
'type' => $type_name1,
]);
$type_name1 = $type1
->id();
// Create a new field.
$bundle_path1 = 'admin/structure/types/manage/' . $type_name1;
$this
->fieldUIAddNewField($bundle_path1, $field_name_input, $field_label);
// Create an additional node type.
$type_name2 = strtolower($this
->randomMachineName(8)) . '_test';
$type2 = $this
->drupalCreateContentType([
'name' => $type_name2,
'type' => $type_name2,
]);
$type_name2 = $type2
->id();
// Add a field to the second node type.
$bundle_path2 = 'admin/structure/types/manage/' . $type_name2;
$this
->fieldUIAddExistingField($bundle_path2, $field_name, $field_label);
\Drupal::service('module_installer')
->install([
'views',
]);
ViewTestData::createTestViews(static::class, [
'field_test_views',
]);
$view = View::load('test_view_field_delete');
$this
->assertNotNull($view);
$this
->assertTrue($view
->status());
// Test that the View depends on the field.
$dependencies = $view
->getDependencies() + [
'config' => [],
];
$this
->assertContains("field.storage.node.{$field_name}", $dependencies['config']);
// Check the config dependencies of the first field, the field storage must
// not be shown as being deleted yet.
$this
->drupalGet("{$bundle_path1}/fields/node.{$type_name1}.{$field_name}/delete");
$this
->assertSession()
->pageTextNotContains('The listed configuration will be deleted.');
$this
->assertSession()
->elementNotExists('xpath', '//ul[@data-drupal-selector="edit-view"]');
$this
->assertSession()
->pageTextNotContains('test_view_field_delete');
// Delete the first field.
$this
->fieldUIDeleteField($bundle_path1, "node.{$type_name1}.{$field_name}", $field_label, $type_name1);
// Check that the field was deleted.
$this
->assertNull(FieldConfig::loadByName('node', $type_name1, $field_name), 'Field was deleted.');
// Check that the field storage was not deleted
$this
->assertNotNull(FieldStorageConfig::loadByName('node', $field_name), 'Field storage was not deleted.');
// Check the config dependencies of the first field.
$this
->drupalGet("{$bundle_path2}/fields/node.{$type_name2}.{$field_name}/delete");
$this
->assertSession()
->pageTextContains('The listed configuration will be updated.');
$this
->assertSession()
->elementTextEquals('xpath', '//ul[@data-drupal-selector="edit-view"]', 'test_view_field_delete');
$xml = $this
->cssSelect('#edit-entity-deletes');
// Test that nothing is scheduled for deletion.
$this
->assertFalse(isset($xml[0]), 'The field currently being deleted is not shown in the entity deletions.');
// Delete the second field.
$this
->fieldUIDeleteField($bundle_path2, "node.{$type_name2}.{$field_name}", $field_label, $type_name2);
// Check that the field was deleted.
$this
->assertNull(FieldConfig::loadByName('node', $type_name2, $field_name), 'Field was deleted.');
// Check that the field storage was deleted too.
$this
->assertNull(FieldStorageConfig::loadByName('node', $field_name), 'Field storage was deleted.');
// Test that the View isn't deleted and has been disabled.
$view = View::load('test_view_field_delete');
$this
->assertNotNull($view);
$this
->assertFalse($view
->status());
// Test that the View no longer depends on the deleted field.
$dependencies = $view
->getDependencies() + [
'config' => [],
];
$this
->assertNotContains("field.storage.node.{$field_name}", $dependencies['config']);
}