class ActionsContentTest in SimpleTest 6
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \ActionsContentTest
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
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ActionsContentTest:: |
property | |||
ActionsContentTest:: |
property | |||
ActionsContentTest:: |
function | Implementation of get_info() for information | ||
ActionsContentTest:: |
function | Various tests, all in one function to assure they happen in the right order. | ||
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 |