class NodeDisplayConfigurableTest in Drupal 10
Same name and namespace in other branches
- 8 core/modules/node/tests/src/Functional/NodeDisplayConfigurableTest.php \Drupal\Tests\node\Functional\NodeDisplayConfigurableTest
- 9 core/modules/node/tests/src/Functional/NodeDisplayConfigurableTest.php \Drupal\Tests\node\Functional\NodeDisplayConfigurableTest
Tests making node base fields' displays configurable.
@group node
Hierarchy
- class \Drupal\Tests\BrowserTestBase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, FunctionalTestSetupTrait, TestSetupTrait, BlockCreationTrait, ConfigTestTrait, ExtensionListTestTrait, ContentTypeCreationTrait, NodeCreationTrait, RandomGeneratorTrait, TestRequirementsTrait, PhpUnitWarnings, UiHelperTrait, UserCreationTrait, XdebugRequestTrait
- class \Drupal\Tests\node\Functional\NodeTestBase
- class \Drupal\Tests\node\Functional\NodeDisplayConfigurableTest
- class \Drupal\Tests\node\Functional\NodeTestBase
Expanded class hierarchy of NodeDisplayConfigurableTest
File
- core/
modules/ node/ tests/ src/ Functional/ NodeDisplayConfigurableTest.php, line 14
Namespace
Drupal\Tests\node\FunctionalView source
class NodeDisplayConfigurableTest extends NodeTestBase {
/**
* Modules to enable.
*
* @var array
*/
protected static $modules = [
'block',
];
/**
* {@inheritdoc}
*/
protected $defaultTheme = 'stark';
/**
* {@inheritdoc}
*/
protected function setUp() : void {
parent::setUp();
$data = $this
->getProvidedData();
$theme = reset($data);
\Drupal::service('theme_installer')
->install([
$theme,
]);
$this
->config('system.theme')
->set('default', $theme)
->save();
$settings = [
'theme' => $theme,
'region' => 'content',
'weight' => -100,
];
$this
->drupalPlaceBlock('page_title_block', $settings);
}
/**
* Sets base fields to configurable display and check settings are respected.
*
* @param string $theme
* The name of the theme being tested.
* @param string $metadata_region
* The region of the node html content where meta data is expected.
* @param bool $field_classes
* If TRUE, check for field--name-XXX classes.
*
* @dataProvider provideThemes
*/
public function testDisplayConfigurable(string $theme, string $metadata_region, bool $field_classes) {
// Change the node type setting to show submitted by information.
$node_type = \Drupal::entityTypeManager()
->getStorage('node_type')
->load('page');
$node_type
->setDisplaySubmitted(TRUE);
$node_type
->save();
$user = $this
->drupalCreateUser([
'administer nodes',
], $this
->randomMachineName(14));
$this
->drupalLogin($user);
$node = $this
->drupalCreateNode([
'uid' => $user
->id(),
]);
$assert = $this
->assertSession();
// Check the node with Drupal default non-configurable display.
$this
->drupalGet($node
->toUrl());
$this
->assertNodeHtml($node, $user, TRUE, $metadata_region, $field_classes, $field_classes);
// Enable module to make base fields' displays configurable.
\Drupal::service('module_installer')
->install([
'node_display_configurable_test',
]);
// Configure display.
$display = EntityViewDisplay::load('node.page.default');
$display
->setComponent('uid', [
'type' => 'entity_reference_label',
'label' => 'above',
'settings' => [
'link' => FALSE,
],
])
->removeComponent('title')
->save();
// Recheck the node with configurable display.
$this
->drupalGet($node
->toUrl());
$this
->assertNodeHtml($node, $user, FALSE, $metadata_region, $field_classes, FALSE);
// Remove from display.
$display
->removeComponent('uid')
->removeComponent('created')
->save();
$this
->drupalGet($node
->toUrl());
$assert
->elementTextNotContains('css', 'article', $user
->getAccountName());
}
/**
* Asserts that the node HTML is as expected.
*
* @param \Drupal\node\NodeInterface $node
* The node being tested.
* @param \Drupal\user\UserInterface $user
* The logged in user.
* @param bool $is_inline
* Whether the fields are rendered inline or not.
* @param string $metadata_region
* The region of the node html content where meta data is expected.
* @param bool $field_classes
* If TRUE, check for field--name-XXX classes on created/uid fields.
* @param bool $title_classes
* If TRUE, check for field--name-XXX classes on title field.
*
* @internal
*/
protected function assertNodeHtml(NodeInterface $node, UserInterface $user, bool $is_inline, string $metadata_region, bool $field_classes, bool $title_classes) : void {
$assert = $this
->assertSession();
$html_element = $is_inline ? 'span' : 'div';
$title_selector = 'h1 span' . ($title_classes ? '.field--name-title' : '');
$assert
->elementTextContains('css', $title_selector, $node
->getTitle());
// With field classes, the selector can be very specific.
if ($field_classes) {
$created_selector = 'article ' . $html_element . '.field--name-created';
$assert
->elementTextContains('css', $created_selector, \Drupal::service('date.formatter')
->format($node
->getCreatedTime()));
}
else {
// When field classes aren't available, use HTML elements for testing.
$formatted_time = \Drupal::service('date.formatter')
->format($node
->getCreatedTime());
if ($is_inline) {
$created_selector = sprintf('//article//%s//%s[text()="%s"]', $metadata_region, $html_element, $formatted_time);
}
else {
$created_selector = sprintf('//article//%s[text()="%s"]', $html_element, $formatted_time);
}
$assert
->elementExists('xpath', $created_selector);
}
$uid_selector = 'article ' . $html_element . ($field_classes ? '.field--name-uid' : '');
if (!$is_inline) {
$field_classes_selector = $field_classes ? "[contains(concat(' ', normalize-space(@class), ' '), ' field--name-uid ')]" : '';
$assert
->elementExists('xpath', sprintf('//article//%s//*%s//%s[text()="Authored by"]', $html_element, $field_classes_selector, $html_element));
$assert
->elementTextContains('css', $uid_selector, $user
->getAccountName());
$assert
->elementNotExists('css', "{$uid_selector} a");
if ($field_classes) {
$assert
->elementExists('css', $created_selector);
}
}
else {
$assert
->elementTextContains('css', $uid_selector . ' a', $user
->getAccountName());
$assert
->elementTextContains('css', 'article ' . $metadata_region, 'Submitted by');
}
}
/**
* Data provider for ::testDisplayConfigurable().
*
* @return array
*/
public function provideThemes() {
return [
[
'claro',
'footer',
TRUE,
],
// @todo Remove Classy from data provider in
// https://www.drupal.org/project/drupal/issues/3110137.
[
'classy',
'footer',
TRUE,
],
// @todo Add coverage for olivero after fixing
// https://www.drupal.org/project/drupal/issues/3215220.
// ['olivero', 'footer', TRUE],
[
'stable',
'footer',
FALSE,
],
[
'stable9',
'footer',
FALSE,
],
];
}
}