123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- <?php
- namespace Drupal\KernelTests\Core\Config;
- use Drupal\Component\Utility\SafeMarkup;
- use Drupal\Component\Utility\Unicode;
- use Drupal\Component\Uuid\Php;
- use Drupal\Core\Config\ConfigImporter;
- use Drupal\Core\Config\ConfigImporterException;
- use Drupal\Core\Config\StorageComparer;
- use Drupal\node\Entity\NodeType;
- use Drupal\KernelTests\KernelTestBase;
- /**
- * Tests validating renamed configuration in a configuration import.
- *
- * @group config
- */
- class ConfigImportRenameValidationTest extends KernelTestBase {
- /**
- * Config Importer object used for testing.
- *
- * @var \Drupal\Core\Config\ConfigImporter
- */
- protected $configImporter;
- /**
- * Modules to enable.
- *
- * @var array
- */
- public static $modules = ['system', 'user', 'node', 'field', 'text', 'config_test'];
- /**
- * {@inheritdoc}
- */
- protected function setUp() {
- parent::setUp();
- $this->installEntitySchema('user');
- $this->installEntitySchema('node');
- $this->installConfig(['field']);
- // Set up the ConfigImporter object for testing.
- $storage_comparer = new StorageComparer(
- $this->container->get('config.storage.sync'),
- $this->container->get('config.storage'),
- $this->container->get('config.manager')
- );
- $this->configImporter = new ConfigImporter(
- $storage_comparer->createChangelist(),
- $this->container->get('event_dispatcher'),
- $this->container->get('config.manager'),
- $this->container->get('lock.persistent'),
- $this->container->get('config.typed'),
- $this->container->get('module_handler'),
- $this->container->get('module_installer'),
- $this->container->get('theme_handler'),
- $this->container->get('string_translation')
- );
- }
- /**
- * Tests configuration renaming validation.
- */
- public function testRenameValidation() {
- // Create a test entity.
- $test_entity_id = $this->randomMachineName();
- $test_entity = entity_create('config_test', [
- 'id' => $test_entity_id,
- 'label' => $this->randomMachineName(),
- ]);
- $test_entity->save();
- $uuid = $test_entity->uuid();
- // Stage the test entity and then delete it from the active storage.
- $active = $this->container->get('config.storage');
- $sync = $this->container->get('config.storage.sync');
- $this->copyConfig($active, $sync);
- $test_entity->delete();
- // Create a content type with a matching UUID in the active storage.
- $content_type = NodeType::create([
- 'type' => Unicode::strtolower($this->randomMachineName(16)),
- 'name' => $this->randomMachineName(),
- 'uuid' => $uuid,
- ]);
- $content_type->save();
- // Confirm that the staged configuration is detected as a rename since the
- // UUIDs match.
- $this->configImporter->reset();
- $expected = [
- 'node.type.' . $content_type->id() . '::config_test.dynamic.' . $test_entity_id,
- ];
- $renames = $this->configImporter->getUnprocessedConfiguration('rename');
- $this->assertSame($expected, $renames);
- // Try to import the configuration. We expect an exception to be thrown
- // because the staged entity is of a different type.
- try {
- $this->configImporter->import();
- $this->fail('Expected ConfigImporterException thrown when a renamed configuration entity does not match the existing entity type.');
- }
- catch (ConfigImporterException $e) {
- $this->pass('Expected ConfigImporterException thrown when a renamed configuration entity does not match the existing entity type.');
- $expected = [
- SafeMarkup::format('Entity type mismatch on rename. @old_type not equal to @new_type for existing configuration @old_name and staged configuration @new_name.', ['@old_type' => 'node_type', '@new_type' => 'config_test', '@old_name' => 'node.type.' . $content_type->id(), '@new_name' => 'config_test.dynamic.' . $test_entity_id])
- ];
- $this->assertEqual($expected, $this->configImporter->getErrors());
- }
- }
- /**
- * Tests configuration renaming validation for simple configuration.
- */
- public function testRenameSimpleConfigValidation() {
- $uuid = new Php();
- // Create a simple configuration with a UUID.
- $config = $this->config('config_test.new');
- $uuid_value = $uuid->generate();
- $config->set('uuid', $uuid_value)->save();
- $active = $this->container->get('config.storage');
- $sync = $this->container->get('config.storage.sync');
- $this->copyConfig($active, $sync);
- $config->delete();
- // Create another simple configuration with the same UUID.
- $config = $this->config('config_test.old');
- $config->set('uuid', $uuid_value)->save();
- // Confirm that the staged configuration is detected as a rename since the
- // UUIDs match.
- $this->configImporter->reset();
- $expected = [
- 'config_test.old::config_test.new'
- ];
- $renames = $this->configImporter->getUnprocessedConfiguration('rename');
- $this->assertSame($expected, $renames);
- // Try to import the configuration. We expect an exception to be thrown
- // because the rename is for simple configuration.
- try {
- $this->configImporter->import();
- $this->fail('Expected ConfigImporterException thrown when simple configuration is renamed.');
- }
- catch (ConfigImporterException $e) {
- $this->pass('Expected ConfigImporterException thrown when simple configuration is renamed.');
- $expected = [
- SafeMarkup::format('Rename operation for simple configuration. Existing configuration @old_name and staged configuration @new_name.', ['@old_name' => 'config_test.old', '@new_name' => 'config_test.new'])
- ];
- $this->assertEqual($expected, $this->configImporter->getErrors());
- }
- }
- }
|