class ContextHandlerTraitTest in Rules 8.3
@coversDefaultClass \Drupal\rules\Context\ContextHandlerTrait @group Rules
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\rules\Unit\RulesUnitTestBase
- class \Drupal\Tests\rules\Unit\ContextHandlerTraitTest
- class \Drupal\Tests\rules\Unit\RulesUnitTestBase
Expanded class hierarchy of ContextHandlerTraitTest
File
- tests/
src/ Unit/ ContextHandlerTraitTest.php, line 16
Namespace
Drupal\Tests\rules\UnitView source
class ContextHandlerTraitTest extends RulesUnitTestBase {
/**
* Tests that a missing required context triggers an exception.
*
* @covers ::prepareContext
*/
public function testMissingContext() {
// Set the expected exception class and message.
$this
->expectException(EvaluationException::class);
$this
->expectExceptionMessage("Required context 'test' is missing for plugin 'testplugin'");
// Set 'getContextValue' as mocked method.
$trait = $this
->getMockForTrait(ContextHandlerTrait::class, [], '', TRUE, TRUE, TRUE, [
'getContextValue',
]);
$context_definition = $this
->prophesize(ContextDefinitionInterface::class);
// Let the trait work with an empty configuration.
$trait->configuration = ContextConfig::create()
->toArray();
// Make the context required in the definition.
$context_definition
->isRequired()
->willReturn(TRUE)
->shouldBeCalledTimes(1);
$plugin = $this
->prophesize(ContextAwarePluginInterface::class);
$plugin
->getContextDefinitions()
->willReturn([
'test' => $context_definition
->reveal(),
])
->shouldBeCalled(1);
$plugin
->getContextValue('test')
->willReturn(NULL)
->shouldBeCalled(1);
$plugin
->getPluginId()
->willReturn('testplugin')
->shouldBeCalledTimes(1);
$state = $this
->prophesize(ExecutionStateInterface::class);
// Make the 'mapContext' method visible.
$reflection = new \ReflectionClass($trait);
$method = $reflection
->getMethod('prepareContext');
$method
->setAccessible(TRUE);
$method
->invokeArgs($trait, [
$plugin
->reveal(),
$state
->reveal(),
]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ContextHandlerTraitTest:: |
public | function | Tests that a missing required context triggers an exception. | |
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
RulesUnitTestBase:: |
protected | property | The mocked expression manager object. | 1 |
RulesUnitTestBase:: |
protected | property | A mocked condition that always evaluates to FALSE. | |
RulesUnitTestBase:: |
protected | property | The mocked expression manager object. | |
RulesUnitTestBase:: |
protected | property | A mocked dummy action object. | |
RulesUnitTestBase:: |
protected | property | A mocked dummy action object. | |
RulesUnitTestBase:: |
protected | property | A mocked condition that always evaluates to TRUE. | |
RulesUnitTestBase:: |
protected | function |
Overrides UnitTestCase:: |
4 |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | 1 |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. |