View source
<?php
namespace Drupal\Tests\user\Unit;
use Drupal\Core\Access\AccessResult;
use Drupal\Tests\UnitTestCase;
use Drupal\user\Access\PermissionAccessCheck;
use Symfony\Component\Routing\Route;
use Drupal\Core\Cache\Context\CacheContextsManager;
use Symfony\Component\DependencyInjection\ContainerBuilder;
class PermissionAccessCheckTest extends UnitTestCase {
public $accessCheck;
protected $container;
protected function setUp() : void {
parent::setUp();
$this->container = new ContainerBuilder();
$cache_contexts_manager = $this
->prophesize(CacheContextsManager::class);
$cache_contexts_manager
->assertValidTokens()
->willReturn(TRUE);
$cache_contexts_manager
->reveal();
$this->container
->set('cache_contexts_manager', $cache_contexts_manager);
\Drupal::setContainer($this->container);
$this->accessCheck = new PermissionAccessCheck();
}
public function providerTestAccess() {
return [
[
[],
FALSE,
],
[
[
'_permission' => 'allowed',
],
TRUE,
[
'user.permissions',
],
],
[
[
'_permission' => 'denied',
],
FALSE,
[
'user.permissions',
],
"The 'denied' permission is required.",
],
[
[
'_permission' => 'allowed+denied',
],
TRUE,
[
'user.permissions',
],
],
[
[
'_permission' => 'allowed+denied+other',
],
TRUE,
[
'user.permissions',
],
],
[
[
'_permission' => 'allowed,denied',
],
FALSE,
[
'user.permissions',
],
"The following permissions are required: 'allowed' AND 'denied'.",
],
];
}
public function testAccess($requirements, $access, array $contexts = [], $message = '') {
$access_result = AccessResult::allowedIf($access)
->addCacheContexts($contexts);
if (!empty($message)) {
$access_result
->setReason($message);
}
$user = $this
->createMock('Drupal\\Core\\Session\\AccountInterface');
$user
->expects($this
->any())
->method('hasPermission')
->willReturnMap([
[
'allowed',
TRUE,
],
[
'denied',
FALSE,
],
[
'other',
FALSE,
],
]);
$route = new Route('', [], $requirements);
$this
->assertEquals($access_result, $this->accessCheck
->access($route, $user));
}
}