function UserRoleEntityTest::testGrantingNonExistentPermission
Same name in other branches
- 9 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php \Drupal\Tests\user\Kernel\UserRoleEntityTest::testGrantingNonExistentPermission()
- 10 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php \Drupal\Tests\user\Kernel\UserRoleEntityTest::testGrantingNonExistentPermission()
File
-
core/
modules/ user/ tests/ src/ Kernel/ UserRoleEntityTest.php, line 49
Class
- UserRoleEntityTest
- @group user @coversDefaultClass \Drupal\user\Entity\Role
Namespace
Drupal\Tests\user\KernelCode
public function testGrantingNonExistentPermission() : void {
$role = Role::create([
'id' => 'test_role',
'label' => 'Test role',
]);
// A single permission that does not exist.
$role->grantPermission('does not exist')
->save();
$log_message = \Drupal::service(BufferingLogger::class)->cleanLogs()[0];
$this->assertSame(RfcLogLevel::ERROR, $log_message[0]);
$this->assertSame('Non-existent permission(s) assigned to role "@label" (@id) were removed. Invalid permission(s): @permissions.', $log_message[1]);
$this->assertSame('Test role', $log_message[2]['@label']);
$this->assertSame('test_role', $log_message[2]['@id']);
$this->assertSame('does not exist', $log_message[2]['@permissions']);
// Multiple permissions that do not exist.
$role->grantPermission('does not exist')
->grantPermission('also does not exist')
->save();
$log_message = \Drupal::service(BufferingLogger::class)->cleanLogs()[0];
$this->assertSame(RfcLogLevel::ERROR, $log_message[0]);
$this->assertSame('Non-existent permission(s) assigned to role "@label" (@id) were removed. Invalid permission(s): @permissions.', $log_message[1]);
$this->assertSame('Test role', $log_message[2]['@label']);
$this->assertSame('test_role', $log_message[2]['@id']);
$this->assertSame('does not exist, also does not exist', $log_message[2]['@permissions']);
$permissions = $role->getPermissions();
$this->assertEmpty(array_intersect([
'does not exist',
'also does not exist',
], $permissions));
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.