0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00
ghost/apps/comments-ui/test/e2e/editor.test.ts
Ronald Langeveld c77080f977
Fixed comments placeholder (#21524)
ref PLG-251

- Fixed comments placeholder to change from "Start the conversation" to
"Join the discussion" when there's more than 1 comment.
- Previously, it only worked after a refresh. This fix ensures it's
reactive and would update the placeholder without the need for a
refresh.
2024-11-05 12:14:29 +09:00

351 lines
11 KiB
TypeScript

import {MockedApi, getModifierKey, initialize, selectText, setClipboard, waitEditorFocused} from '../utils/e2e';
import {expect, test} from '@playwright/test';
test.describe('Editor', async () => {
test('Editor placeholder shows Start the conversation when no existing comments ', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('editor');
const placeholderElement = editor.locator('[data-placeholder="Start the conversation"]');
await expect(placeholderElement).toBeVisible();
});
test('Can comment on a post', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
mockedApi.addComment({
html: '<p>This is comment 1</p>'
});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly',
count: true,
title: 'Title'
});
await expect(frame.getByTestId('comment-component')).toHaveCount(1);
await expect(frame.getByTestId('count')).toHaveText('1 comment');
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
// Wait for animation to finish
await page.waitForTimeout(200);
// Type in the editor
await editor.type('Newly added comment');
// Post the comment
const button = await frame.getByTestId('submit-form-button');
await button.click();
// Check editor is empty
await expect(editor).toHaveText('');
// Check the comment is added to the view
await expect(frame.getByTestId('comment-component')).toHaveCount(2);
await expect(frame.getByTestId('count')).toHaveText('2 comments');
await expect(frame.getByText('This is comment 1')).toBeVisible();
await expect(frame.getByText('Newly added comment')).toBeVisible();
});
test('Can use C to focus editor', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
await page.keyboard.press('c');
// Wait for animation to finish
await page.waitForTimeout(200);
});
test('Can use CMD+ENTER to submit', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
mockedApi.addComment({
html: '<p>This is comment 1</p>'
});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly',
count: true,
title: 'Title'
});
await expect(frame.getByTestId('comment-component')).toHaveCount(1);
await expect(frame.getByTestId('count')).toHaveText('1 comment');
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
// Wait for animation to finish
await page.waitForTimeout(200);
// Type in the editor
await editor.type('Newly added comment');
// Post the comment
await page.keyboard.press(`${getModifierKey()}+Enter`);
// Check editor is empty
await expect(editor).toHaveText('');
// Check the comment is added to the view
await expect(frame.getByTestId('comment-component')).toHaveCount(2);
await expect(frame.getByTestId('count')).toHaveText('2 comments');
await expect(frame.getByText('This is comment 1')).toBeVisible();
await expect(frame.getByText('Newly added comment')).toBeVisible();
});
test('Start the conversation changes to Join the Discussion if more 0 comments. ', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
const placeholderElement = editor.locator('[data-placeholder="Start the conversation"]');
await expect(placeholderElement).toBeVisible();
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
// Wait for animation to finish
await page.waitForTimeout(200);
// Type in the editor
await editor.type('Newly added comment');
// Post the comment
const button = await frame.getByTestId('submit-form-button');
await button.click();
await expect(editor).toHaveText('');
await expect(frame.getByText('Newly added comment')).toBeVisible();
const newPlaceholderElement = editor.locator('[data-placeholder="Join the discussion"]');
await expect(newPlaceholderElement).toBeVisible();
});
test.describe('Markdown', () => {
test('Can use > to type a quote', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
// Type in the editor
await editor.type('> This is a quote');
await page.keyboard.press('Enter');
await editor.type('This is a new line');
await page.keyboard.press('Enter');
await page.keyboard.press('Enter');
await editor.type('This is a new paragraph');
// Post the comment
await page.keyboard.press(`${getModifierKey()}+Enter`);
await expect(editor).toHaveText('');
// Check comment
expect(mockedApi.comments).toHaveLength(1);
expect(mockedApi.comments[0].html).toBe('<blockquote><p>This is a quote</p><p>This is a new line</p></blockquote><p>This is a new paragraph<br></p>');
});
test('Can paste an URL to create a link', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
await setClipboard(page, 'https://www.google.com');
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Check focused
const editorEditable = frame.getByTestId('editor');
// Wait for focused
await waitEditorFocused(editor);
// Type in the editor
await editor.type('Click here to go to a new page');
// Select 'here'
await selectText(editorEditable, /here/);
await page.keyboard.press(`${getModifierKey()}+KeyV`);
await page.waitForTimeout(200);
// Click the button
const button = await frame.getByTestId('submit-form-button');
await button.click();
await expect(editor).toHaveText('');
// Check comment
expect(mockedApi.comments).toHaveLength(1);
expect(mockedApi.comments[0].html).toBe('<p>Click <a target="_blank" rel="noopener noreferrer nofollow" href="https://www.google.com">here</a> to go to a new page</p>');
});
test('Can paste text without creating a url', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
await setClipboard(page, 'Some random text');
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
const editorEditable = frame.getByTestId('editor');
// Type in the editor
await editor.type('Click here to go to a new page');
// Select 'here'
await selectText(editorEditable, /here/);
await page.keyboard.press(`${getModifierKey()}+KeyV`);
await page.waitForTimeout(200);
// Click the button
const button = await frame.getByTestId('submit-form-button');
await button.click();
await expect(editor).toHaveText('');
// Check comment
expect(mockedApi.comments).toHaveLength(1);
expect(mockedApi.comments[0].html).toBe('<p>Click Some random text to go to a new page</p>');
});
test('Cannot bold text', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
await setClipboard(page, 'Some random text');
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
const editorEditable = frame.getByTestId('editor');
// Type in the editor
await editor.type('Click here to go to a new page');
// Select 'here'
await selectText(editorEditable, /here/);
await page.keyboard.press(`${getModifierKey()}+B`);
await page.waitForTimeout(200);
// Click the button
const button = await frame.getByTestId('submit-form-button');
await button.click();
await expect(editor).toHaveText('');
// Check comment
expect(mockedApi.comments).toHaveLength(1);
expect(mockedApi.comments[0].html).toBe('<p>Click here to go to a new page</p>');
});
test('Can do a soft line break', async ({page}) => {
const mockedApi = new MockedApi({});
mockedApi.setMember({});
const {frame} = await initialize({
mockedApi,
page,
publication: 'Publisher Weekly'
});
const editor = frame.getByTestId('form-editor');
await editor.click({force: true});
// Wait for focused
await waitEditorFocused(editor);
// Type in the editor
await editor.type('This is line 1');
await page.keyboard.press('Shift+Enter');
await editor.type('This is line 2');
await page.keyboard.press('Enter');
await editor.type('This is a new paragraph');
// Click the button
const button = await frame.getByTestId('submit-form-button');
await button.click();
await expect(editor).toHaveText('');
// Check comment
expect(mockedApi.comments).toHaveLength(1);
expect(mockedApi.comments[0].html).toBe('<p>This is line 1<br>This is line 2</p><p>This is a new paragraph</p>');
});
});
});