public function BlockContentDeriverTest::testReusableBlocksOnlyAreDerived in Drupal 8
Same name and namespace in other branches
- 9 core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php \Drupal\Tests\block_content\Kernel\BlockContentDeriverTest::testReusableBlocksOnlyAreDerived()
- 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\KernelCode
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));
}