class UserAccessTest in SimpleTest 6
Same name and namespace in other branches
- 5 tests/user_access.test \UserAccessTest
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \UserAccessTest
Expanded class hierarchy of UserAccessTest
File
- tests/
user_module.test, line 156
View source
class UserAccessTest extends DrupalTestCase {
var $_cleanup_masks = array();
function get_info() {
return array(
'name' => t('User access rules'),
'desc' => t('Assure that negative and positive access rules behave as designed.'),
'group' => 'User tests',
);
}
function _addMask($mask, $type, $status = 0) {
db_query("INSERT INTO {access} (mask, type, status) VALUES ('%s', '%s', %d)", $mask, $type, $status);
$aid = db_last_insert_id('access', 'aid');
$str_status = $status == 0 ? 'deny' : 'allow';
$this
->assertTrue(db_affected_rows() > 0, "{$str_status} Mask added for {$type} '{$mask}'");
$this->_cleanup_masks[] = $aid;
}
function tearDown() {
while (sizeof($this->_cleanup_masks) > 0) {
$aid = array_pop($this->_cleanup_masks);
db_query("DELETE FROM {access} WHERE aid = %d", $aid);
}
}
function testAccess() {
/* To avoid conflicts with non allowed account creations */
$this
->drupalVariableSet('user_register', 1);
$this
->_addMask('simpletest_block%', 'user');
$this
->_addMask('simpletest_block_allow%', 'user', 1);
/* first try blocked user */
$name = $this
->randomName(2, 'simpletest_block_');
$mail = "{$name}@example.com";
$edit = array(
'name' => $name,
'mail' => $mail,
);
$this
->drupalPost('user/register', $edit, 'Create new account');
$this
->assertNoUnWantedText(t('Your password and further instructions have been sent to your e-mail address.'), 'blocked user: Your password and further instructions - not found');
$this
->assertText(t('The name @name has been denied access.', array(
'@name' => $name,
)), 'blocked user: denied access - found');
/* Lets make a new browser for new cookies */
$this
->setBrowser($this
->createBrowser());
/* now try allowed user */
$name = $this
->randomName(2, 'simpletest_block_allow_');
$mail = "{$name}@example.com";
$edit = array(
'name' => $name,
'mail' => $mail,
);
$this
->drupalPost('user/register', $edit, 'Create new account');
$this
->assertText(t('Your password and further instructions have been sent to your e-mail address.'), 'access user: Your password and further instructions - found');
$this
->assertNoText(t('The name @name has been denied access.', array(
'@name' => $name,
)), 'access user: denied access - not found');
$user = user_load($edit);
$this
->assertTrue(isset($user->uid), 'user->uid set');
$this
->assertTrue($user->uid > 0, 'uid > 0');
if (isset($user->uid) && $user->uid > 0) {
/* delete test user, roles and maybe authmap */
db_query('DELETE FROM {users} WHERE uid = %d', $user->uid);
db_query('DELETE FROM {users_roles} WHERE uid = %d', $user->uid);
db_query('DELETE FROM {authmap} WHERE uid = %d', $user->uid);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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 | ||
UserAccessTest:: |
property | |||
UserAccessTest:: |
function | |||
UserAccessTest:: |
function |
tearDown implementation, setting back switched modules etc Overrides DrupalTestCase:: |
||
UserAccessTest:: |
function | |||
UserAccessTest:: |
function |