public function CommentPagerTest::testTwoPagers in Drupal 10
Same name and namespace in other branches
- 8 core/modules/comment/tests/src/Functional/CommentPagerTest.php \Drupal\Tests\comment\Functional\CommentPagerTest::testTwoPagers()
- 9 core/modules/comment/tests/src/Functional/CommentPagerTest.php \Drupal\Tests\comment\Functional\CommentPagerTest::testTwoPagers()
Confirms comment paging works correctly with two pagers.
File
- core/
modules/ comment/ tests/ src/ Functional/ CommentPagerTest.php, line 327
Class
- CommentPagerTest
- Tests paging of comments and their settings.
Namespace
Drupal\Tests\comment\FunctionalCode
public function testTwoPagers() {
// Add another field to article content-type.
$this
->addDefaultCommentField('node', 'article', 'comment_2');
// Set default to display comment list with unique pager id.
\Drupal::service('entity_display.repository')
->getViewDisplay('node', 'article')
->setComponent('comment_2', [
'label' => 'hidden',
'type' => 'comment_default',
'weight' => 30,
'settings' => [
'pager_id' => 1,
'view_mode' => 'default',
],
])
->save();
// Make sure pager appears in formatter summary and settings form.
$account = $this
->drupalCreateUser([
'administer node display',
]);
$this
->drupalLogin($account);
$this
->drupalGet('admin/structure/types/manage/article/display');
// No summary for standard pager.
$this
->assertSession()
->pageTextNotContains('Pager ID: 0');
$this
->assertSession()
->pageTextContains('Pager ID: 1');
$this
->submitForm([], 'comment_settings_edit');
// Change default pager to 2.
$this
->submitForm([
'fields[comment][settings_edit_form][settings][pager_id]' => 2,
], 'Save');
$this
->assertSession()
->pageTextContains('Pager ID: 2');
// Revert the changes.
$this
->submitForm([], 'comment_settings_edit');
$this
->submitForm([
'fields[comment][settings_edit_form][settings][pager_id]' => 0,
], 'Save');
// No summary for standard pager.
$this
->assertSession()
->pageTextNotContains('Pager ID: 0');
$this
->drupalLogin($this->adminUser);
// Add a new node with both comment fields open.
$node = $this
->drupalCreateNode([
'type' => 'article',
'promote' => 1,
'uid' => $this->webUser
->id(),
]);
// Set comment options.
$comments = [];
foreach ([
'comment',
'comment_2',
] as $field_name) {
$this
->setCommentForm(TRUE, $field_name);
$this
->setCommentPreview(DRUPAL_OPTIONAL, $field_name);
$this
->setCommentSettings('default_mode', CommentManagerInterface::COMMENT_MODE_FLAT, 'Comment paging changed.', $field_name);
// Set comments to one per page so that we are able to test paging without
// needing to insert large numbers of comments.
$this
->setCommentsPerPage(1, $field_name);
for ($i = 1; $i <= 4; $i++) {
$comment = "Comment {$i} on field {$field_name}";
$comments[] = $this
->postComment($node, $comment, $comment, TRUE, $field_name);
}
}
// Check the first page of the node, and confirm the correct comments are
// shown.
$this
->drupalGet('node/' . $node
->id());
$this
->assertSession()
->pageTextContains('next');
$this
->assertSession()
->pageTextContains('Comment 1 on field comment');
$this
->assertSession()
->pageTextContains('Comment 1 on field comment_2');
// Navigate to next page of field 1.
$this
->clickLinkWithXPath('//h3/a[normalize-space(text())=:label]/ancestor::section[1]//a[@rel="next"]', [
':label' => 'Comment 1 on field comment',
]);
// Check only one pager updated.
$this
->assertSession()
->pageTextContains('Comment 2 on field comment');
$this
->assertSession()
->pageTextContains('Comment 1 on field comment_2');
// Return to page 1.
$this
->drupalGet('node/' . $node
->id());
// Navigate to next page of field 2.
$this
->clickLinkWithXPath('//h3/a[normalize-space(text())=:label]/ancestor::section[1]//a[@rel="next"]', [
':label' => 'Comment 1 on field comment_2',
]);
// Check only one pager updated.
$this
->assertSession()
->pageTextContains('Comment 1 on field comment');
$this
->assertSession()
->pageTextContains('Comment 2 on field comment_2');
// Navigate to next page of field 1.
$this
->clickLinkWithXPath('//h3/a[normalize-space(text())=:label]/ancestor::section[1]//a[@rel="next"]', [
':label' => 'Comment 1 on field comment',
]);
// Check only one pager updated.
$this
->assertSession()
->pageTextContains('Comment 2 on field comment');
$this
->assertSession()
->pageTextContains('Comment 2 on field comment_2');
}