You are here

trait AssertConfigEntityImportTrait in Drupal 8

Same name in this branch
  1. 8 core/modules/config/src/Tests/AssertConfigEntityImportTrait.php \Drupal\config\Tests\AssertConfigEntityImportTrait
  2. 8 core/modules/config/tests/src/Traits/AssertConfigEntityImportTrait.php \Drupal\Tests\config\Traits\AssertConfigEntityImportTrait
Same name and namespace in other branches
  1. 9 core/modules/config/tests/src/Traits/AssertConfigEntityImportTrait.php \Drupal\Tests\config\Traits\AssertConfigEntityImportTrait

Provides test assertions for testing config entity synchronization.

Can be used by test classes that extend \Drupal\Tests\BrowserTestBase or \Drupal\KernelTests\KernelTestBase.

Hierarchy

1 file declares its use of AssertConfigEntityImportTrait
EntityReferenceIntegrationTest.php in core/modules/field/tests/src/Functional/EntityReference/EntityReferenceIntegrationTest.php

File

core/modules/config/tests/src/Traits/AssertConfigEntityImportTrait.php, line 13

Namespace

Drupal\Tests\config\Traits
View source
trait AssertConfigEntityImportTrait {

  /**
   * Asserts that a config entity can be imported without changing it.
   *
   * @param \Drupal\Core\Config\Entity\ConfigEntityInterface $entity
   *   The config entity to test importing.
   */
  public function assertConfigEntityImport(ConfigEntityInterface $entity) {

    // Save original config information.
    $entity_uuid = $entity
      ->uuid();
    $entity_type_id = $entity
      ->getEntityTypeId();
    $original_data = $entity
      ->toArray();

    // Copy everything to sync.
    $this
      ->copyConfig(\Drupal::service('config.storage'), \Drupal::service('config.storage.sync'));

    // Delete the configuration from active. Don't worry about side effects of
    // deleting config like fields cleaning up field storages. The coming import
    // should recreate everything as necessary.
    $entity
      ->delete();
    $this
      ->configImporter()
      ->reset()
      ->import();
    $imported_entity = \Drupal::service('entity.repository')
      ->loadEntityByUuid($entity_type_id, $entity_uuid);
    $this
      ->assertIdentical($original_data, $imported_entity
      ->toArray());
  }

}

Members

Namesort descending Modifiers Type Description Overrides
AssertConfigEntityImportTrait::assertConfigEntityImport public function Asserts that a config entity can be imported without changing it.