function DateFormatAccessControlHandlerTest::testAccessProvider

Same name and namespace in other branches
  1. 9 core/modules/system/tests/src/Kernel/DateFormatAccessControlHandlerTest.php \Drupal\Tests\system\Kernel\DateFormatAccessControlHandlerTest::testAccessProvider()
  2. 8.9.x core/modules/system/tests/src/Kernel/DateFormatAccessControlHandlerTest.php \Drupal\Tests\system\Kernel\DateFormatAccessControlHandlerTest::testAccessProvider()
  3. 10 core/modules/system/tests/src/Kernel/DateFormatAccessControlHandlerTest.php \Drupal\Tests\system\Kernel\DateFormatAccessControlHandlerTest::testAccessProvider()

File

core/modules/system/tests/src/Kernel/DateFormatAccessControlHandlerTest.php, line 75

Class

DateFormatAccessControlHandlerTest
@coversDefaultClass <a href="/api/drupal/core%21modules%21system%21src%21DateFormatAccessControlHandler.php/class/DateFormatAccessControlHandler/11.x" title="Defines the access control handler for the date format entity type." class="local">\Drupal\system\DateFormatAccessControlHandler</a> @group system

Namespace

Drupal\Tests\system\Kernel

Code

public static function testAccessProvider() {
    $c = new ContainerBuilder();
    $cache_contexts_manager = (new Prophet())->prophesize(CacheContextsManager::class);
    $cache_contexts_manager->assertValidTokens()
        ->willReturn(TRUE);
    $cache_contexts_manager->reveal();
    $c->set('cache_contexts_manager', $cache_contexts_manager);
    \Drupal::setContainer($c);
    return [
        'permissionless + unlocked' => [
            [],
            'unlocked',
            AccessResult::allowed(),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required."),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required.")
                ->addCacheTags([
                'rendered',
            ]),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required.")
                ->addCacheTags([
                'rendered',
            ]),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required."),
        ],
        'permissionless + locked' => [
            [],
            'locked',
            AccessResult::allowed(),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required."),
            AccessResult::forbidden()->addCacheTags([
                'rendered',
            ])
                ->setReason("The DateFormat config entity is locked."),
            AccessResult::forbidden()->addCacheTags([
                'rendered',
            ])
                ->setReason("The DateFormat config entity is locked."),
            AccessResult::neutral()->addCacheContexts([
                'user.permissions',
            ])
                ->setReason("The 'administer site configuration' permission is required."),
        ],
        'admin + unlocked' => [
            [
                'administer site configuration',
            ],
            'unlocked',
            AccessResult::allowed(),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ]),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ])
                ->addCacheTags([
                'rendered',
            ]),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ])
                ->addCacheTags([
                'rendered',
            ]),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ]),
        ],
        'admin + locked' => [
            [
                'administer site configuration',
            ],
            'locked',
            AccessResult::allowed(),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ]),
            AccessResult::forbidden()->addCacheTags([
                'rendered',
            ])
                ->setReason("The DateFormat config entity is locked."),
            AccessResult::forbidden()->addCacheTags([
                'rendered',
            ])
                ->setReason("The DateFormat config entity is locked."),
            AccessResult::allowed()->addCacheContexts([
                'user.permissions',
            ]),
        ],
    ];
}

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