class DiscoveryTraitTest
Same name in other branches
- 9 core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php \Drupal\Tests\Component\Plugin\Discovery\DiscoveryTraitTest
- 8.9.x core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php \Drupal\Tests\Component\Plugin\Discovery\DiscoveryTraitTest
- 10 core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php \Drupal\Tests\Component\Plugin\Discovery\DiscoveryTraitTest
@group Plugin @coversDefaultClass \Drupal\Component\Plugin\Discovery\DiscoveryTrait
Hierarchy
- class \Drupal\Tests\Component\Plugin\Discovery\DiscoveryTraitTest extends \PHPUnit\Framework\TestCase
Expanded class hierarchy of DiscoveryTraitTest
File
-
core/
tests/ Drupal/ Tests/ Component/ Plugin/ Discovery/ DiscoveryTraitTest.php, line 15
Namespace
Drupal\Tests\Component\Plugin\DiscoveryView source
class DiscoveryTraitTest extends TestCase {
/**
* Data provider for testDoGetDefinition().
*
* @return array
* - Expected plugin definition.
* - Plugin definition array, to pass to doGetDefinition().
* - Plugin ID to get, passed to doGetDefinition().
*/
public static function providerDoGetDefinition() {
return [
[
'definition',
[
'plugin_name' => 'definition',
],
'plugin_name',
],
[
NULL,
[
'plugin_name' => 'definition',
],
'bad_plugin_name',
],
];
}
/**
* @covers ::doGetDefinition
* @dataProvider providerDoGetDefinition
*/
public function testDoGetDefinition($expected, $definitions, $plugin_id) : void {
$trait = new DiscoveryTraitMockableClass();
// Un-protect the method using reflection.
$method_ref = new \ReflectionMethod($trait, 'doGetDefinition');
// Call doGetDefinition, with $exception_on_invalid always FALSE.
$this->assertSame($expected, $method_ref->invoke($trait, $definitions, $plugin_id, FALSE));
}
/**
* Data provider for testDoGetDefinitionException()
*
* @return array
* - Expected plugin definition.
* - Plugin definition array, to pass to doGetDefinition().
* - Plugin ID to get, passed to doGetDefinition().
*/
public static function providerDoGetDefinitionException() {
return [
[
FALSE,
[
'plugin_name' => 'definition',
],
'bad_plugin_name',
],
];
}
/**
* @covers ::doGetDefinition
* @dataProvider providerDoGetDefinitionException
* @uses \Drupal\Component\Plugin\Exception\PluginNotFoundException
*/
public function testDoGetDefinitionException($expected, $definitions, $plugin_id) : void {
$trait = new DiscoveryTraitMockableClass();
// Un-protect the method using reflection.
$method_ref = new \ReflectionMethod($trait, 'doGetDefinition');
// Call doGetDefinition, with $exception_on_invalid always TRUE.
$this->expectException(PluginNotFoundException::class);
$method_ref->invoke($trait, $definitions, $plugin_id, TRUE);
}
/**
* @covers ::getDefinition
* @dataProvider providerDoGetDefinition
*/
public function testGetDefinition($expected, $definitions, $plugin_id) : void {
// Since getDefinition is a wrapper around doGetDefinition(), we can re-use
// its data provider. We just have to tell abstract method getDefinitions()
// to use the $definitions array.
$trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
->onlyMethods([
'getDefinitions',
])
->getMock();
$trait->expects($this->once())
->method('getDefinitions')
->willReturn($definitions);
// Call getDefinition(), with $exception_on_invalid always FALSE.
$this->assertSame($expected, $trait->getDefinition($plugin_id, FALSE));
}
/**
* @covers ::getDefinition
* @dataProvider providerDoGetDefinitionException
* @uses \Drupal\Component\Plugin\Exception\PluginNotFoundException
*/
public function testGetDefinitionException($expected, $definitions, $plugin_id) : void {
// Since getDefinition is a wrapper around doGetDefinition(), we can re-use
// its data provider. We just have to tell abstract method getDefinitions()
// to use the $definitions array.
$trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
->onlyMethods([
'getDefinitions',
])
->getMock();
$trait->expects($this->once())
->method('getDefinitions')
->willReturn($definitions);
// Call getDefinition(), with $exception_on_invalid always TRUE.
$this->expectException(PluginNotFoundException::class);
$trait->getDefinition($plugin_id, TRUE);
}
/**
* Data provider for testHasDefinition().
*
* @return array
* - Expected TRUE or FALSE.
* - Plugin ID to look for.
*/
public static function providerHasDefinition() {
return [
[
TRUE,
'valid',
],
[
FALSE,
'not_valid',
],
];
}
/**
* @covers ::hasDefinition
* @dataProvider providerHasDefinition
*/
public function testHasDefinition($expected, $plugin_id) : void {
$trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
->onlyMethods([
'getDefinition',
])
->getMock();
// Set up our mocked getDefinition() to return TRUE for 'valid' and FALSE
// for 'not_valid'.
$trait->expects($this->once())
->method('getDefinition')
->willReturnMap([
[
'valid',
FALSE,
TRUE,
],
[
'not_valid',
FALSE,
FALSE,
],
]);
// Call hasDefinition().
$this->assertSame($expected, $trait->hasDefinition($plugin_id));
}
}
Members
Title Sort descending | Modifiers | Object type | Summary |
---|---|---|---|
DiscoveryTraitTest::providerDoGetDefinition | public static | function | Data provider for testDoGetDefinition(). |
DiscoveryTraitTest::providerDoGetDefinitionException | public static | function | Data provider for testDoGetDefinitionException() |
DiscoveryTraitTest::providerHasDefinition | public static | function | Data provider for testHasDefinition(). |
DiscoveryTraitTest::testDoGetDefinition | public | function | @covers ::doGetDefinition @dataProvider providerDoGetDefinition |
DiscoveryTraitTest::testDoGetDefinitionException | public | function | @covers ::doGetDefinition @dataProvider providerDoGetDefinitionException @uses \Drupal\Component\Plugin\Exception\PluginNotFoundException |
DiscoveryTraitTest::testGetDefinition | public | function | @covers ::getDefinition @dataProvider providerDoGetDefinition |
DiscoveryTraitTest::testGetDefinitionException | public | function | @covers ::getDefinition @dataProvider providerDoGetDefinitionException @uses \Drupal\Component\Plugin\Exception\PluginNotFoundException |
DiscoveryTraitTest::testHasDefinition | public | function | @covers ::hasDefinition @dataProvider providerHasDefinition |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.