class LayoutEntityHelperTraitTest
Same name in this branch
- 11.x core/modules/layout_builder/tests/src/Kernel/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Kernel\LayoutEntityHelperTraitTest
Same name in other branches
- 9 core/modules/layout_builder/tests/src/Unit/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Unit\LayoutEntityHelperTraitTest
- 9 core/modules/layout_builder/tests/src/Kernel/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Kernel\LayoutEntityHelperTraitTest
- 8.9.x core/modules/layout_builder/tests/src/Unit/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Unit\LayoutEntityHelperTraitTest
- 8.9.x core/modules/layout_builder/tests/src/Kernel/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Kernel\LayoutEntityHelperTraitTest
- 10 core/modules/layout_builder/tests/src/Unit/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Unit\LayoutEntityHelperTraitTest
- 10 core/modules/layout_builder/tests/src/Kernel/LayoutEntityHelperTraitTest.php \Drupal\Tests\layout_builder\Kernel\LayoutEntityHelperTraitTest
@coversDefaultClass \Drupal\layout_builder\LayoutEntityHelperTrait
@group layout_builder
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Prophecy\PhpUnit\ProphecyTrait, \Drupal\TestTools\Extension\DeprecationBridge\ExpectDeprecationTrait, \Drupal\Tests\RandomGeneratorTrait
- class \Drupal\Tests\layout_builder\Unit\LayoutEntityHelperTraitTest extends \Drupal\Tests\UnitTestCase
Expanded class hierarchy of LayoutEntityHelperTraitTest
File
-
core/
modules/ layout_builder/ tests/ src/ Unit/ LayoutEntityHelperTraitTest.php, line 21
Namespace
Drupal\Tests\layout_builder\UnitView source
class LayoutEntityHelperTraitTest extends UnitTestCase {
/**
* Data provider method for tests that need sections with inline blocks.
*/
public static function providerSectionsWithInlineComponents() {
$prophet = new Prophet();
$components = [];
// Ensure a non-derivative component is not returned.
$non_derivative_component = $prophet->prophesize(SectionComponent::class);
$non_derivative_component->getPlugin()
->willReturn($prophet->prophesize(PluginInspectionInterface::class)
->reveal());
$components[] = $non_derivative_component->reveal();
// Ensure a derivative component with a different base Id is not returned.
$derivative_non_inline_component = $prophet->prophesize(SectionComponent::class);
$plugin = $prophet->prophesize(DerivativeInspectionInterface::class);
$plugin->getBaseId()
->willReturn('some_other_base_id_which_we_do_not_care_about_but_it_is_nothing_personal');
$derivative_non_inline_component->getPlugin()
->willReturn($plugin);
$components[] = $derivative_non_inline_component->reveal();
// Ensure that inline block component is returned.
$inline_component = $prophet->prophesize(SectionComponent::class);
$inline_plugin = $prophet->prophesize(DerivativeInspectionInterface::class)
->willImplement(ConfigurableInterface::class);
$inline_plugin->getBaseId()
->willReturn('inline_block');
$inline_plugin->getConfiguration()
->willReturn([
'block_revision_id' => 'the_revision_id',
]);
$inline_component->getPlugin()
->willReturn($inline_plugin->reveal());
$inline_component = $inline_component->reveal();
$components[] = $inline_component;
// Ensure that inline block component without revision is returned.
$inline_component_without_revision_id = $prophet->prophesize(SectionComponent::class);
$inline_plugin_without_revision_id = $prophet->prophesize(DerivativeInspectionInterface::class)
->willImplement(ConfigurableInterface::class);
$inline_plugin_without_revision_id->getBaseId()
->willReturn('inline_block');
$inline_plugin_without_revision_id->getConfiguration()
->willReturn([
'other_key' => 'other_value',
]);
$inline_component_without_revision_id->getPlugin()
->willReturn($inline_plugin_without_revision_id->reveal());
$inline_component_without_revision_id = $inline_component_without_revision_id->reveal();
$components[] = $inline_component_without_revision_id;
$section = $prophet->prophesize(Section::class);
$section->getComponents()
->willReturn($components);
$components = [];
// Ensure that inline block components in all sections are returned.
$inline_component2 = $prophet->prophesize(SectionComponent::class);
$inline_plugin2 = $prophet->prophesize(DerivativeInspectionInterface::class)
->willImplement(ConfigurableInterface::class);
$inline_plugin2->getBaseId()
->willReturn('inline_block');
$inline_plugin2->getConfiguration()
->willReturn([
'block_revision_id' => 'the_other_revision_id',
]);
$inline_component2->getPlugin()
->willReturn($inline_plugin2->reveal());
$inline_component2 = $inline_component2->reveal();
$components[] = $inline_component2;
$section2 = $prophet->prophesize(Section::class);
$section2->getComponents()
->willReturn($components);
return [
[
[
$section->reveal(),
$section2->reveal(),
],
// getInlineBlockComponents() should return inline blocks even if they
// have no revision Id.
[
$inline_component,
$inline_component_without_revision_id,
$inline_component2,
],
// getInlineBlockRevisionIdsInSections should just the revision Ids.
[
'the_revision_id',
'the_other_revision_id',
],
],
];
}
/**
* @covers ::getInlineBlockComponents
*
* @dataProvider providerSectionsWithInlineComponents
*/
public function testGetInlineBlockComponents($sections, $expected_components) : void {
$test_class = new TestClass();
$this->assertSame($expected_components, $test_class->getInlineBlockComponents($sections));
}
/**
* @covers ::getInlineBlockRevisionIdsInSections
*
* @dataProvider providerSectionsWithInlineComponents
*/
public function testGetInlineBlockRevisionIdsInSections($sections, $components, $expected_revision_ids) : void {
$test_class = new TestClass();
$this->assertSame($expected_revision_ids, $test_class->getInlineBlockRevisionIdsInSections($sections));
}
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overrides |
---|---|---|---|---|
ExpectDeprecationTrait::expectDeprecation | public | function | Adds an expected deprecation. | |
ExpectDeprecationTrait::getCallableName | private static | function | Returns a callable as a string suitable for inclusion in a message. | |
ExpectDeprecationTrait::setUpErrorHandler | public | function | Sets up the test error handler. | |
ExpectDeprecationTrait::tearDownErrorHandler | public | function | Tears down the test error handler. | |
LayoutEntityHelperTraitTest::providerSectionsWithInlineComponents | public static | function | Data provider method for tests that need sections with inline blocks. | |
LayoutEntityHelperTraitTest::testGetInlineBlockComponents | public | function | @covers ::getInlineBlockComponents | |
LayoutEntityHelperTraitTest::testGetInlineBlockRevisionIdsInSections | public | function | @covers ::getInlineBlockRevisionIdsInSections | |
RandomGeneratorTrait::getRandomGenerator | protected | function | Gets the random generator for the utility methods. | |
RandomGeneratorTrait::randomMachineName | protected | function | Generates a unique random string containing letters and numbers. | |
RandomGeneratorTrait::randomObject | public | function | Generates a random PHP object. | |
RandomGeneratorTrait::randomString | public | function | Generates a pseudo-random string of ASCII characters of codes 32 to 126. | |
UnitTestCase::$root | protected | property | The app root. | |
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::getStringTranslationStub | public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase::setUp | protected | function | 367 | |
UnitTestCase::setUpBeforeClass | public static | function |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.