class EntityExtraEventTest in Hook Event Dispatcher 8
Class EntityExtraEventTest.
@package Drupal\Tests\hook_event_dispatcher\Unit\Entity
@group hook_event_dispatcher
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\hook_event_dispatcher\Unit\EntityExtra\EntityExtraEventTest
Expanded class hierarchy of EntityExtraEventTest
File
- tests/
src/ Unit/ EntityExtra/ EntityExtraEventTest.php, line 19
Namespace
Drupal\Tests\hook_event_dispatcher\Unit\EntityExtraView source
class EntityExtraEventTest extends UnitTestCase {
/**
* The manager.
*
* @var \Drupal\Tests\hook_event_dispatcher\Unit\HookEventDispatcherManagerSpy
*/
private $manager;
/**
* {@inheritdoc}
*/
public function setUp() {
$builder = new ContainerBuilder();
$this->manager = new HookEventDispatcherManagerSpy();
$builder
->set('hook_event_dispatcher.manager', $this->manager);
$builder
->compile();
\Drupal::setContainer($builder);
}
/**
* Test EntityExtraFieldInfoEvent with helper functions.
*/
public function testEntityExtraFieldInfoEventWithHelperFunctions() {
$this->manager
->setEventCallbacks([
HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO => function (EntityExtraFieldInfoEvent $event) {
$event
->addDisplayFieldInfo('node', 'test', 'field_test', [
'test' => 'node',
]);
$event
->addFormFieldInfo('entity', 'test_entity', 'field_node', [
'test' => 'entity',
]);
},
]);
$expectedFieldInfo = [
'node' => [
'test' => [
'display' => [
'field_test' => [
'test' => 'node',
],
],
],
],
'entity' => [
'test_entity' => [
'form' => [
'field_node' => [
'test' => 'entity',
],
],
],
],
];
$hookFieldInfoResult = hook_event_dispatcher_entity_extra_field_info();
self::assertEquals($expectedFieldInfo, $hookFieldInfoResult);
/** @var \Drupal\hook_event_dispatcher\Event\EntityExtra\EntityExtraFieldInfoEvent $event */
$event = $this->manager
->getRegisteredEvent(HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO);
self::assertEquals($expectedFieldInfo, $event
->getFieldInfo());
}
/**
* Test EntityExtraFieldInfoEvent with set function.
*/
public function testEntityExtraFieldInfoEventWithSetFunction() {
$fieldInfo = [
'node' => [
'test' => [
'display' => [
'field_test' => [
'test' => 'node',
],
],
],
],
'entity' => [
'test_entity' => [
'form' => [
'field_node' => [
'test' => 'entity',
],
],
],
],
];
$this->manager
->setEventCallbacks([
HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO => function (EntityExtraFieldInfoEvent $event) use ($fieldInfo) {
$event
->setFieldInfo($fieldInfo);
},
]);
$hookFieldInfoResult = hook_event_dispatcher_entity_extra_field_info();
self::assertEquals($fieldInfo, $hookFieldInfoResult);
/** @var \Drupal\hook_event_dispatcher\Event\EntityExtra\EntityExtraFieldInfoEvent $event */
$event = $this->manager
->getRegisteredEvent(HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO);
self::assertEquals($fieldInfo, $event
->getFieldInfo());
}
/**
* Test EntityExtraFieldInfoAlterEvent.
*/
public function testEntityExtraFieldInfoAlterEvent() {
$this->manager
->setEventCallbacks([
HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO_ALTER => function (EntityExtraFieldInfoAlterEvent $event) {
$info =& $event
->getFieldInfo();
$info['taxonomy_term']['sheep']['display']['field_herd']['sheep'] = 'herd';
},
]);
$fieldInfo = $expectedFieldInfo = [
'node' => [
'test' => [
'display' => [
'field_test' => [
'test' => 'node',
],
],
],
],
'entity' => [
'test_entity' => [
'form' => [
'field_node' => [
'test' => 'entity',
],
],
],
],
];
$expectedFieldInfo['taxonomy_term']['sheep']['display']['field_herd']['sheep'] = 'herd';
hook_event_dispatcher_entity_extra_field_info_alter($fieldInfo);
/** @var \Drupal\hook_event_dispatcher\Event\EntityExtra\EntityExtraFieldInfoAlterEvent $event */
$event = $this->manager
->getRegisteredEvent(HookEventDispatcherInterface::ENTITY_EXTRA_FIELD_INFO_ALTER);
self::assertEquals($expectedFieldInfo, $event
->getFieldInfo());
self::assertEquals($expectedFieldInfo, $fieldInfo);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
EntityExtraEventTest:: |
private | property | The manager. | |
EntityExtraEventTest:: |
public | function |
Overrides UnitTestCase:: |
|
EntityExtraEventTest:: |
public | function | Test EntityExtraFieldInfoAlterEvent. | |
EntityExtraEventTest:: |
public | function | Test EntityExtraFieldInfoEvent with helper functions. | |
EntityExtraEventTest:: |
public | function | Test EntityExtraFieldInfoEvent with set function. | |
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. | |
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. |