You are here

class ActionsContentTest in SimpleTest 6

Hierarchy

Expanded class hierarchy of ActionsContentTest

File

tests/content_actions.test, line 2

View source
class ActionsContentTest extends DrupalTestCase {
  var $_cleanup_roles = array();
  var $_cleanup_users = array();

  /**
   * Implementation of get_info() for information
   */
  function get_info() {
    return array(
      'name' => t('Actions content'),
      'desc' => t('Perform various tests with content actions.'),
      'group' => 'Actions',
    );
  }

  /**
   * Various tests, all in one function to assure they happen in the right order.
   */
  function testActionsContent() {
    global $user;
    $this
      ->drupalModuleEnable('trigger');
    $content_actions = array(
      'node_publish_action',
      'node_unpublish_action',
      'node_make_sticky_action',
      'node_make_unsticky_action',
      'node_promote_action',
      'node_unpromote_action',
    );
    $hash = md5('node_publish_action');
    $not_clean = db_result(db_query("SELECT COUNT(*) FROM {trigger_assignments} WHERE aid IN ('" . implode("','", $content_actions) . "')"));
    $this
      ->assertFalse($not_clean, t('Actions were already assigned to the trigger. Unassign all content triggers before attempting to run again.'));
    if ($not_clean) {
      return;
    }

    // Test 1: Assign an action to a trigger, then pull the trigger, and make sure the actions fire. (Wow, those metaphors work out nicely).
    $test_user = $this
      ->drupalCreateUserRolePerm(array(
      'administer actions',
      'create page content',
    ));
    $this
      ->drupalLoginUser($test_user);

    // Set action id to "publish post".
    $edit = array(
      'aid' => $hash,
    );
    $this
      ->drupalPost('admin/build/trigger/node', $edit, 'Assign');

    // Create an unpublished node.
    $node = $this
      ->drupalCreateNode(array(
      'status' => 0,
    ));

    // Node should be published automatically.
    $loaded_node = node_load($node->nid);
    $this
      ->assertTrue($loaded_node->status == 1, t('Check to make sure the node is automatically published'));

    // Leave action assigned for next test
    // Test 2: There should be an error when the action is assigned to the trigger twice.
    $edit = array(
      'aid' => $hash,
    );
    $this
      ->drupalPost('admin/build/trigger/node', $edit, 'Assign');
    $this
      ->assertWantedRaw(t('The action you chose is already assigned to that trigger.'), t('Check to make sure an error occurs when assigning an action to a trigger twice.'));

    // Test 3: The action should be able to be unassigned from a trigger.
    // This effectively cleans up as well.
    $this
      ->drupalPost('admin/build/trigger/unassign/nodeapi/presave/' . $hash, array(), 'Unassign');
    $this
      ->assertWantedRaw(t('Action %action has been unassigned.', array(
      '%action' => 'Publish post',
    )), t('Check to make sure action can be unassigned from trigger.'));
    $assigned = db_result(db_query("SELECT COUNT(*) FROM {trigger_assignments} WHERE aid IN ('" . implode("','", $content_actions) . "')"));
    $this
      ->assertFalse($assigned, t('Check to make sure unassign worked properly at the database level.'));
  }

}

Members

Namesort descending Modifiers Type Description Overrides
ActionsContentTest::$_cleanup_roles property
ActionsContentTest::$_cleanup_users property
ActionsContentTest::get_info function Implementation of get_info() for information
ActionsContentTest::testActionsContent function Various tests, all in one function to assure they happen in the right order.
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