class EventPropertyAccessTest

Same name in this branch
  1. 8.x-3.x tests/src/Kernel/EventPropertyAccessTest.php \Drupal\Tests\rules\Kernel\EventPropertyAccessTest

Checks that the events defined in the rules_test_event module are correct.

@group RulesEvent

Hierarchy

  • class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\Traits\PhpUnitWarnings, \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait
    • class \Drupal\Tests\rules\Unit\Integration\RulesIntegrationTestBase extends \Drupal\Tests\UnitTestCase
      • class \Drupal\Tests\rules\Unit\Integration\RulesEntityIntegrationTestBase extends \Drupal\Tests\rules\Unit\Integration\RulesIntegrationTestBase
        • class \Drupal\Tests\rules\Unit\Integration\Event\EventTestBase extends \Drupal\Tests\rules\Unit\Integration\RulesEntityIntegrationTestBase
          • class \Drupal\Tests\rules\Unit\Integration\Event\EventPropertyAccessTest extends \Drupal\Tests\rules\Unit\Integration\Event\EventTestBase

Expanded class hierarchy of EventPropertyAccessTest

File

tests/src/Unit/Integration/Event/EventPropertyAccessTest.php, line 16

Namespace

Drupal\Tests\rules\Unit\Integration\Event
View source
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(),
            ],
        ];
    }

}

Members

Title Sort descending Deprecated Modifiers Object type Summary Overriden Title Overrides
EventPropertyAccessTest::provideTestEvent public function Provider for events to test.
EventPropertyAccessTest::setUp protected function Overrides EventTestBase::setUp
EventPropertyAccessTest::testEventContextDefinition public function Tests the event metadata to ensure that all properties may be accessed.
EventTestBase::$eventManager protected property The Rules event plugin manager.
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.
RulesEntityIntegrationTestBase::$entityAccess protected property The mocked entity access handler.
RulesEntityIntegrationTestBase::$fieldTypeManager protected property The field type manager.
RulesEntityIntegrationTestBase::$languageManager protected property The language manager mock.
RulesEntityIntegrationTestBase::getContextDefinitionFor protected function Helper to mock a context definition with a mocked data definition.
RulesIntegrationTestBase::$actionManager protected property
RulesIntegrationTestBase::$cacheBackend protected property
RulesIntegrationTestBase::$classResolver protected property The class resolver mock for the typed data manager.
RulesIntegrationTestBase::$conditionManager protected property
RulesIntegrationTestBase::$container protected property The Drupal service container.
RulesIntegrationTestBase::$dataFetcher protected property The data fetcher service.
RulesIntegrationTestBase::$dataFilterManager protected property The data filter manager.
RulesIntegrationTestBase::$enabledModules protected property Array object keyed with module names and TRUE as value.
RulesIntegrationTestBase::$entityFieldManager protected property
RulesIntegrationTestBase::$entityTypeBundleInfo protected property
RulesIntegrationTestBase::$entityTypeManager protected property
RulesIntegrationTestBase::$fieldTypeCategoryManager protected property The field type category info plugin manager.
RulesIntegrationTestBase::$logger protected property A mocked Rules logger.channel.rules_debug service. 6
RulesIntegrationTestBase::$messenger protected property The messenger service.
RulesIntegrationTestBase::$moduleHandler protected property
RulesIntegrationTestBase::$namespaces protected property All setup&#039;ed namespaces.
RulesIntegrationTestBase::$placeholderResolver protected property The placeholder resolver service.
RulesIntegrationTestBase::$rulesDataProcessorManager protected property
RulesIntegrationTestBase::$rulesExpressionManager protected property
RulesIntegrationTestBase::$typedDataManager protected property
RulesIntegrationTestBase::constructModulePath protected function Determines the path to a module&#039;s class files.
RulesIntegrationTestBase::enableModule protected function Fakes the enabling of a module and adds its namespace for plugin loading.
RulesIntegrationTestBase::getTypedData protected function Returns a typed data object.
RulesIntegrationTestBase::prophesizeEntity protected function Helper method to mock irrelevant cache methods on entities.
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