BlockTest.php

Same filename in this branch
  1. 10 core/modules/views/tests/src/Unit/Plugin/views/display/BlockTest.php
  2. 10 core/modules/block/tests/src/Kernel/Plugin/migrate/source/BlockTest.php
  3. 10 core/modules/block/tests/src/Functional/BlockTest.php
Same filename in other branches
  1. 9 core/modules/jsonapi/tests/src/Functional/BlockTest.php
  2. 9 core/modules/views/tests/src/Unit/Plugin/views/display/BlockTest.php
  3. 9 core/modules/block/tests/src/Kernel/Plugin/migrate/source/BlockTest.php
  4. 9 core/modules/block/tests/src/Functional/BlockTest.php
  5. 8.9.x core/modules/jsonapi/tests/src/Functional/BlockTest.php
  6. 8.9.x core/modules/views/tests/src/Unit/Plugin/views/display/BlockTest.php
  7. 8.9.x core/modules/block/tests/src/Kernel/Plugin/migrate/source/BlockTest.php
  8. 8.9.x core/modules/block/tests/src/Functional/BlockTest.php
  9. 11.x core/modules/jsonapi/tests/src/Functional/BlockTest.php
  10. 11.x core/modules/views/tests/src/Unit/Plugin/views/display/BlockTest.php
  11. 11.x core/modules/block/tests/src/Kernel/Plugin/migrate/source/BlockTest.php
  12. 11.x core/modules/block/tests/src/Functional/BlockTest.php

Namespace

Drupal\Tests\jsonapi\Functional

File

core/modules/jsonapi/tests/src/Functional/BlockTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\jsonapi\Functional;

use Drupal\block\Entity\Block;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\Url;

/**
 * JSON:API integration test for the "Block" config entity type.
 *
 * @group jsonapi
 * @group #slow
 */
class BlockTest extends ConfigEntityResourceTestBase {
    
    /**
     * {@inheritdoc}
     */
    protected static $modules = [
        'block',
    ];
    
    /**
     * {@inheritdoc}
     */
    protected static $entityTypeId = 'block';
    
    /**
     * {@inheritdoc}
     */
    protected static $resourceTypeName = 'block--block';
    
    /**
     * {@inheritdoc}
     *
     * @var \Drupal\block\BlockInterface
     */
    protected $entity;
    
    /**
     * {@inheritdoc}
     */
    protected $defaultTheme = 'stark';
    
    /**
     * {@inheritdoc}
     */
    protected function setUpAuthorization($method) {
        switch ($method) {
            case 'GET':
                $this->entity
                    ->setVisibilityConfig('user_role', [])
                    ->save();
                break;
        }
    }
    
    /**
     * {@inheritdoc}
     */
    protected function createEntity() {
        $block = Block::create([
            'plugin' => 'llama_block',
            'region' => 'header',
            'id' => 'llama',
            'theme' => 'stark',
        ]);
        // All blocks can be viewed by the anonymous user by default. An interesting
        // side effect of this is that any anonymous user is also able to read the
        // corresponding block config entity via REST, even if an authentication
        // provider is configured for the block config entity REST resource! In
        // other words: Block entities do not distinguish between 'view' as in
        // "render on a page" and 'view' as in "read the configuration".
        // This prevents that.
        // @todo Fix this in https://www.drupal.org/node/2820315.
        $block->setVisibilityConfig('user_role', [
            'id' => 'user_role',
            'roles' => [
                'non-existing-role' => 'non-existing-role',
            ],
            'negate' => FALSE,
            'context_mapping' => [
                'user' => '@user.current_user_context:current_user',
            ],
        ]);
        $block->save();
        return $block;
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getExpectedDocument() {
        $self_url = Url::fromUri('base:/jsonapi/block/block/' . $this->entity
            ->uuid())
            ->setAbsolute()
            ->toString(TRUE)
            ->getGeneratedUrl();
        return [
            'jsonapi' => [
                'meta' => [
                    'links' => [
                        'self' => [
                            'href' => 'http://jsonapi.org/format/1.0/',
                        ],
                    ],
                ],
                'version' => '1.0',
            ],
            'links' => [
                'self' => [
                    'href' => $self_url,
                ],
            ],
            'data' => [
                'id' => $this->entity
                    ->uuid(),
                'type' => 'block--block',
                'links' => [
                    'self' => [
                        'href' => $self_url,
                    ],
                ],
                'attributes' => [
                    'weight' => NULL,
                    'langcode' => 'en',
                    'status' => TRUE,
                    'dependencies' => [
                        'theme' => [
                            'stark',
                        ],
                    ],
                    'theme' => 'stark',
                    'region' => 'header',
                    'provider' => NULL,
                    'plugin' => 'llama_block',
                    'settings' => [
                        'id' => 'broken',
                        'label' => '',
                        'provider' => 'core',
                        'label_display' => 'visible',
                    ],
                    'visibility' => [],
                    'drupal_internal__id' => 'llama',
                ],
            ],
        ];
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getPostDocument() {
        // @todo Update once https://www.drupal.org/node/2300677 is fixed.
        return [];
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getExpectedCacheContexts(?array $sparse_fieldset = NULL) {
        // @see ::createEntity()
        return array_values(array_diff(parent::getExpectedCacheContexts(), [
            'user.permissions',
        ]));
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getExpectedCacheTags(?array $sparse_fieldset = NULL) {
        // Because the 'user.permissions' cache context is missing, the cache tag
        // for the anonymous user role is never added automatically.
        return array_values(array_diff(parent::getExpectedCacheTags(), [
            'config:user.role.anonymous',
        ]));
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getExpectedUnauthorizedAccessMessage($method) {
        switch ($method) {
            case 'GET':
                return "The block visibility condition 'user_role' denied access.";
            default:
                return parent::getExpectedUnauthorizedAccessMessage($method);
        }
    }
    
    /**
     * {@inheritdoc}
     */
    protected function getExpectedUnauthorizedAccessCacheability() {
        // @see \Drupal\block\BlockAccessControlHandler::checkAccess()
        return parent::getExpectedUnauthorizedAccessCacheability()->setCacheTags([
            '4xx-response',
            'config:block.block.llama',
            'http_response',
            'user:2',
        ])
            ->setCacheContexts([
            'url.query_args',
            'url.site',
            'user.roles',
        ]);
    }
    
    /**
     * {@inheritdoc}
     */
    protected static function getExpectedCollectionCacheability(AccountInterface $account, array $collection, ?array $sparse_fieldset = NULL, $filtered = FALSE) {
        return parent::getExpectedCollectionCacheability($account, $collection, $sparse_fieldset, $filtered)->addCacheTags([
            'user:2',
        ])
            ->addCacheContexts([
            'user.roles',
        ]);
    }

}

Classes

Title Deprecated Summary
BlockTest JSON:API integration test for the "Block" config entity type.

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