2024-03-06 18:34:07 +03:00
|
|
|
import { type Page } from '@playwright/test'
|
|
|
|
import { expect } from './customExpect'
|
2024-02-05 17:20:24 +03:00
|
|
|
import * as locate from './locate'
|
2024-02-06 19:15:00 +03:00
|
|
|
import { graphNodeByBinding } from './locate'
|
2023-11-27 18:48:37 +03:00
|
|
|
|
|
|
|
// =================
|
|
|
|
// === goToGraph ===
|
|
|
|
// =================
|
|
|
|
|
|
|
|
/** Perform a successful login. */
|
2024-05-27 15:53:16 +03:00
|
|
|
export async function goToGraph(page: Page, closeDocPanel: boolean = true) {
|
2023-11-27 18:48:37 +03:00
|
|
|
await page.goto('/')
|
2024-03-14 20:05:26 +03:00
|
|
|
// Initial load through vite can take a while. Make sure that the first locator has enough time.
|
|
|
|
await expect(page.locator('.GraphEditor')).toBeVisible({ timeout: 100000 })
|
2024-02-05 17:20:24 +03:00
|
|
|
// Wait until nodes are loaded.
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNode(page)).toExist()
|
2024-07-04 23:55:59 +03:00
|
|
|
if (closeDocPanel) {
|
|
|
|
await expect(page.getByTestId('rightDock')).toExist()
|
|
|
|
await page.getByRole('button', { name: 'Documentation Panel' }).click()
|
|
|
|
// Wait for the closing animation.
|
2024-07-12 13:45:57 +03:00
|
|
|
await expect(page.getByTestId('rightDock')).toBeHidden()
|
2024-07-04 23:55:59 +03:00
|
|
|
}
|
2024-02-28 16:14:48 +03:00
|
|
|
// Wait for position initialization
|
2024-05-31 11:26:45 +03:00
|
|
|
await expectNodePositionsInitialized(page, 72)
|
2024-03-06 18:34:07 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
export async function expectNodePositionsInitialized(page: Page, yPos: number) {
|
2024-03-14 16:43:44 +03:00
|
|
|
// Wait until edges are initialized and displayed correctly.
|
2024-07-12 13:45:57 +03:00
|
|
|
await expect(page.getByTestId('broken-edge')).toBeHidden()
|
2024-03-14 16:43:44 +03:00
|
|
|
// Wait until node sizes are initialized.
|
|
|
|
await expect(locate.graphNode(page).first().locator('.bgFill')).toBeVisible()
|
2024-03-06 18:34:07 +03:00
|
|
|
// TODO: The yPos should not need to be a variable. Instead, first automatically positioned nodes
|
|
|
|
// should always have constant known position. This is a bug caused by incorrect layout after
|
|
|
|
// entering a function. To be fixed with #9255
|
2024-02-28 16:14:48 +03:00
|
|
|
await expect(locate.graphNode(page).first()).toHaveCSS(
|
|
|
|
'transform',
|
2024-03-06 18:34:07 +03:00
|
|
|
`matrix(1, 0, 0, 1, -16, ${yPos})`,
|
2024-02-28 16:14:48 +03:00
|
|
|
)
|
2023-11-27 18:48:37 +03:00
|
|
|
}
|
2024-02-06 19:15:00 +03:00
|
|
|
|
2024-03-06 18:34:07 +03:00
|
|
|
export async function exitFunction(page: Page, x = 300, y = 300) {
|
2024-05-24 16:28:51 +03:00
|
|
|
await locate.graphEditor(page).dblclick({ position: { x, y } })
|
2024-03-06 18:34:07 +03:00
|
|
|
}
|
|
|
|
|
2024-02-06 19:15:00 +03:00
|
|
|
// =================
|
|
|
|
// === Drag Node ===
|
|
|
|
// =================
|
|
|
|
|
|
|
|
/// Move node defined by the given binding by the given x and y.
|
|
|
|
export async function dragNodeByBinding(page: Page, nodeBinding: string, x: number, y: number) {
|
|
|
|
const node = graphNodeByBinding(page, nodeBinding)
|
2024-07-04 23:55:59 +03:00
|
|
|
const grabHandle = node.locator('.grab-handle')
|
2024-02-06 19:15:00 +03:00
|
|
|
await grabHandle.dragTo(grabHandle, {
|
|
|
|
targetPosition: { x, y },
|
|
|
|
force: true,
|
|
|
|
})
|
|
|
|
}
|
2024-07-12 13:45:57 +03:00
|
|
|
|
|
|
|
/// Move mouse away to avoid random hover events and wait for any circular menus to disappear.
|
2024-08-13 19:30:11 +03:00
|
|
|
export async function ensureNoCircularMenusVisibleDueToHovering(page: Page) {
|
2024-07-12 13:45:57 +03:00
|
|
|
await page.mouse.move(-1000, 0)
|
|
|
|
await expect(locate.circularMenu(page)).toBeHidden()
|
|
|
|
}
|
2024-08-13 19:30:11 +03:00
|
|
|
|
|
|
|
/// Ensure no nodes are selected.
|
|
|
|
export async function deselectNodes(page: Page) {
|
|
|
|
await page.mouse.click(0, 0)
|
|
|
|
await expect(locate.selectedNodes(page)).toHaveCount(0)
|
|
|
|
}
|