function ConfigImporterTest::testSecondaryUpdateDeletedDeleterFirst

Same name and namespace in other branches
  1. 8.9.x core/tests/Drupal/KernelTests/Core/Config/ConfigImporterTest.php \Drupal\KernelTests\Core\Config\ConfigImporterTest::testSecondaryUpdateDeletedDeleterFirst()

Tests that secondary updates for deleted files work as expected.

File

core/tests/Drupal/KernelTests/Core/Config/ConfigImporterTest.php, line 288

Class

ConfigImporterTest
Tests importing configuration from files into active configuration.

Namespace

Drupal\KernelTests\Core\Config

Code

public function testSecondaryUpdateDeletedDeleterFirst() {
  $name_deleter = 'config_test.dynamic.deleter';
  $name_deletee = 'config_test.dynamic.deletee';
  $name_other = 'config_test.dynamic.other';
  $storage = $this->container
    ->get('config.storage');
  $sync = $this->container
    ->get('config.storage.sync');
  $uuid = $this->container
    ->get('uuid');
  $values_deleter = [
    'id' => 'deleter',
    'label' => 'Deleter',
    'weight' => 0,
    'uuid' => $uuid->generate(),
  ];
  $storage->write($name_deleter, $values_deleter);
  $values_deleter['label'] = 'Updated Deleter';
  $sync->write($name_deleter, $values_deleter);
  $values_deletee = [
    'id' => 'deletee',
    'label' => 'Deletee',
    'weight' => 0,
    'uuid' => $uuid->generate(),
    // Add a dependency on deleter, to make sure that is synced first.
'dependencies' => [
      'config' => [
        $name_deleter,
      ],
    ],
  ];
  $storage->write($name_deletee, $values_deletee);
  $values_deletee['label'] = 'Updated Deletee';
  $sync->write($name_deletee, $values_deletee);
  // Ensure that import will continue after the error.
  $values_other = [
    'id' => 'other',
    'label' => 'Other',
    'weight' => 0,
    'uuid' => $uuid->generate(),
    // Add a dependency on deleter, to make sure that is synced first. This
    // will also be synced after the deletee due to alphabetical ordering.
'dependencies' => [
      'config' => [
        $name_deleter,
      ],
    ],
  ];
  $storage->write($name_other, $values_other);
  $values_other['label'] = 'Updated other';
  $sync->write($name_other, $values_other);
  // Check update changelist order.
  $config_importer = $this->configImporter();
  $updates = $config_importer->getStorageComparer()
    ->getChangelist('update');
  $expected = [
    $name_deleter,
    $name_deletee,
    $name_other,
  ];
  $this->assertSame($expected, $updates);
  // Import.
  $config_importer->import();
  $entity_storage = \Drupal::entityTypeManager()->getStorage('config_test');
  $deleter = $entity_storage->load('deleter');
  $this->assertEquals('deleter', $deleter->id());
  $this->assertEquals($values_deleter['uuid'], $deleter->uuid());
  $this->assertEquals($values_deleter['label'], $deleter->label());
  // The deletee was deleted in
  // \Drupal\config_test\Entity\ConfigTest::postSave().
  $this->assertNull($entity_storage->load('deletee'));
  $other = $entity_storage->load('other');
  $this->assertEquals('other', $other->id());
  $this->assertEquals($values_other['uuid'], $other->uuid());
  $this->assertEquals($values_other['label'], $other->label());
  $logs = $config_importer->getErrors();
  $this->assertCount(1, $logs);
  $this->assertEquals(new FormattableMarkup('Update target "@name" is missing.', [
    '@name' => $name_deletee,
  ]), $logs[0]);
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.