function FilteredPluginManagerTraitTest::testGetFilteredDefinitions

Same name and namespace in other branches
  1. 9 core/tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php \Drupal\Tests\Core\Plugin\FilteredPluginManagerTraitTest::testGetFilteredDefinitions()
  2. 8.9.x core/tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php \Drupal\Tests\Core\Plugin\FilteredPluginManagerTraitTest::testGetFilteredDefinitions()
  3. 11.x core/tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php \Drupal\Tests\Core\Plugin\FilteredPluginManagerTraitTest::testGetFilteredDefinitions()

@covers ::getFilteredDefinitions @dataProvider providerTestGetFilteredDefinitions

File

core/tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php, line 25

Class

FilteredPluginManagerTraitTest
@coversDefaultClass <a href="/api/drupal/core%21lib%21Drupal%21Core%21Plugin%21FilteredPluginManagerTrait.php/trait/FilteredPluginManagerTrait/10" title="Provides a trait for plugin managers that allow filtering plugin definitions." class="local">\Drupal\Core\Plugin\FilteredPluginManagerTrait</a> @group Plugin

Namespace

Drupal\Tests\Core\Plugin

Code

public function testGetFilteredDefinitions($contexts, $expected) : void {
    // Start with two plugins.
    $definitions = [];
    $definitions['plugin1'] = [
        'id' => 'plugin1',
    ];
    $definitions['plugin2'] = [
        'id' => 'plugin2',
    ];
    $type = 'the_type';
    $consumer = 'the_consumer';
    $extra = [
        'foo' => 'bar',
    ];
    $context_handler = $this->prophesize(ContextHandlerInterface::class);
    // Remove the second plugin when context1 is provided.
    $context_handler->filterPluginDefinitionsByContexts([
        'context1' => 'fake context',
    ], $definitions)
        ->willReturn([
        'plugin1' => $definitions['plugin1'],
    ]);
    // Remove the first plugin when no contexts are provided.
    $context_handler->filterPluginDefinitionsByContexts([], $definitions)
        ->willReturn([
        'plugin2' => $definitions['plugin2'],
    ]);
    // After context filtering, the alter hook will be invoked.
    $module_handler = $this->prophesize(ModuleHandlerInterface::class);
    $hooks = [
        "plugin_filter_{$type}",
        "plugin_filter_{$type}__{$consumer}",
    ];
    $module_handler->alter($hooks, $expected, $extra, $consumer)
        ->shouldBeCalled();
    $theme_manager = $this->prophesize(ThemeManagerInterface::class);
    $theme_manager->alter($hooks, $expected, $extra, $consumer)
        ->shouldBeCalled();
    $plugin_manager = new TestFilteredPluginManager($definitions, $module_handler->reveal(), $theme_manager->reveal(), $context_handler->reveal());
    $result = $plugin_manager->getFilteredDefinitions($consumer, $contexts, $extra);
    $this->assertSame($expected, $result);
}

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