class Upgrade6Test in Drupal 10
Same name and namespace in other branches
- 8 core/modules/migrate_drupal_ui/tests/src/Functional/d6/Upgrade6Test.php \Drupal\Tests\migrate_drupal_ui\Functional\d6\Upgrade6Test
- 9 core/modules/migrate_drupal_ui/tests/src/Functional/d6/Upgrade6Test.php \Drupal\Tests\migrate_drupal_ui\Functional\d6\Upgrade6Test
Tests Drupal 6 upgrade using the migrate UI.
The test method is provided by the MigrateUpgradeTestBase class.
@group migrate_drupal_ui
Hierarchy
- class \Drupal\Tests\BrowserTestBase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, FunctionalTestSetupTrait, TestSetupTrait, BlockCreationTrait, ConfigTestTrait, ExtensionListTestTrait, ContentTypeCreationTrait, NodeCreationTrait, RandomGeneratorTrait, TestRequirementsTrait, PhpUnitWarnings, UiHelperTrait, UserCreationTrait, XdebugRequestTrait
- class \Drupal\Tests\migrate_drupal_ui\Functional\MigrateUpgradeTestBase uses MigrationConfigurationTrait
- class \Drupal\Tests\migrate_drupal_ui\Functional\MigrateUpgradeExecuteTestBase uses CreateTestContentEntitiesTrait
- class \Drupal\Tests\migrate_drupal_ui\Functional\d6\Upgrade6Test
- class \Drupal\Tests\migrate_drupal_ui\Functional\MigrateUpgradeExecuteTestBase uses CreateTestContentEntitiesTrait
- class \Drupal\Tests\migrate_drupal_ui\Functional\MigrateUpgradeTestBase uses MigrationConfigurationTrait
Expanded class hierarchy of Upgrade6Test
File
- core/
modules/ migrate_drupal_ui/ tests/ src/ Functional/ d6/ Upgrade6Test.php, line 15
Namespace
Drupal\Tests\migrate_drupal_ui\Functional\d6View source
class Upgrade6Test extends MigrateUpgradeExecuteTestBase {
/**
* {@inheritdoc}
*/
protected static $modules = [
'book',
'config_translation',
'content_translation',
'datetime_range',
'forum',
'language',
'migrate_drupal_ui',
'rdf',
'statistics',
'telephone',
'update',
];
/**
* The entity storage for node.
*
* @var \Drupal\Core\Entity\EntityStorageInterface
*/
protected $nodeStorage;
/**
* {@inheritdoc}
*/
protected function setUp() : void {
parent::setUp();
// @todo remove in https://www.drupal.org/project/drupal/issues/3267040
// Delete the existing content made to test the ID Conflict form. Migrations
// are to be done on a site without content. The test of the ID Conflict
// form is being moved to its own issue which will remove the deletion
// of the created nodes.
// See https://www.drupal.org/project/drupal/issues/3087061.
$this->nodeStorage = $this->container
->get('entity_type.manager')
->getStorage('node');
$this->nodeStorage
->delete($this->nodeStorage
->loadMultiple());
$this
->loadFixture($this
->getModulePath('migrate_drupal') . '/tests/fixtures/drupal6.php');
// @todo Remove this in https://www.drupal.org/node/3267515
\Drupal::service('module_installer')
->uninstall([
'rdf',
]);
}
/**
* {@inheritdoc}
*/
protected function getSourceBasePath() {
return __DIR__ . '/files';
}
/**
* {@inheritdoc}
*/
protected function getEntityCounts() {
return [
'block' => 36,
'block_content' => 2,
'block_content_type' => 1,
'comment' => 8,
// The 'standard' profile provides the 'comment' comment type, and the
// migration creates 12 comment types, one per node type.
'comment_type' => 14,
'contact_form' => 5,
'contact_message' => 0,
'configurable_language' => 5,
'editor' => 2,
'field_config' => 103,
'field_storage_config' => 71,
'file' => 7,
'filter_format' => 7,
'image_style' => 6,
'language_content_settings' => 15,
'node' => 18,
// The 'book' module provides the 'book' node type, and the migration
// creates 12 node types.
'node_type' => 14,
'search_page' => 2,
'shortcut' => 2,
'shortcut_set' => 1,
'action' => 33,
'menu' => 8,
'path_alias' => 8,
'taxonomy_term' => 15,
'taxonomy_vocabulary' => 7,
'tour' => 6,
'user' => 7,
'user_role' => 7,
'menu_link_content' => 10,
'view' => 14,
'date_format' => 12,
'entity_form_display' => 31,
'entity_form_mode' => 1,
'entity_view_display' => 58,
'entity_view_mode' => 12,
'base_field_override' => 41,
];
}
/**
* {@inheritdoc}
*/
protected function getEntityCountsIncremental() {
$counts = $this
->getEntityCounts();
$counts['block_content'] = 3;
$counts['comment'] = 9;
$counts['file'] = 8;
$counts['menu_link_content'] = 11;
$counts['node'] = 19;
$counts['taxonomy_term'] = 16;
$counts['user'] = 8;
return $counts;
}
/**
* {@inheritdoc}
*/
protected function getAvailablePaths() {
return [
'Block',
'Block translation',
'Book',
'CCK translation',
'Comment',
'Contact',
'Content',
'Content translation',
'Content type translation',
'Date',
'Email',
'FileField',
'Filter',
'Forum',
'ImageCache',
'ImageField',
'Internationalization',
'Locale',
'Menu',
'Menu translation',
'Node',
'Node Reference',
'Option Widgets',
'Path',
'Profile translation',
'Search',
'Statistics',
'String translation',
'Synchronize translations',
'System',
'Taxonomy',
'Taxonomy translation',
'Text',
'Update status',
'Upload',
'User',
'User Reference',
// Include modules that do not have an upgrade path and are enabled in the
// source database'.
'Date API',
'Date Timezone',
'Event',
'ImageAPI',
'Number',
'PHP filter',
'Profile',
'Variable admin',
];
}
/**
* {@inheritdoc}
*/
protected function getMissingPaths() {
return [
'Aggregator',
];
}
/**
* Executes all steps of migrations upgrade.
*/
public function testUpgradeAndIncremental() {
// Perform upgrade followed by an incremental upgrade.
$this
->doUpgradeAndIncremental();
// Ensure a migrated user can log in.
$this
->assertUserLogIn(2, 'john.doe_pass');
$this
->assertFollowUpMigrationResults();
$this
->assertEmailsSent();
}
/**
* Tests that follow-up migrations have been run successfully.
*
* @internal
*/
protected function assertFollowUpMigrationResults() : void {
$node = Node::load(10);
$this
->assertSame('12', $node
->get('field_reference')->target_id);
$this
->assertSame('12', $node
->get('field_reference_2')->target_id);
$translation = $node
->getTranslation('fr');
$this
->assertSame('12', $translation
->get('field_reference')->target_id);
$this
->assertSame('12', $translation
->get('field_reference_2')->target_id);
$node = Node::load(12)
->getTranslation('en');
$this
->assertSame('10', $node
->get('field_reference')->target_id);
$this
->assertSame('10', $node
->get('field_reference_2')->target_id);
$translation = $node
->getTranslation('fr');
$this
->assertSame('10', $translation
->get('field_reference')->target_id);
$this
->assertSame('10', $translation
->get('field_reference_2')->target_id);
}
}