You are here

public function ReEnableModuleFieldTest::testReEnabledField in Drupal 9

Same name and namespace in other branches
  1. 8 core/modules/field/tests/src/Functional/ReEnableModuleFieldTest.php \Drupal\Tests\field\Functional\ReEnableModuleFieldTest::testReEnabledField()

Tests the behavior of a field module after being disabled and re-enabled.

See also

field_system_info_alter()

File

core/modules/field/tests/src/Functional/ReEnableModuleFieldTest.php, line 52

Class

ReEnableModuleFieldTest
Tests the behavior of a field module after being disabled and re-enabled.

Namespace

Drupal\Tests\field\Functional

Code

public function testReEnabledField() {

  // Add a telephone field to the article content type.
  $field_storage = FieldStorageConfig::create([
    'field_name' => 'field_telephone',
    'entity_type' => 'node',
    'type' => 'telephone',
  ]);
  $field_storage
    ->save();
  FieldConfig::create([
    'field_storage' => $field_storage,
    'bundle' => 'article',
    'label' => 'Telephone Number',
  ])
    ->save();

  /** @var \Drupal\Core\Entity\EntityDisplayRepositoryInterface $display_repository */
  $display_repository = \Drupal::service('entity_display.repository');
  $display_repository
    ->getFormDisplay('node', 'article')
    ->setComponent('field_telephone', [
    'type' => 'telephone_default',
    'settings' => [
      'placeholder' => '123-456-7890',
    ],
  ])
    ->save();
  $display_repository
    ->getViewDisplay('node', 'article')
    ->setComponent('field_telephone', [
    'type' => 'telephone_link',
    'weight' => 1,
  ])
    ->save();

  // Display the article node form and verify the telephone widget is present.
  $this
    ->drupalGet('node/add/article');
  $this
    ->assertSession()
    ->fieldValueEquals("field_telephone[0][value]", '');

  // Submit an article node with a telephone field so data exist for the
  // field.
  $edit = [
    'title[0][value]' => $this
      ->randomMachineName(),
    'field_telephone[0][value]' => "123456789",
  ];
  $this
    ->submitForm($edit, 'Save');
  $this
    ->assertSession()
    ->responseContains('<a href="tel:123456789">');

  // Test that the module can't be uninstalled from the UI while there is data
  // for its fields.
  $admin_user = $this
    ->drupalCreateUser([
    'access administration pages',
    'administer modules',
  ]);
  $this
    ->drupalLogin($admin_user);
  $this
    ->drupalGet('admin/modules/uninstall');
  $this
    ->assertSession()
    ->pageTextContains("The Telephone number field type is used in the following field: node.field_telephone");

  // Add another telephone field to a different entity type in order to test
  // the message for the case when multiple fields are blocking the
  // uninstallation of a module.
  $field_storage2 = FieldStorageConfig::create([
    'field_name' => 'field_telephone_2',
    'entity_type' => 'user',
    'type' => 'telephone',
  ]);
  $field_storage2
    ->save();
  FieldConfig::create([
    'field_storage' => $field_storage2,
    'bundle' => 'user',
    'label' => 'User Telephone Number',
  ])
    ->save();
  $this
    ->drupalGet('admin/modules/uninstall');
  $this
    ->assertSession()
    ->pageTextContains("The Telephone number field type is used in the following fields: node.field_telephone, user.field_telephone_2");

  // Delete both fields.
  $field_storage
    ->delete();
  $field_storage2
    ->delete();
  $this
    ->drupalGet('admin/modules/uninstall');
  $this
    ->assertSession()
    ->pageTextContains('Fields pending deletion');
  $this
    ->cronRun();
  $this
    ->assertSession()
    ->pageTextNotContains("The Telephone number field type is used in the following field: node.field_telephone");
  $this
    ->assertSession()
    ->pageTextNotContains('Fields pending deletion');
}