e3cf05f408
This PR replaces our webdriver end to end tests with playwright tests. It: - replaces our webdriver workflow with a new e2e workflow based on playwright - removes the webdriver project - adds e2e tests to our examples app - replaces all `data-wd` attributes with `data-testid` ### Coverage Most of the tests from our previous e2e tests are reproduced here, though there are some related to our gestures that will need to be done in a different way—or not at all. I've also added a handful of new tests, too. ### Where are they The tests are now part of our examples app rather than being in its own different app. This should help us test our different examples too. As far as I can tell there are no downsides here in terms of the regular developer experience, though they might complicate any CodeSandbox projects that are hooked into the examples app. ### Change Type - [x] `tests` — Changes to any testing-related code only (will not publish a new version)
191 lines
4.9 KiB
TypeScript
191 lines
4.9 KiB
TypeScript
import test, { expect, Page } from '@playwright/test'
|
|
import { App } from '@tldraw/tldraw'
|
|
import { setupPage } from '../shared-e2e'
|
|
|
|
declare const __tldraw_editor_events: any[]
|
|
|
|
// We're just testing the events, not the actual results.
|
|
|
|
let page: Page
|
|
|
|
declare const app: App
|
|
|
|
test.describe('Canvas events', () => {
|
|
test.beforeAll(async ({ browser }) => {
|
|
page = await browser.newPage()
|
|
await setupPage(page)
|
|
})
|
|
|
|
test.describe('pointer events', () => {
|
|
test('pointer down', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(100, 100)
|
|
await page.mouse.down()
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'canvas',
|
|
type: 'pointer',
|
|
name: 'pointer_down',
|
|
})
|
|
})
|
|
|
|
test('pointer move', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(100, 100)
|
|
await page.mouse.down()
|
|
await page.mouse.move(101, 101)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'canvas',
|
|
type: 'pointer',
|
|
name: 'pointer_move',
|
|
})
|
|
})
|
|
|
|
test('pointer up', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(100, 100)
|
|
await page.mouse.down()
|
|
await page.mouse.move(101, 101)
|
|
await page.mouse.up()
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'canvas',
|
|
type: 'pointer',
|
|
name: 'pointer_up',
|
|
})
|
|
})
|
|
|
|
test('pointer leave', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(100, 100)
|
|
await page.mouse.move(-10, 50)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'canvas',
|
|
type: 'pointer',
|
|
name: 'pointer_leave',
|
|
})
|
|
})
|
|
|
|
test('pointer enter', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(-10, 50)
|
|
await page.mouse.move(1, 50)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-2))).toMatchObject({
|
|
target: 'canvas',
|
|
type: 'pointer',
|
|
name: 'pointer_enter',
|
|
})
|
|
})
|
|
})
|
|
|
|
test.describe('click events', () => {
|
|
// todo
|
|
})
|
|
|
|
test.describe('pinch events', () => {
|
|
// todo
|
|
})
|
|
|
|
test.describe('keyboard events', () => {
|
|
// todo
|
|
})
|
|
|
|
test.fixme('wheel events', async () => {
|
|
await page.mouse.move(200, 200) // to kill any double clicks
|
|
await page.mouse.move(100, 100)
|
|
await page.mouse.wheel(10, 10)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
type: 'wheel',
|
|
name: 'wheel',
|
|
delta: {
|
|
x: -20,
|
|
y: -20,
|
|
},
|
|
})
|
|
})
|
|
|
|
test.fixme('complete', async () => {
|
|
await page.evaluate(async () => app.complete())
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
type: 'misc',
|
|
name: 'complete',
|
|
})
|
|
})
|
|
|
|
test.fixme('cancel', async () => {
|
|
await page.evaluate(async () => app.cancel())
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
type: 'misc',
|
|
name: 'complete',
|
|
})
|
|
})
|
|
|
|
test.fixme('interrupt', async () => {
|
|
await page.evaluate(async () => app.interrupt())
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
type: 'misc',
|
|
name: 'interrupt',
|
|
})
|
|
})
|
|
})
|
|
|
|
test.describe('Shape events', () => {
|
|
test.beforeAll(async ({ browser }) => {
|
|
page = await browser.newPage()
|
|
await setupPage(page)
|
|
await page.keyboard.press('r')
|
|
await page.mouse.click(150, 150)
|
|
await page.mouse.move(0, 0)
|
|
await page.keyboard.press('Escape')
|
|
})
|
|
|
|
test.describe('pointer events', () => {
|
|
test('pointer enter', async () => {
|
|
await page.mouse.move(51, 51)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-2))).toMatchObject({
|
|
target: 'shape',
|
|
type: 'pointer',
|
|
name: 'pointer_enter',
|
|
})
|
|
})
|
|
|
|
test('pointer leave', async () => {
|
|
await page.mouse.move(51, 51)
|
|
await page.mouse.move(-10, -10)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'shape',
|
|
type: 'pointer',
|
|
name: 'pointer_leave',
|
|
})
|
|
})
|
|
|
|
test('pointer down', async () => {
|
|
await page.mouse.move(51, 51)
|
|
await page.mouse.down()
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'shape',
|
|
type: 'pointer',
|
|
name: 'pointer_down',
|
|
})
|
|
})
|
|
|
|
test('pointer move', async () => {
|
|
await page.mouse.move(51, 51)
|
|
await page.mouse.move(52, 52)
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-1))).toMatchObject({
|
|
target: 'shape',
|
|
type: 'pointer',
|
|
name: 'pointer_move',
|
|
})
|
|
})
|
|
|
|
test('pointer up', async () => {
|
|
await page.mouse.move(51, 51)
|
|
await page.mouse.down()
|
|
await page.mouse.up()
|
|
expect(await page.evaluate(() => __tldraw_editor_events.at(-2))).toMatchObject({
|
|
target: 'shape',
|
|
type: 'pointer',
|
|
name: 'pointer_up',
|
|
})
|
|
})
|
|
})
|
|
})
|