import {MockedApi, initialize} from '../utils/e2e'; import {expect, test} from '@playwright/test'; test.describe('Pagination', async () => { test('Shows pagination button on top if more than 5 comments', async ({page}) => { const mockedApi = new MockedApi({}); mockedApi.addComment({ html: '

This is comment 1

' }); mockedApi.addComment({ html: '

This is comment 2

' }); mockedApi.addComment({ html: '

This is comment 3

' }); mockedApi.addComment({ html: '

This is comment 4

' }); mockedApi.addComment({ html: '

This is comment 5

' }); mockedApi.addComment({ html: '

This is comment 6

' }); const {frame} = await initialize({ mockedApi, page, publication: 'Publisher Weekly' }); await expect(frame.getByTestId('pagination-component')).toBeVisible(); // Check text in pagination button await expect(frame.getByTestId('pagination-component')).toContainText('Show 1 previous comment'); // Test total comments with test-id comment-component is 5 await expect(frame.getByTestId('comment-component')).toHaveCount(5); // Check only the first 5 comments are visible await expect(frame.getByText('This is comment 1')).not.toBeVisible(); await expect(frame.getByText('This is comment 2')).toBeVisible(); await expect(frame.getByText('This is comment 3')).toBeVisible(); await expect(frame.getByText('This is comment 4')).toBeVisible(); await expect(frame.getByText('This is comment 5')).toBeVisible(); await expect(frame.getByText('This is comment 6')).toBeVisible(); // Click the pagination button await frame.getByTestId('pagination-component').click(); // Check only 6 visible (not more than that) await expect(frame.getByTestId('comment-component')).toHaveCount(6); // Check comments 6 is visible await expect(frame.getByText('This is comment 1')).toBeVisible(); // Check the pagination button is not visible await expect(frame.getByTestId('pagination-component')).not.toBeVisible(); }); test('Shows pagination button for replies', async ({page}) => { const mockedApi = new MockedApi({}); mockedApi.addComment({ html: '

This is comment 1

', replies: [ mockedApi.buildReply({ html: '

This is reply 1

' }), mockedApi.buildReply({ html: '

This is reply 2

' }), mockedApi.buildReply({ html: '

This is reply 3

' }), mockedApi.buildReply({ html: '

This is reply 4

' }) ] }); const {frame} = await initialize({ mockedApi, page, publication: 'Publisher Weekly' }); await expect(frame.getByTestId('reply-pagination-button')).toBeVisible(); // Check text in pagination button await expect(frame.getByTestId('reply-pagination-button')).toContainText('Show 1 more reply'); await expect(frame.getByTestId('comment-component')).toHaveCount(4); // Check only the first 5 comments are visible await expect(frame.getByText('This is comment 1')).toBeVisible(); await expect(frame.getByText('This is reply 1')).toBeVisible(); await expect(frame.getByText('This is reply 2')).toBeVisible(); await expect(frame.getByText('This is reply 3')).toBeVisible(); await expect(frame.getByText('This is reply 4')).not.toBeVisible(); // Click the pagination button await frame.getByTestId('reply-pagination-button').click(); // No longer visible await expect(frame.getByTestId('reply-pagination-button')).not.toBeVisible(); await expect(frame.getByTestId('comment-component')).toHaveCount(5); await expect(frame.getByText('This is comment 1')).toBeVisible(); await expect(frame.getByText('This is reply 1')).toBeVisible(); await expect(frame.getByText('This is reply 2')).toBeVisible(); await expect(frame.getByText('This is reply 3')).toBeVisible(); await expect(frame.getByText('This is reply 4')).toBeVisible(); }); test('Can handle comments with deleted member', async ({page}) => { const mockedApi = new MockedApi({}); mockedApi.addComment({ html: '

This is comment 1

', member: null }); const {frame} = await initialize({ mockedApi, page, publication: 'Publisher Weekly' }); await expect(frame.getByTestId('comment-component')).toHaveCount(1); await expect(frame.getByText('This is comment 1')).toBeVisible(); }); });