You are here

class HookDiscoveryTest in Drupal 9

Same name and namespace in other branches
  1. 8 core/tests/Drupal/Tests/Core/Plugin/Discovery/HookDiscoveryTest.php \Drupal\Tests\Core\Plugin\Discovery\HookDiscoveryTest

@coversDefaultClass \Drupal\Core\Plugin\Discovery\HookDiscovery @group Plugin

Hierarchy

Expanded class hierarchy of HookDiscoveryTest

File

core/tests/Drupal/Tests/Core/Plugin/Discovery/HookDiscoveryTest.php, line 13

Namespace

Drupal\Tests\Core\Plugin\Discovery
View source
class HookDiscoveryTest extends UnitTestCase {

  /**
   * The mocked module handler.
   *
   * @var \Drupal\Core\Extension\ModuleHandlerInterface|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $moduleHandler;

  /**
   * The tested hook discovery.
   *
   * @var \Drupal\Core\Plugin\Discovery\HookDiscovery
   */
  protected $hookDiscovery;

  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    $this->moduleHandler = $this
      ->createMock('Drupal\\Core\\Extension\\ModuleHandlerInterface');
    $this->hookDiscovery = new HookDiscovery($this->moduleHandler, 'test_plugin');
  }

  /**
   * Tests the getDefinitions() method without any plugins.
   *
   * @see \Drupal\Core\Plugin\Discovery::getDefinitions()
   */
  public function testGetDefinitionsWithoutPlugins() {
    $this->moduleHandler
      ->expects($this
      ->once())
      ->method('getImplementations')
      ->with('test_plugin')
      ->will($this
      ->returnValue([]));
    $this
      ->assertCount(0, $this->hookDiscovery
      ->getDefinitions());
  }

  /**
   * Tests the getDefinitions() method with some plugins.
   *
   * @see \Drupal\Core\Plugin\Discovery::getDefinitions()
   */
  public function testGetDefinitions() {
    $this->moduleHandler
      ->expects($this
      ->once())
      ->method('getImplementations')
      ->with('test_plugin')
      ->will($this
      ->returnValue([
      'hook_discovery_test',
      'hook_discovery_test2',
    ]));
    $this->moduleHandler
      ->expects($this
      ->exactly(2))
      ->method('invoke')
      ->willReturnMap([
      [
        'hook_discovery_test',
        'test_plugin',
        [],
        $this
          ->hookDiscoveryTestTestPlugin(),
      ],
      [
        'hook_discovery_test2',
        'test_plugin',
        [],
        $this
          ->hookDiscoveryTest2TestPlugin(),
      ],
    ]);
    $definitions = $this->hookDiscovery
      ->getDefinitions();
    $this
      ->assertCount(3, $definitions);
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Apple', $definitions['test_id_1']['class']);
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Orange', $definitions['test_id_2']['class']);
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Cherry', $definitions['test_id_3']['class']);

    // Ensure that the module was set.
    $this
      ->assertEquals('hook_discovery_test', $definitions['test_id_1']['provider']);
    $this
      ->assertEquals('hook_discovery_test', $definitions['test_id_2']['provider']);
    $this
      ->assertEquals('hook_discovery_test2', $definitions['test_id_3']['provider']);
  }

  /**
   * Tests the getDefinition method with some plugins.
   *
   * @see \Drupal\Core\Plugin\Discovery::getDefinition()
   */
  public function testGetDefinition() {
    $this->moduleHandler
      ->expects($this
      ->exactly(4))
      ->method('getImplementations')
      ->with('test_plugin')
      ->will($this
      ->returnValue([
      'hook_discovery_test',
      'hook_discovery_test2',
    ]));
    $this->moduleHandler
      ->expects($this
      ->any())
      ->method('invoke')
      ->willReturnMap([
      [
        'hook_discovery_test',
        'test_plugin',
        [],
        $this
          ->hookDiscoveryTestTestPlugin(),
      ],
      [
        'hook_discovery_test2',
        'test_plugin',
        [],
        $this
          ->hookDiscoveryTest2TestPlugin(),
      ],
    ]);
    $this
      ->assertNull($this->hookDiscovery
      ->getDefinition('test_non_existent', FALSE));
    $plugin_definition = $this->hookDiscovery
      ->getDefinition('test_id_1');
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Apple', $plugin_definition['class']);
    $this
      ->assertEquals('hook_discovery_test', $plugin_definition['provider']);
    $plugin_definition = $this->hookDiscovery
      ->getDefinition('test_id_2');
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Orange', $plugin_definition['class']);
    $this
      ->assertEquals('hook_discovery_test', $plugin_definition['provider']);
    $plugin_definition = $this->hookDiscovery
      ->getDefinition('test_id_3');
    $this
      ->assertEquals('Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Cherry', $plugin_definition['class']);
    $this
      ->assertEquals('hook_discovery_test2', $plugin_definition['provider']);
  }

  /**
   * Tests the getDefinition method with an unknown plugin ID.
   *
   * @see \Drupal\Core\Plugin\Discovery::getDefinition()
   */
  public function testGetDefinitionWithUnknownID() {
    $this->moduleHandler
      ->expects($this
      ->once())
      ->method('getImplementations')
      ->will($this
      ->returnValue([]));
    $this
      ->expectException(PluginNotFoundException::class);
    $this->hookDiscovery
      ->getDefinition('test_non_existent', TRUE);
  }
  protected function hookDiscoveryTestTestPlugin() {
    return [
      'test_id_1' => [
        'class' => 'Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Apple',
      ],
      'test_id_2' => [
        'class' => 'Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Orange',
      ],
    ];
  }
  protected function hookDiscoveryTest2TestPlugin() {
    return [
      'test_id_3' => [
        'class' => 'Drupal\\plugin_test\\Plugin\\plugin_test\\fruit\\Cherry',
      ],
    ];
  }

}

Members

Namesort descending Modifiers Type Description Overrides
HookDiscoveryTest::$hookDiscovery protected property The tested hook discovery.
HookDiscoveryTest::$moduleHandler protected property The mocked module handler.
HookDiscoveryTest::hookDiscoveryTest2TestPlugin protected function
HookDiscoveryTest::hookDiscoveryTestTestPlugin protected function
HookDiscoveryTest::setUp protected function Overrides UnitTestCase::setUp
HookDiscoveryTest::testGetDefinition public function Tests the getDefinition method with some plugins.
HookDiscoveryTest::testGetDefinitions public function Tests the getDefinitions() method with some plugins.
HookDiscoveryTest::testGetDefinitionsWithoutPlugins public function Tests the getDefinitions() method without any plugins.
HookDiscoveryTest::testGetDefinitionWithUnknownID public function Tests the getDefinition method with an unknown plugin ID.
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals Deprecated protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.
UnitTestCase::setUpBeforeClass public static function