use Drupal\Component\Plugin\Discovery\DiscoveryInterface;
use Drupal\Core\Block\BlockManager;
+use Drupal\Core\Block\Plugin\Block\Broken;
use Drupal\Core\Cache\CacheBackendInterface;
use Drupal\Core\Extension\ModuleHandlerInterface;
use Drupal\Tests\UnitTestCase;
+use Psr\Log\LoggerInterface;
/**
* @coversDefaultClass \Drupal\Core\Block\BlockManager
*/
protected $blockManager;
+ /**
+ * The logger.
+ *
+ * @var \Psr\Log\LoggerInterface
+ */
+ protected $logger;
+
/**
* {@inheritdoc}
*/
$cache_backend = $this->prophesize(CacheBackendInterface::class);
$module_handler = $this->prophesize(ModuleHandlerInterface::class);
- $this->blockManager = new BlockManager(new \ArrayObject(), $cache_backend->reveal(), $module_handler->reveal());
+ $this->logger = $this->prophesize(LoggerInterface::class);
+ $this->blockManager = new BlockManager(new \ArrayObject(), $cache_backend->reveal(), $module_handler->reveal(), $this->logger->reveal());
$this->blockManager->setStringTranslation($this->getStringTranslationStub());
$discovery = $this->prophesize(DiscoveryInterface::class);
'broken' => [
'admin_label' => 'Broken/Missing',
'category' => 'Block',
+ 'class' => Broken::class,
+ 'provider' => 'core',
],
'block1' => [
'admin_label' => 'Coconut',
$this->assertSame(['block3', 'block1'], array_keys($definitions['Group 2']));
}
+ /**
+ * @covers ::handlePluginNotFound
+ */
+ public function testHandlePluginNotFound() {
+ $this->logger->warning('The "%plugin_id" was not found', ['%plugin_id' => 'invalid'])->shouldBeCalled();
+ $plugin = $this->blockManager->createInstance('invalid');
+ $this->assertSame('broken', $plugin->getPluginId());
+ }
+
}