UserRoleEntityTest.php

Same filename and directory in other branches
  1. 9 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php
  2. 8.9.x core/modules/user/tests/src/Kernel/UserRoleEntityTest.php
  3. 10 core/modules/user/tests/src/Kernel/UserRoleEntityTest.php

Namespace

Drupal\Tests\user\Kernel

File

core/modules/user/tests/src/Kernel/UserRoleEntityTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\user\Kernel;

use Drupal\Core\DependencyInjection\ContainerBuilder;
use Drupal\Core\Logger\RfcLogLevel;
use Drupal\KernelTests\KernelTestBase;
use Drupal\user\Entity\Role;
use Symfony\Component\ErrorHandler\BufferingLogger;

/**
 * @group user
 * @coversDefaultClass \Drupal\user\Entity\Role
 */
class UserRoleEntityTest extends KernelTestBase {
  
  /**
   * {@inheritdoc}
   */
  protected static $modules = [
    'system',
    'user',
    'user_permissions_test',
  ];
  
  /**
   * {@inheritdoc}
   */
  public function register(ContainerBuilder $container) : void {
    parent::register($container);
    $container->register(BufferingLogger::class)
      ->addTag('logger');
  }
  
  /**
   * Tests the order of granted permissions in a role.
   */
  public function testOrderOfPermissions() : void {
    $role = Role::create([
      'id' => 'test_role',
      'label' => 'Test role',
    ]);
    $role->grantPermission('b')
      ->grantPermission('a')
      ->grantPermission('c')
      ->save();
    $this->assertEquals([
      'a',
      'b',
      'c',
    ], $role->getPermissions());
    $role->revokePermission('b')
      ->save();
    $this->assertEquals([
      'a',
      'c',
    ], $role->getPermissions());
    $role->grantPermission('b')
      ->save();
    $this->assertEquals([
      'a',
      'b',
      'c',
    ], $role->getPermissions());
  }
  
  /**
   * Tests granting non-existent permissions to a role.
   */
  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));
  }
  
  /**
   * Tests permission revocation during a configuration synchronization.
   */
  public function testPermissionRevokeAndConfigSync() : void {
    $role = Role::create([
      'id' => 'test_role',
      'label' => 'Test role',
    ]);
    $role->setSyncing(TRUE);
    $role->grantPermission('a')
      ->grantPermission('b')
      ->grantPermission('c')
      ->save();
    $this->assertSame([
      'a',
      'b',
      'c',
    ], $role->getPermissions());
    $role->revokePermission('b')
      ->save();
    $this->assertSame([
      'a',
      'c',
    ], $role->getPermissions());
  }

}

Classes

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

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.