UserRoleAdminTest.php

Definition of Drupal\user\Tests\UserRoleAdminTest.

Namespace

Drupal\user\Tests

File

drupal/core/modules/user/lib/Drupal/user/Tests/UserRoleAdminTest.php
View source
<?php

/**
 * @file
 * Definition of Drupal\user\Tests\UserRoleAdminTest.
 */
namespace Drupal\user\Tests;

use Drupal\simpletest\WebTestBase;

/**
 * Test case to test adding, editing and deleting roles.
 */
class UserRoleAdminTest extends WebTestBase {
  public static function getInfo() {
    return array(
      'name' => 'User role administration',
      'description' => 'Test adding, editing and deleting user roles and changing role weights.',
      'group' => 'User',
    );
  }
  function setUp() {
    parent::setUp();
    $this->admin_user = $this
      ->drupalCreateUser(array(
      'administer permissions',
      'administer users',
    ));
  }

  /**
   * Test adding, renaming and deleting roles.
   */
  function testRoleAdministration() {
    $this
      ->drupalLogin($this->admin_user);

    // Test adding a role. (In doing so, we use a role name that happens to
    // correspond to an integer, to test that the role administration pages
    // correctly distinguish between role names and IDs.)
    $role_name = '123';
    $edit = array(
      'role[name]' => $role_name,
      'role[rid]' => $role_name,
    );
    $this
      ->drupalPost('admin/people/roles', $edit, t('Add role'));
    $this
      ->assertText(t('The role has been added.'), 'The role has been added.');
    $role = user_role_load($role_name);
    $this
      ->assertTrue(is_object($role), 'The role was successfully retrieved from the database.');

    // Try adding a duplicate role.
    $this
      ->drupalPost(NULL, $edit, t('Add role'));
    $this
      ->assertRaw(t('The machine-readable name is already in use. It must be unique.'), 'Duplicate role warning displayed.');

    // Test renaming a role.
    $old_name = $role_name;
    $role_name = '456';
    $edit = array(
      'role[name]' => $role_name,
    );
    $this
      ->drupalPost("admin/people/roles/edit/{$role->rid}", $edit, t('Save role'));
    $this
      ->assertText(t('The role has been renamed.'), 'The role has been renamed.');
    $new_role = user_role_load($old_name);
    $this
      ->assertEqual($new_role->name, $role_name, 'The role name has been successfully changed.');

    // Test deleting a role.
    $this
      ->drupalPost("admin/people/roles/edit/{$role->rid}", NULL, t('Delete role'));
    $this
      ->drupalPost(NULL, NULL, t('Delete'));
    $this
      ->assertText(t('The role has been deleted.'), 'The role has been deleted');
    $this
      ->assertNoLinkByHref("admin/people/roles/edit/{$role->rid}", 'Role edit link removed.');
    $this
      ->assertFalse(user_role_load($role_name), 'A deleted role can no longer be loaded.');

    // Make sure that the system-defined roles can be edited via the user
    // interface.
    $this
      ->drupalGet('admin/people/roles/edit/' . DRUPAL_ANONYMOUS_RID);
    $this
      ->assertResponse(200, 'Access granted when trying to edit the built-in anonymous role.');
    $this
      ->assertNoText(t('Delete role'), 'Delete button for the anonymous role is not present.');
    $this
      ->drupalGet('admin/people/roles/edit/' . DRUPAL_AUTHENTICATED_RID);
    $this
      ->assertResponse(200, 'Access granted when trying to edit the built-in authenticated role.');
    $this
      ->assertNoText(t('Delete role'), 'Delete button for the authenticated role is not present.');
  }

  /**
   * Test user role weight change operation.
   */
  function testRoleWeightChange() {
    $this
      ->drupalLogin($this->admin_user);

    // Pick up a random role and get its weight.
    $rid = array_rand(user_roles());
    $role = user_role_load($rid);
    $old_weight = $role->weight;

    // Change the role weight and submit the form.
    $edit = array(
      'roles[' . $rid . '][weight]' => $old_weight + 1,
    );
    $this
      ->drupalPost('admin/people/roles', $edit, t('Save order'));
    $this
      ->assertText(t('The role settings have been updated.'), 'The role settings form submitted successfully.');

    // Retrieve the saved role and compare its weight.
    $role = user_role_load($rid);
    $new_weight = $role->weight;
    $this
      ->assertTrue($old_weight + 1 == $new_weight, 'Role weight updated successfully.');
  }

}

Classes

Namesort descending Description
UserRoleAdminTest Test case to test adding, editing and deleting roles.