mirror of
https://github.com/enso-org/enso.git
synced 2025-01-05 14:11:36 +03:00
6d72a75f5e
* Ctrl+click to follow link; clicking link opens a popup. Fixes #11692. - Ctrl+click to follow link (and add hover text) - When editing, if the cursor is in a link a popup allows following the link. - Text filters (e.g. recognizing links) now apply to text dragged into the editor, or pasted with the context menu, besides pasting with the keyboard (uses new feature from updated CM). - Simplify CM editors by moving setup and reactivity patterns into shared helpers. - Add integration tests for link interactions in component comments and documentation panel. - Fix code editor tooltips (fixes #11740). - All lines containing selected text show markup
115 lines
4.8 KiB
TypeScript
115 lines
4.8 KiB
TypeScript
import test from 'playwright/test'
|
|
import * as actions from './actions'
|
|
import { expect } from './customExpect'
|
|
import { CONTROL_KEY } from './keyboard'
|
|
import * as locate from './locate'
|
|
|
|
test('Edit comment by click', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const nodeComment = locate.nodeCommentContent(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(nodeComment).toHaveText('This node can be entered')
|
|
|
|
await nodeComment.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
const NEW_COMMENT = 'New comment text'
|
|
await nodeComment.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toBeFocused()
|
|
await expect(nodeComment).toHaveText(NEW_COMMENT)
|
|
})
|
|
|
|
test('Start editing comment via menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'More' }).click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'Comment' }).click()
|
|
await expect(locate.nodeCommentContent(node)).toBeFocused()
|
|
})
|
|
|
|
test('Start editing comment via context menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click({ button: 'right' })
|
|
await page.getByRole('button', { name: 'Add Comment' }).click()
|
|
await expect(locate.nodeCommentContent(node)).toBeFocused()
|
|
})
|
|
|
|
test('Start editing comment via context menu when multiple components initially selected', async ({
|
|
page,
|
|
}) => {
|
|
await actions.goToGraph(page)
|
|
const otherNode = locate.graphNodeByBinding(page, 'sum')
|
|
await otherNode.click()
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click({ modifiers: ['Shift'] })
|
|
const anotherNode = locate.graphNodeByBinding(page, 'list')
|
|
await anotherNode.click({ modifiers: ['Shift'] })
|
|
await node.click({ button: 'right' })
|
|
await expect(locate.selectedNodes(page)).toHaveCount(3)
|
|
await page.getByRole('button', { name: 'Add Comment' }).click()
|
|
await expect(locate.selectedNodes(page)).toHaveCount(1)
|
|
await expect(locate.nodeCommentContent(node)).toBeFocused()
|
|
})
|
|
|
|
test('Add new comment via menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const INITIAL_NODE_COMMENTS = 1
|
|
await expect(locate.nodeCommentContent(page)).toHaveCount(INITIAL_NODE_COMMENTS)
|
|
const node = locate.graphNodeByBinding(page, 'data')
|
|
const nodeComment = locate.nodeCommentContent(node)
|
|
|
|
await node.click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'More' }).click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'Comment' }).click()
|
|
await expect(locate.nodeCommentContent(node)).toBeFocused()
|
|
const NEW_COMMENT = 'New comment text'
|
|
await nodeComment.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toBeFocused()
|
|
await expect(nodeComment).toHaveText(NEW_COMMENT)
|
|
await expect(locate.nodeCommentContent(page)).toHaveCount(INITIAL_NODE_COMMENTS + 1)
|
|
})
|
|
|
|
test('Delete comment by clearing text', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const nodeComment = locate.nodeCommentContent(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(nodeComment).toHaveText('This node can be entered')
|
|
|
|
await nodeComment.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
await page.keyboard.press(`Delete`)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toExist()
|
|
})
|
|
|
|
test('URL added to comment is rendered as link', async ({ page, context }) => {
|
|
await actions.goToGraph(page)
|
|
const comment = locate.nodeComment(locate.graphNodeByBinding(page, 'final'))
|
|
const commentContent = locate.nodeCommentContent(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(commentContent).toHaveText('This node can be entered')
|
|
await expect(commentContent.locator('a')).not.toExist()
|
|
|
|
await commentContent.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
const NEW_COMMENT = "Here's a URL: https://example.com"
|
|
await commentContent.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(commentContent).not.toBeFocused()
|
|
await expect(commentContent).toHaveText(NEW_COMMENT)
|
|
await expect(commentContent.locator('a')).toHaveCount(1)
|
|
|
|
await expect(commentContent.locator('a')).toHaveAccessibleDescription(
|
|
/Click to edit.*Click to open link/,
|
|
)
|
|
await commentContent.locator('a').click()
|
|
await expect(commentContent).toBeFocused()
|
|
await expect(comment.locator('.LinkEditPopup')).toExist()
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(commentContent).not.toBeFocused()
|
|
await expect(comment.locator('.LinkEditPopup')).not.toBeVisible()
|
|
const newPagePromise = new Promise<true>((resolve) => context.once('page', () => resolve(true)))
|
|
await commentContent.locator('a').click({ modifiers: ['ControlOrMeta'] })
|
|
await expect(() => newPagePromise).toPass({ timeout: 5000 })
|
|
})
|