class GroupPermissionCheckerTest in Group 8
Same name and namespace in other branches
- 2.0.x tests/src/Unit/GroupPermissionCheckerTest.php \Drupal\Tests\group\Unit\GroupPermissionCheckerTest
Tests the group permission checker service.
@coversDefaultClass \Drupal\group\Access\GroupPermissionChecker @group group
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\group\Unit\GroupPermissionCheckerTest
Expanded class hierarchy of GroupPermissionCheckerTest
File
- tests/
src/ Unit/ GroupPermissionCheckerTest.php, line 20
Namespace
Drupal\Tests\group\UnitView source
class GroupPermissionCheckerTest extends UnitTestCase {
/**
* The group permission calculator.
*
* @var \Drupal\group\Access\ChainGroupPermissionCalculatorInterface|\Prophecy\Prophecy\ProphecyInterface
*/
protected $permissionCalculator;
/**
* The group permission checker.
*
* @var \Drupal\group\Access\GroupPermissionCheckerInterface
*/
protected $permissionChecker;
/**
* {@inheritdoc}
*/
public function setUp() {
parent::setUp();
$this->permissionCalculator = $this
->prophesize(ChainGroupPermissionCalculatorInterface::class);
$this->permissionChecker = new GroupPermissionChecker($this->permissionCalculator
->reveal());
}
/**
* Tests checking whether a user has a permission in a group.
*
* @param bool $can_bypass
* Whether the user can bypass group access.
* @param bool $is_anon
* Whether the user is anonymous.
* @param array $group_type_permissions
* The permissions the user has in the group type scope.
* @param array $group_permissions
* The permissions the user has in the group scope.
* @param string $permission
* The permission to check for.
* @param bool $has_permission
* Whether the user should have the permission.
* @param string $message
* The message to use in the assertion.
*
* @covers ::hasPermissionInGroup
* @dataProvider provideHasPermissionInGroupScenarios
*/
public function testHasPermissionInGroup($can_bypass, $is_anon, $group_type_permissions, $group_permissions, $permission, $has_permission, $message) {
$account = $this
->prophesize(AccountInterface::class);
$account
->hasPermission('bypass group access')
->willReturn($can_bypass);
$account
->isAnonymous()
->willReturn($is_anon);
$group = $this
->prophesize(GroupInterface::class);
$group
->id()
->willReturn(1);
$group
->bundle()
->willReturn('foo');
$scope_gt = CalculatedGroupPermissionsItemInterface::SCOPE_GROUP_TYPE;
$scope_g = CalculatedGroupPermissionsItemInterface::SCOPE_GROUP;
$calculated_permissions = new RefinableCalculatedGroupPermissions();
foreach ($group_type_permissions as $identifier => $permissions) {
$calculated_permissions
->addItem(new CalculatedGroupPermissionsItem($scope_gt, $identifier, $permissions));
}
foreach ($group_permissions as $identifier => $permissions) {
$calculated_permissions
->addItem(new CalculatedGroupPermissionsItem($scope_g, $identifier, $permissions));
}
$this->permissionCalculator
->calculatePermissions($account
->reveal())
->willReturn($calculated_permissions);
$result = $this->permissionChecker
->hasPermissionInGroup($permission, $account
->reveal(), $group
->reveal());
$this
->assertSame($has_permission, $result, $message);
}
/**
* Data provider for testHasPermissionInGroup().
*
* All scenarios assume group ID 1 and type 'foo'.
*/
public function provideHasPermissionInGroupScenarios() {
$scenarios['anonymousWithBypass'] = [
TRUE,
TRUE,
[],
[],
'view group',
TRUE,
'An anonymous user with the bypass permission can view the group.',
];
$scenarios['authenticatedWithBypass'] = [
TRUE,
FALSE,
[],
[],
'view group',
TRUE,
'An authenticated user with the bypass permission can view the group.',
];
$scenarios['anonymousWithAdmin'] = [
FALSE,
TRUE,
[
'foo' => [
'administer group',
],
],
[],
'view group',
TRUE,
'An anonymous user with the group admin permission can view the group.',
];
$scenarios['outsiderWithAdmin'] = [
FALSE,
FALSE,
[
'foo' => [
'administer group',
],
],
[],
'view group',
TRUE,
'An outsider with the group admin permission can view the group.',
];
$scenarios['memberWithAdmin'] = [
FALSE,
FALSE,
[],
[
1 => [
'administer group',
],
],
'view group',
TRUE,
'A member with the group admin permission can view the group.',
];
$scenarios['anonymousWithPermission'] = [
FALSE,
TRUE,
[
'foo' => [
'view group',
],
],
[],
'view group',
TRUE,
'An anonymous user with the right permission can view the group.',
];
$scenarios['outsiderWithPermission'] = [
FALSE,
FALSE,
[
'foo' => [
'view group',
],
],
[],
'view group',
TRUE,
'An outsider with the right permission can view the group.',
];
$scenarios['memberWithPermission'] = [
FALSE,
FALSE,
[],
[
1 => [
'view group',
],
],
'view group',
TRUE,
'A member with the right permission can view the group.',
];
$scenarios['anonymousWithoutPermission'] = [
FALSE,
TRUE,
[
'foo' => [],
],
[],
'view group',
FALSE,
'An anonymous user without the right permission can not view the group.',
];
$scenarios['outsiderWithoutPermission'] = [
FALSE,
FALSE,
[
'foo' => [],
],
[],
'view group',
FALSE,
'An outsider without the right permission can not view the group.',
];
$scenarios['memberWithoutPermission'] = [
FALSE,
FALSE,
[],
[
1 => [],
],
'view group',
FALSE,
'A member without the right permission can not view the group.',
];
return $scenarios;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
GroupPermissionCheckerTest:: |
protected | property | The group permission calculator. | |
GroupPermissionCheckerTest:: |
protected | property | The group permission checker. | |
GroupPermissionCheckerTest:: |
public | function | Data provider for testHasPermissionInGroup(). | |
GroupPermissionCheckerTest:: |
public | function |
Overrides UnitTestCase:: |
|
GroupPermissionCheckerTest:: |
public | function | Tests checking whether a user has a permission in a group. | |
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | 1 |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. |