function UserRoleEntityTest::testGrantingNonExistentPermission

Same name 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()

File

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

Class

UserRoleEntityTest
@group user @coversDefaultClass \Drupal\user\Entity\Role

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.