protected function MigrateUiParagraphsTestBase::assertMigrateUpgradeViaUi in Paragraphs 8
Executes the upgrade process by the UI and asserts basic expectations.
1 call to MigrateUiParagraphsTestBase::assertMigrateUpgradeViaUi()
- MigrateUiParagraphsTest::testParagraphsMigrate in tests/src/ Functional/ Migrate/ MigrateUiParagraphsTest.php 
- Tests the result of the paragraphs migration.
File
- tests/src/ Functional/ Migrate/ MigrateUiParagraphsTestBase.php, line 402 
Class
- MigrateUiParagraphsTestBase
- Provides a base class for testing Paragraphs migration via the UI.
Namespace
Drupal\Tests\paragraphs\Functional\MigrateCode
protected function assertMigrateUpgradeViaUi() {
  $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
    ->submitForm([], $this
    ->t('Continue'));
  $session
    ->pageTextContains('Provide credentials for the database of the Drupal site you want to upgrade.');
  $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
      ->getSourcePrivateFilesPath(),
    'version' => $version,
    'source_base_path' => $this
      ->getSourceBasePath(),
  ];
  if (count($drivers) !== 1) {
    $edit['driver'] = $driver;
  }
  $edits = $this
    ->translatePostValues($edit);
  $this
    ->submitForm($edits, $this
    ->t('Review upgrade'));
  $session
    ->pageTextNotContains('Resolve all issues below to continue the upgrade.');
  // ID conflict form.
  $session
    ->buttonExists($this
    ->t('I acknowledge I may lose data. Continue anyway.'));
  $this
    ->submitForm([], $this
    ->t('I acknowledge I may lose data. Continue anyway.'));
  $session
    ->statusCodeEquals(200);
  // Perform the upgrade.
  $this
    ->submitForm([], $this
    ->t('Perform upgrade'));
  $session
    ->pageTextContains($this
    ->t('Congratulations, you upgraded Drupal!'));
  // Have to reset all the statics after migration to ensure entities are
  // loadable.
  $this
    ->resetAll();
}