1 upgrade.test | protected UpgradePathTestCase::performUpgrade($register_errors = TRUE) |
Perform the upgrade.
Parameters
$register_errors: Register the errors during the upgrade process as failures.
Return value
bool: TRUE if the upgrade succeeded, FALSE otherwise.
File
- core/
modules/ simpletest/ tests/ upgrade/ upgrade.test, line 170
Class
- UpgradePathTestCase
- Perform end-to-end tests of the upgrade path.
Code
protected function performUpgrade($register_errors = TRUE) {
// Load the first update screen.
$update_url = $GLOBALS['base_url'] . '/core/update.php';
$this->backdropGet($update_url, array('external' => TRUE));
if (!$this->assertResponse(200)) {
return FALSE;
}
// Confirm the upgrade from D7 state has been set.
backdrop_static_reset('states');
$d7_upgrade_state = state_get('update_d7_upgrade');
$this->assertTrue($d7_upgrade_state, 'The "update_d7_upgrade" state has been set before the update.');
// When upgrading from Drupal 7, the backup step should not be shown.
$this->assertNoRaw('<span class="task-item">Backup</span>');
$this->assertRaw('<span class="task-item">Review updates</span>');
// Continue.
$this->backdropPost(NULL, array(), t('Continue'));
if (!$this->assertResponse(200)) {
return FALSE;
}
// Go!
$this->backdropPost(NULL, array(), t('Apply pending updates'));
if (!$this->assertText(t('Updates were attempted'))) {
return FALSE;
}
// Check for errors during the update process.
foreach ($this->xpath('//li[@class=:class]', array(':class' => 'failure')) as $element) {
$message = strip_tags($element->asXML());
$this->upgradeErrors[] = $message;
if ($register_errors) {
$this->fail($message);
}
}
if (!empty($this->upgradeErrors)) {
// Upgrade failed, the installation might be in an inconsistent state,
// don't process.
return FALSE;
}
// Check if there still are pending updates.
$this->backdropGet($update_url, array('external' => TRUE));
$this->backdropPost(NULL, array(), t('Continue'));
if (!$this->assertText(t('No pending updates.'), 'No pending updates at the end of the update process.')) {
return FALSE;
}
// Confirm the upgrade from D7 state is now cleared.
backdrop_static_reset('states');
$d7_upgrade_state = state_get('update_d7_upgrade');
$this->assertNull($d7_upgrade_state, 'The "update_d7_upgrade" state has been cleared after the update.');
// Upgrade succeed, rebuild the environment so that we can call the API
// of the child site directly from this request.
$this->upgradedSite = TRUE;
// Reload module list. For modules that are enabled in the test database,
// but not on the test client, we need to load the code here.
$new_modules = array_diff(module_list(TRUE), $this->loadedModules);
foreach ($new_modules as $module) {
backdrop_load('module', $module);
}
// Reload hook implementations
module_implements_reset();
// Rebuild caches.
backdrop_static_reset();
backdrop_flush_all_caches();
// Reload global $conf array and permissions.
$this->refreshVariables();
$this->checkPermissions(array(), TRUE);
// Check we can load the home page of the new site.
$this->backdropGet('');
return $this->assertText('Powered by Backdrop CMS', 'The home page of the upgraded site loads successfully.');
}