class ContextTest in Drupal 8
Same name in this branch
- 8 core/tests/Drupal/Tests/Core/Plugin/Context/ContextTest.php \Drupal\Tests\Core\Plugin\Context\ContextTest
- 8 core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php \Drupal\Tests\Component\Plugin\Context\ContextTest
Same name and namespace in other branches
- 9 core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php \Drupal\Tests\Component\Plugin\Context\ContextTest
- 10 core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php \Drupal\Tests\Component\Plugin\Context\ContextTest
@coversDefaultClass \Drupal\Component\Plugin\Context\Context @group Plugin
Hierarchy
- class \Drupal\Tests\Component\Plugin\Context\ContextTest extends \PHPUnit\Framework\TestCase
Expanded class hierarchy of ContextTest
File
- core/
tests/ Drupal/ Tests/ Component/ Plugin/ Context/ ContextTest.php, line 12
Namespace
Drupal\Tests\Component\Plugin\ContextView source
class ContextTest extends TestCase {
/**
* Data provider for testGetContextValue.
*/
public function providerGetContextValue() {
return [
[
'context_value',
'context_value',
FALSE,
'data_type',
],
[
NULL,
NULL,
FALSE,
'data_type',
],
[
'will throw exception',
NULL,
TRUE,
'data_type',
],
];
}
/**
* @covers ::getContextValue
* @dataProvider providerGetContextValue
*/
public function testGetContextValue($expected, $context_value, $is_required, $data_type) {
// Mock a Context object.
$mock_context = $this
->getMockBuilder('Drupal\\Component\\Plugin\\Context\\Context')
->disableOriginalConstructor()
->setMethods([
'getContextDefinition',
])
->getMock();
// If the context value exists, getContextValue() behaves like a normal
// getter.
if ($context_value) {
// Set visibility of contextValue.
$ref_context_value = new \ReflectionProperty($mock_context, 'contextValue');
$ref_context_value
->setAccessible(TRUE);
// Set contextValue to a testable state.
$ref_context_value
->setValue($mock_context, $context_value);
// Exercise getContextValue().
$this
->assertEquals($context_value, $mock_context
->getContextValue());
}
else {
// Create a mock definition.
$mock_definition = $this
->getMockBuilder('Drupal\\Component\\Plugin\\Context\\ContextDefinitionInterface')
->setMethods([
'isRequired',
'getDataType',
])
->getMockForAbstractClass();
// Set expectation for isRequired().
$mock_definition
->expects($this
->once())
->method('isRequired')
->willReturn($is_required);
// Set expectation for getDataType().
$mock_definition
->expects($this
->exactly($is_required ? 1 : 0))
->method('getDataType')
->willReturn($data_type);
// Set expectation for getContextDefinition().
$mock_context
->expects($this
->once())
->method('getContextDefinition')
->willReturn($mock_definition);
// Set expectation for exception.
if ($is_required) {
$this
->expectException('Drupal\\Component\\Plugin\\Exception\\ContextException');
$this
->expectExceptionMessage(sprintf("The %s context is required and not present.", $data_type));
}
// Exercise getContextValue().
$this
->assertEquals($context_value, $mock_context
->getContextValue());
}
}
/**
* @covers ::getContextValue
*/
public function testDefaultValue() {
$mock_definition = $this
->getMockBuilder('Drupal\\Component\\Plugin\\Context\\ContextDefinitionInterface')
->setMethods([
'getDefaultValue',
])
->getMockForAbstractClass();
$mock_definition
->expects($this
->once())
->method('getDefaultValue')
->willReturn('test');
$context = new Context($mock_definition);
$this
->assertEquals('test', $context
->getContextValue());
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ContextTest:: |
public | function | Data provider for testGetContextValue. | |
ContextTest:: |
public | function | @covers ::getContextValue | |
ContextTest:: |
public | function | @covers ::getContextValue @dataProvider providerGetContextValue |