You are here

class MagicJSTestCase in Magic 7.2

An even quicker test to ensure that we have the right CSS gets returned when we run our regex to selectively remove files.

Hierarchy

Expanded class hierarchy of MagicJSTestCase

See also

DrupalUnitTestCase

File

./magic.test, line 186
A few tests to ensure the magic module is doing what it should be.

View source
class MagicJSTestCase extends DrupalUnitTestCase {

  /**
   * {@inheritdoc}
   */
  public static function getInfo() {
    return array(
      'name' => 'Magic JS Tests',
      'description' => 'Ensure that our JS is removed or added appropriately.',
      'group' => 'Magic',
    );
  }

  /**
   * Set up the test environment.
   */
  public function setUp() {
    drupal_load('module', 'magic');
    parent::setUp();
  }
  private function the_js_files($files = null) {

    // Will grab the active theme.
    $theme = drupal_get_path('theme', $GLOBALS['theme_key']);
    $js_files = array(
      'overlay' => array(
        'type' => 'file',
        'data' => 'modules/overlay/js/overlay.js',
      ),
      'ctools' => array(
        'type' => 'file',
        'data' => 'sites/all/modules/contrib/ctools/js/ctools.js',
      ),
      'theme' => array(
        'type' => 'file',
        'data' => $theme . '/js/main.js',
      ),
      'external' => array(
        'type' => 'external',
        'data' => '//external.file.com/folder/filename.js',
      ),
      'inline' => array(
        'type' => 'inline',
        'data' => 'jQuery();',
      ),
    );
    $return = array();
    if ($files == null) {
      $files = array_keys($js_files);
    }
    foreach ($js_files as $name => $data) {
      if (in_array($name, $files)) {
        $return[] = $data;
      }
    }
    return $return;
  }

  /**
   * Test magic_assets_exclude().
   *
   * Testing to see if our regex sends back the appropriate responses.
   */
  public function testMagicJSExcludes() {
    module_load_include('inc', 'magic', 'includes/magic.assets');

    // A set of trials for our CSS testing.
    $tests = array(
      array(
        'removal' => array(
          'overlay/*.js',
        ),
        'expected' => array(
          'ctools',
          'theme',
          'external',
          'inline',
        ),
        'message' => 'Ensuring the js removal also works',
      ),
      array(
        'removal' => array(
          ':all',
          '~:current-theme',
        ),
        'expected' => array(
          'theme',
          'inline',
        ),
        'message' => 'Ensure the tokens work with JS',
      ),
    );
    foreach ($tests as $test) {
      $js = $this
        ->the_js_files();
      $expected = $this
        ->the_js_files($test['expected']);
      $steps = magic_assets_regex_steps($test['removal']);
      magic_assets_exclude($js, $steps);

      // We run this so that the array keys are the same.
      $js = array_values($js);
      $this
        ->assertEqual($expected, $js, $test['message']);
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$assertions protected property Assertions thrown in that test case.
DrupalTestCase::$databasePrefix protected property The database prefix of this test run.
DrupalTestCase::$originalFileDirectory protected property The original file directory, before it was changed for testing purposes.
DrupalTestCase::$results public property Current results of this test case.
DrupalTestCase::$setup protected property Flag to indicate whether the test has been set up.
DrupalTestCase::$setupDatabasePrefix protected property
DrupalTestCase::$setupEnvironment protected property
DrupalTestCase::$skipClasses protected property This class is skipped when looking for the source of an assertion.
DrupalTestCase::$testId protected property The test run ID.
DrupalTestCase::$timeLimit protected property Time limit for the test.
DrupalTestCase::$useSetupInstallationCache public property Whether to cache the installation part of the setUp() method.
DrupalTestCase::$useSetupModulesCache public property Whether to cache the modules installation part of the setUp() method.
DrupalTestCase::$verboseDirectoryUrl protected property URL to the verbose output file directory.
DrupalTestCase::assert protected function Internal helper: stores the assert.
DrupalTestCase::assertEqual protected function Check to see if two values are equal.
DrupalTestCase::assertFalse protected function Check to see if a value is false (an empty string, 0, NULL, or FALSE).
DrupalTestCase::assertIdentical protected function Check to see if two values are identical.
DrupalTestCase::assertNotEqual protected function Check to see if two values are not equal.
DrupalTestCase::assertNotIdentical protected function Check to see if two values are not identical.
DrupalTestCase::assertNotNull protected function Check to see if a value is not NULL.
DrupalTestCase::assertNull protected function Check to see if a value is NULL.
DrupalTestCase::assertTrue protected function Check to see if a value is not false (not an empty string, 0, NULL, or FALSE).
DrupalTestCase::deleteAssert public static function Delete an assertion record by message ID.
DrupalTestCase::error protected function Fire an error assertion. 1
DrupalTestCase::errorHandler public function Handle errors during test runs. 1
DrupalTestCase::exceptionHandler protected function Handle exceptions.
DrupalTestCase::fail protected function Fire an assertion that is always negative.
DrupalTestCase::generatePermutations public static function Converts a list of possible parameters into a stack of permutations.
DrupalTestCase::getAssertionCall protected function Cycles through backtrace until the first non-assertion method is found.
DrupalTestCase::getDatabaseConnection public static function Returns the database connection to the site running Simpletest.
DrupalTestCase::insertAssert public static function Store an assertion from outside the testing context.
DrupalTestCase::pass protected function Fire an assertion that is always positive.
DrupalTestCase::randomName public static function Generates a random string containing letters and numbers.
DrupalTestCase::randomString public static function Generates a random string of ASCII characters of codes 32 to 126.
DrupalTestCase::run public function Run all tests in this class.
DrupalTestCase::verbose protected function Logs a verbose message in a text file.
DrupalUnitTestCase::tearDown protected function 1
DrupalUnitTestCase::__construct function Constructor for DrupalUnitTestCase. Overrides DrupalTestCase::__construct
MagicJSTestCase::getInfo public static function
MagicJSTestCase::setUp public function Set up the test environment. Overrides DrupalUnitTestCase::setUp
MagicJSTestCase::testMagicJSExcludes public function Test magic_assets_exclude().
MagicJSTestCase::the_js_files private function