You are here

class UserAccessTest in SimpleTest 5

Same name and namespace in other branches
  1. 6 tests/user_module.test \UserAccessTest

Hierarchy

Expanded class hierarchy of UserAccessTest

File

tests/user_access.test, line 2

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 tearDown() {
    while (sizeof($this->_cleanup_masks) > 0) {
      $aid = array_pop($this->_cleanup_masks);
      db_query("DELETE FROM {access} WHERE aid = %d", $aid);
    }
    parent::tearDown();
  }
  function _addMask($mask, $type, $status = 0) {
    $aid = db_next_id('{access}_aid');
    db_query("INSERT INTO {access} (aid, mask, type, status) VALUES ('%s', '%s', '%s', %d)", $aid, $mask, $type, $status);
    $str_status = $status == 0 ? 'deny' : 'allow';
    $this
      ->assertTrue(db_affected_rows() > 0, "{$str_status} Mask added for {$type} '{$mask}'");
    $this->_cleanup_masks[] = $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
      ->drupalPostRequest('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
      ->drupalPostRequest('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

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupModules property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content 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::clickLink function Follows a link by name. Will click the first link found with this link text by default, or a later one if an index is given. Match is case insensitive with normalised space. Does make assertations if the click was sucessful or not and it does…
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
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 Brokder 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::drupalPostRequest function Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser
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 druapl 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
UserAccessTest::$_cleanup_masks property
UserAccessTest::get_info function
UserAccessTest::tearDown function tearDown implementation, setting back switched modules etc Overrides DrupalTestCase::tearDown
UserAccessTest::testAccess function
UserAccessTest::_addMask function