/core/modules/user/src/Tests/UserEditTest.php
PHP | 140 lines | 85 code | 22 blank | 33 comment | 0 complexity | b161b46367b3a571b4237ce05cf7376b MD5 | raw file
- <?php
- namespace Drupal\user\Tests;
- use Drupal\simpletest\WebTestBase;
- /**
- * Tests user edit page.
- *
- * @group user
- */
- class UserEditTest extends WebTestBase {
- /**
- * Test user edit page.
- */
- function testUserEdit() {
- // Test user edit functionality.
- $user1 = $this->drupalCreateUser(array('change own username'));
- $user2 = $this->drupalCreateUser(array());
- $this->drupalLogin($user1);
- // Test that error message appears when attempting to use a non-unique user name.
- $edit['name'] = $user2->getUsername();
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t('The username %name is already taken.', array('%name' => $edit['name'])));
- // Check that filling out a single password field does not validate.
- $edit = array();
- $edit['pass[pass1]'] = '';
- $edit['pass[pass2]'] = $this->randomMachineName();
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertText(t("The specified passwords do not match."), 'Typing mismatched passwords displays an error message.');
- $edit['pass[pass1]'] = $this->randomMachineName();
- $edit['pass[pass2]'] = '';
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertText(t("The specified passwords do not match."), 'Typing mismatched passwords displays an error message.');
- // Test that the error message appears when attempting to change the mail or
- // pass without the current password.
- $edit = array();
- $edit['mail'] = $this->randomMachineName() . '@new.example.com';
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t("Your current password is missing or incorrect; it's required to change the %name.", array('%name' => t('Email'))));
- $edit['current_pass'] = $user1->pass_raw;
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t("The changes have been saved."));
- // Test that the user must enter current password before changing passwords.
- $edit = array();
- $edit['pass[pass1]'] = $new_pass = $this->randomMachineName();
- $edit['pass[pass2]'] = $new_pass;
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t("Your current password is missing or incorrect; it's required to change the %name.", array('%name' => t('Password'))));
- // Try again with the current password.
- $edit['current_pass'] = $user1->pass_raw;
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t("The changes have been saved."));
- // Make sure the changed timestamp is updated.
- $this->assertEqual($user1->getChangedTime(), REQUEST_TIME, 'Changing a user sets "changed" timestamp.');
- // Make sure the user can log in with their new password.
- $this->drupalLogout();
- $user1->pass_raw = $new_pass;
- $this->drupalLogin($user1);
- $this->drupalLogout();
- // Test that the password strength indicator displays.
- $config = $this->config('user.settings');
- $this->drupalLogin($user1);
- $config->set('password_strength', TRUE)->save();
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t('Password strength:'), 'The password strength indicator is displayed.');
- $config->set('password_strength', FALSE)->save();
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertNoRaw(t('Password strength:'), 'The password strength indicator is not displayed.');
- // Check that the user status field has the correct value and that it is
- // properly displayed.
- $admin_user = $this->drupalCreateUser(array('administer users'));
- $this->drupalLogin($admin_user);
- $this->drupalGet('user/' . $user1->id() . '/edit');
- $this->assertNoFieldChecked('edit-status-0');
- $this->assertFieldChecked('edit-status-1');
- $edit = array('status' => 0);
- $this->drupalPostForm('user/' . $user1->id() . '/edit', $edit, t('Save'));
- $this->assertText(t('The changes have been saved.'));
- $this->assertFieldChecked('edit-status-0');
- $this->assertNoFieldChecked('edit-status-1');
- $edit = array('status' => 1);
- $this->drupalPostForm('user/' . $user1->id() . '/edit', $edit, t('Save'));
- $this->assertText(t('The changes have been saved.'));
- $this->assertNoFieldChecked('edit-status-0');
- $this->assertFieldChecked('edit-status-1');
- }
- /**
- * Tests setting the password to "0".
- *
- * We discovered in https://www.drupal.org/node/2563751 that logging in with a
- * password that is literally "0" was not possible. This test ensures that
- * this regression can't happen again.
- */
- public function testUserWith0Password() {
- $admin = $this->drupalCreateUser(['administer users']);
- $this->drupalLogin($admin);
- // Create a regular user.
- $user1 = $this->drupalCreateUser([]);
- $edit = ['pass[pass1]' => '0', 'pass[pass2]' => '0'];
- $this->drupalPostForm("user/" . $user1->id() . "/edit", $edit, t('Save'));
- $this->assertRaw(t("The changes have been saved."));
- }
- /**
- * Tests editing of a user account without an email address.
- */
- function testUserWithoutEmailEdit() {
- // Test that an admin can edit users without an email address.
- $admin = $this->drupalCreateUser(array('administer users'));
- $this->drupalLogin($admin);
- // Create a regular user.
- $user1 = $this->drupalCreateUser(array());
- // This user has no email address.
- $user1->mail = '';
- $user1->save();
- $this->drupalPostForm("user/" . $user1->id() . "/edit", array('mail' => ''), t('Save'));
- $this->assertRaw(t("The changes have been saved."));
- }
- }