You are here

class EnableCoreModuleTest in SimpleTest 6

Hierarchy

Expanded class hierarchy of EnableCoreModuleTest

File

tests/modules_system.test, line 3

View source
class EnableCoreModuleTest extends DrupalTestCase {

  /**
   * Implementation of get_info() for information
   */
  function get_info() {
    return array(
      'name' => t('Enable core modules'),
      'desc' => 'Enables all core modules by POST - looks for error messages, confirms table creation, etc.',
      'group' => 'Modules',
    );
  }
  function testEnableCoreModules() {

    // Get a list of the modules to enable
    $modules_to_enable = 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);
    $web_user = $this
      ->drupalCreateUserRolePerm(array(
      'access administration pages',
      'administer site configuration',
    ));
    $this
      ->drupalLoginUser($web_user);
    $edit = array();

    // We temporarily disable any modules we're testing so that we can re-enable them for testing
    foreach ($modules_to_enable as $module) {
      if (module_exists($module)) {
        $this
          ->drupalModuleDisable($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, we check the tables for each module
    // We also refresh the module list and make sure the modules are enabled
    module_list(true, false);
    foreach ($modules_to_enable as $module) {
      $cur_schema = drupal_get_schema_unprocessed($module);
      $tables = is_array($cur_schema) ? array_keys($cur_schema) : array();
      foreach ($tables as $table) {
        $this
          ->assertTrue(db_table_exists($table), t('Make sure that the database table for the module exists'));
      }
      $this
        ->assertTrue(module_exists($module), t('Check to see that the module is actually enabled'));
    }

    // Disable/uninstall all the modules that have been installed by this process
    // We first need to refresh the module list
    include_once './includes/install.inc';
    foreach ($modules_to_enable as $module) {

      // We uninstall the modules that weren't already enabled
      if (!in_array($module, $enabled_modules)) {
        module_disable(array(
          $module,
        ));
        drupal_uninstall_module($module);
      }
    }
    drupal_clear_css_cache();
    drupal_clear_js_cache();
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupContentTypes property
DrupalTestCase::$_cleanupNodes property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content property
DrupalTestCase::$_modules property
DrupalTestCase::$_originalModules property
DrupalTestCase::assertCopy function Will trigger a pass if both parameters refer to different objects. Fail otherwise.
DrupalTestCase::assertEqual function Will trigger a pass if the two parameters have the same value only. Otherwise a fail.
DrupalTestCase::assertError function Confirms that an error has occurred and optionally that the error text matches exactly.
DrupalTestCase::assertErrorPattern function Confirms that an error has occurred and that the error text matches a Perl regular expression.
DrupalTestCase::assertIdentical function Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail.
DrupalTestCase::assertIsA 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::assertNoErrors function Confirms that no errors have occurred so far in the test method.
DrupalTestCase::assertNotA function Type and class mismatch test. Will pass if class name or underling type does not match the one specified.
DrupalTestCase::assertNotEqual function Will trigger a pass if the two parameters have a different value. Otherwise a fail.
DrupalTestCase::assertNotIdentical function Will trigger a pass if the two parameters have the different value or different type.
DrupalTestCase::assertNotNull function Will be true if the value is set.
DrupalTestCase::assertNoUnwantedPattern function Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found.
DrupalTestCase::assertNoUnwantedRaw function Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise.
DrupalTestCase::assertNull function Will be true if the value is null.
DrupalTestCase::assertReference function Will trigger a pass if both parameters refer to the same object. Fail otherwise.
DrupalTestCase::assertWantedPattern function Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise.
DrupalTestCase::assertWantedRaw function Will trigger a pass if the raw text is found on the loaded page Fail otherwise.
DrupalTestCase::checkOriginalModules function Retrieves and saves current modules list into $_originalModules and $_modules.
DrupalTestCase::clickLink function Follows a link by name.
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
DrupalTestCase::drupalCreateContentType function Creates a custom content type based on default settings.
DrupalTestCase::drupalCreateNode function Creates a node based on default settings.
DrupalTestCase::drupalCreateRolePerm function Create a role / perm combination specified by permissions
DrupalTestCase::drupalCreateUserRolePerm function Creates a user / role / permissions combination specified by permissions
DrupalTestCase::drupalGet function @abstract Broker for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::drupalGetContent function @TODO: needs documentation
DrupalTestCase::drupalLoginUser function Logs in a user with the internal browser
DrupalTestCase::drupalModuleDisable function Disables a drupal module
DrupalTestCase::drupalModuleEnable function Enables a drupal module
DrupalTestCase::drupalPost 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::drupalRawPost function @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::DrupalTestCase function
DrupalTestCase::drupalVariableSet function Set a drupal variable and keep track of the changes for tearDown()
DrupalTestCase::randomName function Generates a random string, to be used as name or whatever
DrupalTestCase::run function Just some info for the reporter
DrupalTestCase::tearDown function tearDown implementation, setting back switched modules etc 8
EnableCoreModuleTest::get_info function Implementation of get_info() for information
EnableCoreModuleTest::testEnableCoreModules function