You are here

public function BlockContentDeriverTest::testReusableBlocksOnlyAreDerived in Drupal 8

Same name and namespace in other branches
  1. 9 core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php \Drupal\Tests\block_content\Kernel\BlockContentDeriverTest::testReusableBlocksOnlyAreDerived()
  2. 10 core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php \Drupal\Tests\block_content\Kernel\BlockContentDeriverTest::testReusableBlocksOnlyAreDerived()

Tests that only reusable blocks are derived.

File

core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php, line 34

Class

BlockContentDeriverTest
Tests block content plugin deriver.

Namespace

Drupal\Tests\block_content\Kernel

Code

public function testReusableBlocksOnlyAreDerived() {

  // Create a block content type.
  $block_content_type = BlockContentType::create([
    'id' => 'spiffy',
    'label' => 'Mucho spiffy',
    'description' => "Provides a block type that increases your site's spiffiness by up to 11%",
  ]);
  $block_content_type
    ->save();

  // And a block content entity.
  $block_content = BlockContent::create([
    'info' => 'Spiffy prototype',
    'type' => 'spiffy',
  ]);
  $block_content
    ->save();

  // Ensure the reusable block content is provided as a derivative block
  // plugin.

  /** @var \Drupal\Core\Block\BlockManagerInterface $block_manager */
  $block_manager = $this->container
    ->get('plugin.manager.block');
  $plugin_id = 'block_content' . PluginBase::DERIVATIVE_SEPARATOR . $block_content
    ->uuid();
  $this
    ->assertTrue($block_manager
    ->hasDefinition($plugin_id));

  // Set the block not to be reusable.
  $block_content
    ->setNonReusable();
  $block_content
    ->save();

  // Ensure the non-reusable block content is not provided a derivative block
  // plugin.
  $this
    ->assertFalse($block_manager
    ->hasDefinition($plugin_id));
}