Issue #1598618 by aspilicious, Rob Loach: Convert update.test to PSR-0.
parent
d4a401a352
commit
c1ecf4f6c8
|
@ -0,0 +1,38 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Definition of Drupal\system\Tests\Update\DependencyHookInvocationTest.
|
||||
*/
|
||||
|
||||
namespace Drupal\system\Tests\Update;
|
||||
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
* Tests for the invocation of hook_update_dependencies().
|
||||
*/
|
||||
class DependencyHookInvocationTest extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Update dependency hook invocation',
|
||||
'description' => 'Test that the hook invocation for determining update dependencies works correctly.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
parent::setUp('update_test_1', 'update_test_2');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
/**
|
||||
* Test the structure of the array returned by hook_update_dependencies().
|
||||
*/
|
||||
function testHookUpdateDependencies() {
|
||||
$update_dependencies = update_retrieve_dependencies();
|
||||
$this->assertTrue($update_dependencies['system'][8000]['update_test_1'] == 8000, t('An update function that has a dependency on two separate modules has the first dependency recorded correctly.'));
|
||||
$this->assertTrue($update_dependencies['system'][8000]['update_test_2'] == 8001, t('An update function that has a dependency on two separate modules has the second dependency recorded correctly.'));
|
||||
$this->assertTrue($update_dependencies['system'][8001]['update_test_1'] == 8002, t('An update function that depends on more than one update from the same module only has the dependency on the higher-numbered update function recorded.'));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,40 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Definition of Drupal\system\Tests\Update\DependencyMissingTest.
|
||||
*/
|
||||
|
||||
namespace Drupal\system\Tests\Update;
|
||||
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
* Tests for missing update dependencies.
|
||||
*/
|
||||
class DependencyMissingTest extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Missing update dependencies',
|
||||
'description' => 'Test that missing update dependencies are correctly flagged.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
// Only install update_test_2.module, even though its updates have a
|
||||
// dependency on update_test_3.module.
|
||||
parent::setUp('update_test_2');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
function testMissingUpdate() {
|
||||
$starting_updates = array(
|
||||
'update_test_2' => 8000,
|
||||
);
|
||||
$update_graph = update_resolve_dependencies($starting_updates);
|
||||
$this->assertTrue($update_graph['update_test_2_update_8000']['allowed'], t("The module's first update function is allowed to run, since it does not have any missing dependencies."));
|
||||
$this->assertFalse($update_graph['update_test_2_update_8001']['allowed'], t("The module's second update function is not allowed to run, since it has a direct dependency on a missing update."));
|
||||
$this->assertFalse($update_graph['update_test_2_update_8002']['allowed'], t("The module's third update function is not allowed to run, since it has an indirect dependency on a missing update."));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,60 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Definition of Drupal\system\Tests\Update\DependencyOrderingTest.
|
||||
*/
|
||||
|
||||
namespace Drupal\system\Tests\Update;
|
||||
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
* Tests for the update dependency ordering system.
|
||||
*/
|
||||
class DependencyOrderingTest extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Update dependency ordering',
|
||||
'description' => 'Test that update functions are run in the proper order.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
parent::setUp('update_test_1', 'update_test_2', 'update_test_3');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that updates within a single module run in the correct order.
|
||||
*/
|
||||
function testUpdateOrderingSingleModule() {
|
||||
$starting_updates = array(
|
||||
'update_test_1' => 8000,
|
||||
);
|
||||
$expected_updates = array(
|
||||
'update_test_1_update_8000',
|
||||
'update_test_1_update_8001',
|
||||
'update_test_1_update_8002',
|
||||
);
|
||||
$actual_updates = array_keys(update_resolve_dependencies($starting_updates));
|
||||
$this->assertEqual($expected_updates, $actual_updates, t('Updates within a single module run in the correct order.'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that dependencies between modules are resolved correctly.
|
||||
*/
|
||||
function testUpdateOrderingModuleInterdependency() {
|
||||
$starting_updates = array(
|
||||
'update_test_2' => 8000,
|
||||
'update_test_3' => 8000,
|
||||
);
|
||||
$update_order = array_keys(update_resolve_dependencies($starting_updates));
|
||||
// Make sure that each dependency is satisfied.
|
||||
$first_dependency_satisfied = array_search('update_test_2_update_8000', $update_order) < array_search('update_test_3_update_8000', $update_order);
|
||||
$this->assertTrue($first_dependency_satisfied, t('The dependency of the second module on the first module is respected by the update function order.'));
|
||||
$second_dependency_satisfied = array_search('update_test_3_update_8000', $update_order) < array_search('update_test_2_update_8001', $update_order);
|
||||
$this->assertTrue($second_dependency_satisfied, t('The dependency of the first module on the second module is respected by the update function order.'));
|
||||
}
|
||||
}
|
|
@ -1,117 +0,0 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Tests for the update system.
|
||||
*/
|
||||
|
||||
use Drupal\simpletest\WebTestBase;
|
||||
|
||||
/**
|
||||
* Tests for the update dependency ordering system.
|
||||
*/
|
||||
class UpdateDependencyOrderingTestCase extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Update dependency ordering',
|
||||
'description' => 'Test that update functions are run in the proper order.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
parent::setUp('update_test_1', 'update_test_2', 'update_test_3');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that updates within a single module run in the correct order.
|
||||
*/
|
||||
function testUpdateOrderingSingleModule() {
|
||||
$starting_updates = array(
|
||||
'update_test_1' => 8000,
|
||||
);
|
||||
$expected_updates = array(
|
||||
'update_test_1_update_8000',
|
||||
'update_test_1_update_8001',
|
||||
'update_test_1_update_8002',
|
||||
);
|
||||
$actual_updates = array_keys(update_resolve_dependencies($starting_updates));
|
||||
$this->assertEqual($expected_updates, $actual_updates, t('Updates within a single module run in the correct order.'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that dependencies between modules are resolved correctly.
|
||||
*/
|
||||
function testUpdateOrderingModuleInterdependency() {
|
||||
$starting_updates = array(
|
||||
'update_test_2' => 8000,
|
||||
'update_test_3' => 8000,
|
||||
);
|
||||
$update_order = array_keys(update_resolve_dependencies($starting_updates));
|
||||
// Make sure that each dependency is satisfied.
|
||||
$first_dependency_satisfied = array_search('update_test_2_update_8000', $update_order) < array_search('update_test_3_update_8000', $update_order);
|
||||
$this->assertTrue($first_dependency_satisfied, t('The dependency of the second module on the first module is respected by the update function order.'));
|
||||
$second_dependency_satisfied = array_search('update_test_3_update_8000', $update_order) < array_search('update_test_2_update_8001', $update_order);
|
||||
$this->assertTrue($second_dependency_satisfied, t('The dependency of the first module on the second module is respected by the update function order.'));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests for missing update dependencies.
|
||||
*/
|
||||
class UpdateDependencyMissingTestCase extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Missing update dependencies',
|
||||
'description' => 'Test that missing update dependencies are correctly flagged.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
// Only install update_test_2.module, even though its updates have a
|
||||
// dependency on update_test_3.module.
|
||||
parent::setUp('update_test_2');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
function testMissingUpdate() {
|
||||
$starting_updates = array(
|
||||
'update_test_2' => 8000,
|
||||
);
|
||||
$update_graph = update_resolve_dependencies($starting_updates);
|
||||
$this->assertTrue($update_graph['update_test_2_update_8000']['allowed'], t("The module's first update function is allowed to run, since it does not have any missing dependencies."));
|
||||
$this->assertFalse($update_graph['update_test_2_update_8001']['allowed'], t("The module's second update function is not allowed to run, since it has a direct dependency on a missing update."));
|
||||
$this->assertFalse($update_graph['update_test_2_update_8002']['allowed'], t("The module's third update function is not allowed to run, since it has an indirect dependency on a missing update."));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests for the invocation of hook_update_dependencies().
|
||||
*/
|
||||
class UpdateDependencyHookInvocationTestCase extends WebTestBase {
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => 'Update dependency hook invocation',
|
||||
'description' => 'Test that the hook invocation for determining update dependencies works correctly.',
|
||||
'group' => 'Update API',
|
||||
);
|
||||
}
|
||||
|
||||
function setUp() {
|
||||
parent::setUp('update_test_1', 'update_test_2');
|
||||
require_once DRUPAL_ROOT . '/core/includes/update.inc';
|
||||
}
|
||||
|
||||
/**
|
||||
* Test the structure of the array returned by hook_update_dependencies().
|
||||
*/
|
||||
function testHookUpdateDependencies() {
|
||||
$update_dependencies = update_retrieve_dependencies();
|
||||
$this->assertTrue($update_dependencies['system'][8000]['update_test_1'] == 8000, t('An update function that has a dependency on two separate modules has the first dependency recorded correctly.'));
|
||||
$this->assertTrue($update_dependencies['system'][8000]['update_test_2'] == 8001, t('An update function that has a dependency on two separate modules has the second dependency recorded correctly.'));
|
||||
$this->assertTrue($update_dependencies['system'][8001]['update_test_1'] == 8002, t('An update function that depends on more than one update from the same module only has the dependency on the higher-numbered update function recorded.'));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue