class DisableUninstallCoreModuleTest in SimpleTest 6
Hierarchy
- class \DrupalTestCase extends \WebTestCase
Expanded class hierarchy of DisableUninstallCoreModuleTest
File
- tests/
modules_system.test, line 130
View source
class DisableUninstallCoreModuleTest extends DrupalTestCase {
/**
* Implementation of get_info() for information
*/
function get_info() {
return array(
'name' => t('Disable/uninstall core modules'),
'desc' => 'Disables and uninstalls core modules, ensures that that tables are properly deleted, no error messages are shown, etc.',
'group' => 'Modules',
);
}
function testDisableUninstallCoreModules() {
// Get a list of the modules to test
$modules_to_test = array(
'aggregator',
'blog',
'blogapi',
'book',
'color',
'comment',
'contact',
'dblog',
'forum',
'help',
'locale',
'menu',
'openid',
'path',
'php',
'ping',
'poll',
'profile',
'search',
'statistics',
'syslog',
'taxonomy',
'throttle',
'tracker',
'translation',
'trigger',
'update',
'upload',
);
// Get a list of the currently enabled modules
$enabled_modules = module_list(true, false);
// We don't want to test any modules that are already enabled, since that would involve a loss of data
foreach ($enabled_modules as $module) {
if (in_array($module, $modules_to_test)) {
unset($modules_to_test[array_search($module, $modules_to_test)]);
}
}
// Enable all the modules that are not already enabled
include_once './includes/install.inc';
module_enable($modules_to_test);
drupal_install_modules($modules_to_test);
$web_user = $this
->drupalCreateUserRolePerm(array(
'access administration pages',
'administer site configuration',
));
$this
->drupalLoginUser($web_user);
// Disable/uninstall the given modules: we keep every other module enabled
// We do this loop because for each level of dependency, we need one more request
while (count(array_diff(module_list(true, false), $enabled_modules)) > 0) {
$edit = array();
foreach ($modules_to_test as $module) {
$edit['status[' . $module . ']'] = 0;
}
foreach ($enabled_modules as $module) {
$edit['status[' . $module . ']'] = $module;
}
$this
->drupalPost('admin/build/modules/list/confirm', $edit, 'Save configuration');
$this
->assertWantedRaw(t('The configuration options have been saved.'), t('Ensure that the module status has been updated'));
}
// Now, lets make sure the modules are truly disabled and then try to uninstall them
module_list(true, false);
$edit = array();
foreach ($modules_to_test as $module) {
$this
->assertFalse(module_exists($module), t('Make sure the module has been disabled'));
if (module_hook($module, 'uninstall')) {
$edit['uninstall[' . $module . ']'] = $module;
}
}
$this
->drupalPost('admin/build/modules/uninstall/confirm', $edit, 'Uninstall');
// We need to confirm this by clicking again
$this->_browser
->clickSubmit(t('Uninstall'));
$this
->assertWantedRaw(t('The selected modules have been uninstalled.'), 'Check to ensure that the modules have been removed');
// Now, we check the tables for each module
foreach ($modules_to_test as $module) {
$cur_schema = drupal_get_schema_unprocessed($module);
$tables = is_array($cur_schema) ? array_keys($cur_schema) : array();
foreach ($tables as $table) {
$this
->assertFalse(db_table_exists($table), t('Ensure that the database table has been properly removed'));
}
}
drupal_clear_css_cache();
drupal_clear_js_cache();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DisableUninstallCoreModuleTest:: |
function | Implementation of get_info() for information | ||
DisableUninstallCoreModuleTest:: |
function | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to different objects. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value only. Otherwise a fail. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and optionally that the error text matches exactly. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and that the error text matches a Perl regular expression. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail. | ||
DrupalTestCase:: |
function | Type and class test. Will pass if class matches the type name or is a subclass or if not an object, but the type is correct. | ||
DrupalTestCase:: |
function | Confirms that no errors have occurred so far in the test method. | ||
DrupalTestCase:: |
function | Type and class mismatch test. Will pass if class name or underling type does not match the one specified. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have a different value. Otherwise a fail. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the different value or different type. | ||
DrupalTestCase:: |
function | Will be true if the value is set. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Will be true if the value is null. | ||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to the same object. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Retrieves and saves current modules list into $_originalModules and $_modules. | ||
DrupalTestCase:: |
function | Follows a link by name. | ||
DrupalTestCase:: |
function | @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site. | ||
DrupalTestCase:: |
function | Creates a custom content type based on default settings. | ||
DrupalTestCase:: |
function | Creates a node based on default settings. | ||
DrupalTestCase:: |
function | Create a role / perm combination specified by permissions | ||
DrupalTestCase:: |
function | Creates a user / role / permissions combination specified by permissions | ||
DrupalTestCase:: |
function | @abstract Broker for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | @TODO: needs documentation | ||
DrupalTestCase:: |
function | Logs in a user with the internal browser | ||
DrupalTestCase:: |
function | Disables a drupal module | ||
DrupalTestCase:: |
function | Enables a drupal module | ||
DrupalTestCase:: |
function | Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser By $reporting you specify if this request does assertions or not Warning: empty ("") returns will cause fails with $reporting | ||
DrupalTestCase:: |
function | @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | |||
DrupalTestCase:: |
function | Set a drupal variable and keep track of the changes for tearDown() | ||
DrupalTestCase:: |
function | Generates a random string, to be used as name or whatever | ||
DrupalTestCase:: |
function | Just some info for the reporter | ||
DrupalTestCase:: |
function | tearDown implementation, setting back switched modules etc | 8 |