X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=web%2Fcore%2Fmodules%2Fuser%2Fsrc%2FTests%2FUserRoleAdminTest.php;fp=web%2Fcore%2Fmodules%2Fuser%2Fsrc%2FTests%2FUserRoleAdminTest.php;h=0000000000000000000000000000000000000000;hb=af6d1fb995500ae68849458ee10d66abbdcfb252;hp=eca9915d77c1353bd51760c7faae1c1f70049227;hpb=680c79a86e3ed402f263faeac92e89fb6d9edcc0;p=yaffs-website diff --git a/web/core/modules/user/src/Tests/UserRoleAdminTest.php b/web/core/modules/user/src/Tests/UserRoleAdminTest.php deleted file mode 100644 index eca9915d7..000000000 --- a/web/core/modules/user/src/Tests/UserRoleAdminTest.php +++ /dev/null @@ -1,132 +0,0 @@ -adminUser = $this->drupalCreateUser(['administer permissions', 'administer users']); - $this->drupalPlaceBlock('local_tasks_block'); - } - - /** - * Test adding, renaming and deleting roles. - */ - public function testRoleAdministration() { - $this->drupalLogin($this->adminUser); - $default_langcode = \Drupal::languageManager()->getDefaultLanguage()->getId(); - // Test presence of tab. - $this->drupalGet('admin/people/permissions'); - $tabs = $this->xpath('//ul[@class=:classes and //a[contains(., :text)]]', [ - ':classes' => 'tabs primary', - ':text' => t('Roles'), - ]); - $this->assertEqual(count($tabs), 1, 'Found roles tab'); - - // 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 = ['label' => $role_name, 'id' => $role_name]; - $this->drupalPostForm('admin/people/roles/add', $edit, t('Save')); - $this->assertRaw(t('Role %label has been added.', ['%label' => 123])); - $role = Role::load($role_name); - $this->assertTrue(is_object($role), 'The role was successfully retrieved from the database.'); - - // Check that the role was created in site default language. - $this->assertEqual($role->language()->getId(), $default_langcode); - - // Try adding a duplicate role. - $this->drupalPostForm('admin/people/roles/add', $edit, t('Save')); - $this->assertRaw(t('The machine-readable name is already in use. It must be unique.'), 'Duplicate role warning displayed.'); - - // Test renaming a role. - $role_name = '456'; - $edit = ['label' => $role_name]; - $this->drupalPostForm("admin/people/roles/manage/{$role->id()}", $edit, t('Save')); - $this->assertRaw(t('Role %label has been updated.', ['%label' => $role_name])); - \Drupal::entityManager()->getStorage('user_role')->resetCache([$role->id()]); - $new_role = Role::load($role->id()); - $this->assertEqual($new_role->label(), $role_name, 'The role name has been successfully changed.'); - - // Test deleting a role. - $this->drupalGet("admin/people/roles/manage/{$role->id()}"); - $this->clickLink(t('Delete')); - $this->drupalPostForm(NULL, [], t('Delete')); - $this->assertRaw(t('The role %label has been deleted.', ['%label' => $role_name])); - $this->assertNoLinkByHref("admin/people/roles/manage/{$role->id()}", 'Role edit link removed.'); - \Drupal::entityManager()->getStorage('user_role')->resetCache([$role->id()]); - $this->assertFalse(Role::load($role->id()), '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/manage/' . RoleInterface::ANONYMOUS_ID); - $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/manage/' . RoleInterface::AUTHENTICATED_ID); - $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 and ordering. - */ - public function testRoleWeightOrdering() { - $this->drupalLogin($this->adminUser); - $roles = user_roles(); - $weight = count($roles); - $new_role_weights = []; - $saved_rids = []; - - // Change the role weights to make the roles in reverse order. - $edit = []; - foreach ($roles as $role) { - $edit['entities[' . $role->id() . '][weight]'] = $weight; - $new_role_weights[$role->id()] = $weight; - $saved_rids[] = $role->id(); - $weight--; - } - $this->drupalPostForm('admin/people/roles', $edit, t('Save')); - $this->assertText(t('The role settings have been updated.'), 'The role settings form submitted successfully.'); - - // Load up the user roles with the new weights. - drupal_static_reset('user_roles'); - $roles = user_roles(); - $rids = []; - // Test that the role weights have been correctly saved. - foreach ($roles as $role) { - $this->assertEqual($role->getWeight(), $new_role_weights[$role->id()]); - $rids[] = $role->id(); - } - // The order of the roles should be reversed. - $this->assertIdentical($rids, array_reverse($saved_rids)); - } - -}