function UserRoleEntityTest::testGrantingNonExistentPermission

Same name and namespace in other branches
  1. 9 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php \Drupal\Tests\user\Kernel\UserRoleEntityTest::testGrantingNonExistentPermission()
  2. 10 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php \Drupal\Tests\user\Kernel\UserRoleEntityTest::testGrantingNonExistentPermission()

Tests granting non-existent permissions to a role.

File

core/modules/user/tests/src/Kernel/UserRoleEntityTest.php, line 55

Class

UserRoleEntityTest
@group user @coversDefaultClass \Drupal\user\Entity\Role[[api-linebreak]]

Namespace

Drupal\Tests\user\Kernel

Code

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.