NodeClassicTest.php

Same filename in other branches
  1. 9 core/modules/migrate_drupal_ui/tests/src/Functional/d6/NodeClassicTest.php
  2. 10 core/modules/migrate_drupal_ui/tests/src/Functional/d6/NodeClassicTest.php
  3. 11.x core/modules/migrate_drupal_ui/tests/src/Functional/d6/NodeClassicTest.php

Namespace

Drupal\Tests\migrate_drupal_ui\Functional\d6

File

core/modules/migrate_drupal_ui/tests/src/Functional/d6/NodeClassicTest.php

View source
<?php

namespace Drupal\Tests\migrate_drupal_ui\Functional\d6;

use Drupal\migrate_drupal\NodeMigrateType;
use Drupal\Tests\migrate_drupal\Traits\NodeMigrateTypeTestTrait;
use Drupal\Tests\migrate_drupal_ui\Functional\MigrateUpgradeExecuteTestBase;

/**
 * Tests the classic node migration runs.
 *
 * The classic node migration will run and not the complete node migration
 * when there is a pre-existing classic node migrate map table.
 *
 * @group migrate_drupal_ui
 */
class NodeClassicTest extends MigrateUpgradeExecuteTestBase {
    use NodeMigrateTypeTestTrait;
    
    /**
     * {@inheritdoc}
     */
    public static $modules = [
        'language',
        'content_translation',
        'config_translation',
        'migrate_drupal_ui',
        'telephone',
        'aggregator',
        'book',
        'forum',
        'statistics',
        // Required for translation migrations.
'migrate_drupal_multilingual',
    ];
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() {
        parent::setUp();
        $this->loadFixture(drupal_get_path('module', 'migrate_drupal') . '/tests/fixtures/drupal6.php');
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getSourceBasePath() {
        return __DIR__ . '/files';
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getEntityCounts() {
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getEntityCountsIncremental() {
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getAvailablePaths() {
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getMissingPaths() {
    }
    
    /**
     * Tests ID Conflict form.
     */
    public function testMigrateUpgradeExecute() {
        // Add a node classic migrate table to d8.
        $this->makeNodeMigrateMapTable(NodeMigrateType::NODE_MIGRATE_TYPE_CLASSIC, '6');
        $connection_options = $this->sourceDatabase
            ->getConnectionOptions();
        $this->drupalGet('/upgrade');
        $session = $this->assertSession();
        $session->responseContains("Upgrade a site by importing its files and the data from its database into a clean and empty new install of Drupal {$this->destinationSiteVersion}.");
        $this->drupalPostForm(NULL, [], t('Continue'));
        $session->pageTextContains('Provide credentials for the database of the Drupal site you want to upgrade.');
        $session->fieldExists('mysql[host]');
        $driver = $connection_options['driver'];
        $connection_options['prefix'] = $connection_options['prefix']['default'];
        // Use the driver connection form to get the correct options out of the
        // database settings. This supports all of the databases we test against.
        $drivers = drupal_get_database_types();
        $form = $drivers[$driver]->getFormOptions($connection_options);
        $connection_options = array_intersect_key($connection_options, $form + $form['advanced_options']);
        $version = $this->getLegacyDrupalVersion($this->sourceDatabase);
        $edit = [
            $driver => $connection_options,
            'source_private_file_path' => $this->getSourceBasePath(),
            'version' => $version,
        ];
        $edit['d6_source_base_path'] = $this->getSourceBasePath();
        if (count($drivers) !== 1) {
            $edit['driver'] = $driver;
        }
        $edits = $this->translatePostValues($edit);
        // Start the upgrade process.
        $this->drupalGet('/upgrade');
        $session->responseContains("Upgrade a site by importing its files and the data from its database into a clean and empty new install of Drupal {$this->destinationSiteVersion}.");
        $this->drupalPostForm(NULL, [], t('Continue'));
        $session->pageTextContains('Provide credentials for the database of the Drupal site you want to upgrade.');
        $session->fieldExists('mysql[host]');
        // When the Credential form is submitted the migrate map tables are created.
        $this->drupalPostForm(NULL, $edits, t('Review upgrade'));
        // Confirm there are only classic node migration map tables. This shows
        // that only the classic migration will run.
        $results = $this->nodeMigrateMapTableCount('6');
        $this->assertSame(13, $results['node']);
        $this->assertSame(0, $results['node_complete']);
    }

}

Classes

Title Deprecated Summary
NodeClassicTest Tests the classic node migration runs.

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