You are here

class UserRegistrationTest in SimpleTest 5

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

Class to test the user registration process,

  • based on initial version by Kuba Zygmunt -

Hierarchy

Expanded class hierarchy of UserRegistrationTest

File

tests/user_registration_test.test, line 6

View source
class UserRegistrationTest extends DrupalTestCase {
  function get_info() {
    return array(
      'name' => t('User registration'),
      'desc' => t('Registers a user, fails login, successfully logs in, changes password, logs out.'),
      'group' => 'User tests',
    );
  }
  function testUserRegistration() {

    /* We first allow every user to login instantly. */
    $this
      ->drupalVariableSet('user_register', 1);

    /* make sure the profiles module is disabled to avoid conflicts */
    $this
      ->drupalModuleDisable('profiles');
    $name = $this
      ->randomName();
    $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.'), 'Your password and further instructions ... found');
    $this
      ->assertNoText(t('The name %name has been denied access.', array(
      '%name' => $name,
    )), 'not denied access');

    // now we check database fields
    // we can use an 'edit' array to load user variable
    $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) {
      return FALSE;
    }
    $this
      ->assertEqual($user->name, $name, 'Checking name of user');
    $this
      ->assertEqual($user->mail, $mail, 'Checking e-mail address');
    $this
      ->assertEqual($user->mode, 0, 'Checking mode field');
    $this
      ->assertEqual($user->sort, 0, 'Checking sort field');
    $this
      ->assertEqual($user->threshold, 0, 'Checking treshold field');
    $this
      ->assertEqual($user->theme, '', 'Checking theme field');
    $this
      ->assertEqual($user->signature, '', 'Checking signature field');
    $this
      ->assertTrue($user->created > time() - 20, 0, 'Checking creation time.');
    $this
      ->assertEqual($user->status, variable_get('user_register', 1) == 1 ? 1 : 0, 'Checking status field');
    $this
      ->assertEqual($user->timezone, NULL, 'Checking timezone field');
    $this
      ->assertEqual($user->language, '', 'Checking language field');
    $this
      ->assertEqual($user->picture, '', 'Check picture field');
    $this
      ->assertEqual($user->init, $mail, 'Check init field');

    /* We try to login with a wrong password */
    $login_edit = array(
      'name' => $name,
      'pass' => 'foo',
    );
    $this
      ->drupalPostRequest('user', $login_edit, 'Log in');
    $this
      ->assertText(t('Sorry, unrecognized username or password. Have you forgotten your password?'), 'Test for failed Login');
    $url = user_pass_reset_url($user);

    /* TODO: find a better way, we currently have to do it that way, see user.module line 1041. */
    sleep(1);
    $this->_browser
      ->get($url);

    // Will proabaly not work localised as the text is sent to tranlate wrapped in <p> usually
    $this
      ->assertText(t('This login can be used only once.'), "Check for 'used only once' notice");
    $this->_browser
      ->clickSubmit(t('Log in'));
    $this
      ->assertText(t('You have just used your one-time login link. It is no longer necessary to use this link to login. Please change your password.'), "Check for one time login notice after clicking Login button.");

    /* now lets change our password */
    $new_pass = user_password();
    $this
      ->assertTrue($this->_browser
      ->setField('pass[pass1]', $new_pass), 'Pass1 field set.');
    $this
      ->assertTrue($this->_browser
      ->setField('pass[pass2]', $new_pass), 'Pass2 field set.');
    $this->_browser
      ->clickSubmit();
    $this
      ->assertText(t('The changes have been saved.'), "Changed password to '{$new_pass}'");

    /* Check if the password changes are present in db */
    $user = user_load(array(
      'uid' => $user->uid,
    ));
    $this
      ->assertEqual($user->pass, md5($new_pass), 'Correct password in database');

    /* logout */
    $this
      ->clickLink('Log out');
    $this
      ->assertNoText($user->name, 'Logged out');

    /* login again */
    $login_edit['pass'] = $new_pass;
    $this
      ->drupalPostRequest('user', $login_edit, 'Log in');

    /** $pname = theme('placeholder', $user->name); /** @TODO: this one messes html tags->search fails */
    $pname = $user->name;
    $this
      ->assertText($pname, 'Logged in (name found)');
    $this
      ->assertNoText(t('Sorry. Unrecognized username or password.'), 'Logged in (not sorry)');
    $this
      ->assertNoText(t('User login'), 'Logged in (no user login form present)');
    $this
      ->assertNoText(t('The username %name has been blocked.', array(
      '%name' => $pname,
    )), 'Not blocked');
    $this
      ->assertNoText(t('The name %name is a reserved username.', array(
      '%name' => $pname,
    )), 'Access granted');

    /* 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
DrupalTestCase::tearDown function tearDown implementation, setting back switched modules etc 1
UserRegistrationTest::get_info function
UserRegistrationTest::testUserRegistration function