EventPropertyAccessTest.php
Same filename in this branch
Namespace
Drupal\Tests\rules\Unit\Integration\EventFile
-
tests/
src/ Unit/ Integration/ Event/ EventPropertyAccessTest.php
View source
<?php
namespace Drupal\Tests\rules\Unit\Integration\Event;
use Drupal\rules\Core\RulesEventManager;
use Drupal\rules_test_event\Event\PlainEvent;
use Drupal\rules_test_event\Event\GenericEvent;
use Drupal\rules_test_event\Event\GetterEvent;
use Symfony\Component\EventDispatcher\GenericEvent as SymfonyGenericEvent;
/**
* Checks that the events defined in the rules_test_event module are correct.
*
* @group RulesEvent
*/
class EventPropertyAccessTest extends EventTestBase {
/**
* {@inheritdoc}
*/
protected function setUp() : void {
parent::setUp();
// Must enable our test module to make its plugins discoverable.
$this->enableModule('rules_test_event', [
'Drupal\\rules_test_event' => __DIR__ . '/../../../../modules/rules_test_event/src',
]);
// Tell the plugin manager where to look for plugins.
$this->moduleHandler
->getModuleDirectories()
->willReturn([
'rules_test_event' => __DIR__ . '/../../../../modules/rules_test_event/',
]);
// Create a real plugin manager with a mock moduleHandler.
$this->eventManager = new RulesEventManager($this->moduleHandler
->reveal(), $this->entityTypeBundleInfo
->reveal());
}
/**
* Tests the event metadata to ensure that all properties may be accessed.
*
* Access to properties declared in the metadata is tested using code copied
* from \Drupal\rules\EventSubscriber\GenericEventSubscriber, so this test
* does not directly test GenericEventSubscriber - that is done correctly
* in the Kernel test \Drupal\Tests\rules\Kernel\EventPropertyAccessTest.
*
* @param string $event_name
* The Plugin ID of the event being tested.
* @param object $event
* The event object being tested.
* In Drupal 9 this will be a \Symfony\Component\EventDispatcher\Event,
* In Drupal 10 this will be a \Symfony\Contracts\EventDispatcher\Event.
*
* @dataProvider provideTestEvent
*/
public function testEventContextDefinition($event_name, object $event) : void {
$plugin = $this->eventManager
->createInstance($event_name);
$context_definitions = $plugin->getContextDefinitions();
foreach ($context_definitions as $name => $definition) {
$this->assertSame('string', $definition->getDataType());
// Properties for these test events should be named <visibility>Property.
// We just want the <visibility> part.
$visibility = substr($name, 0, -8);
$this->assertSame('A ' . $visibility . ' string', $definition->getLabel());
// If this is a GenericEvent, get the value of the context variable from
// the event arguments.
if ($event instanceof SymfonyGenericEvent) {
$value = $event->getArgument($name);
}
elseif ($definition->hasGetter()) {
$value = $event->{$definition->getGetter()}();
}
else {
$getter = function ($property) {
return $this->{$property};
};
$value = $getter->call($event, $name);
}
$this->assertEquals($visibility . ' property', $value);
}
}
/**
* Provider for events to test.
*
* Passes an event name and an event object for each test case.
* Here we use all the events defined in the rules_test_event test module.
*
* @return array
* Array of array of values to be passed to our test.
*/
public function provideTestEvent() : array {
return [
'Plain event' => [
'rules_test_event.plain_event',
new PlainEvent(),
],
'Generic event' => [
'rules_test_event.generic_event',
new GenericEvent('Test subject', [
'publicProperty' => 'public property',
'protectedProperty' => 'protected property',
'privateProperty' => 'private property',
]),
],
'Getter event' => [
'rules_test_event.getter_event',
new GetterEvent(),
],
];
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
EventPropertyAccessTest | Checks that the events defined in the rules_test_event module are correct. |