function OpenIDRegistrationTestCase::testRegisterUserWithEmailVerification

Test OpenID auto-registration with e-mail verification enabled.

File

modules/openid/openid.test, line 420

Class

OpenIDRegistrationTestCase
Test account registration using Simple Registration and Attribute Exchange.

Code

function testRegisterUserWithEmailVerification() {
  variable_set('user_email_verification', TRUE);
  // Tell openid_test.module to respond with these SREG fields.
  variable_set('openid_test_response', array(
    'openid.sreg.nickname' => 'john',
    'openid.sreg.email' => 'john@example.com',
  ));
  // Use a User-supplied Identity that is the URL of an XRDS document.
  $identity = url('openid-test/yadis/xrds', array(
    'absolute' => TRUE,
  ));
  $this->submitLoginForm($identity);
  $this->assertRaw(t('Once you have verified your e-mail address, you may log in via OpenID.'), 'User was asked to verify e-mail address.');
  $this->assertRaw(t('A welcome message with further instructions has been sent to your e-mail address.'), 'A welcome message was sent to the user.');
  $reset_url = $this->getPasswordResetURLFromMail();
  $user = user_load_by_name('john');
  $this->assertTrue($user, 'User was registered with right username.');
  $this->assertEqual($user->mail, 'john@example.com', 'User was registered with right email address.');
  $this->assertFalse($user->data, 'No additional user info was saved.');
  $this->submitLoginForm($identity);
  $this->assertRaw(t('You must validate your email address for this account before logging in via OpenID.'));
  // Follow the one-time login that was sent in the welcome e-mail.
  $this->drupalGet($reset_url);
  $this->drupalPost(NULL, array(), t('Log in'));
  $this->drupalLogout();
  // Verify that the account was activated.
  $this->submitLoginForm($identity);
  $this->assertLink(t('Log out'), 0, 'User was logged in.');
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.