tldraw/apps/examples/e2e/tests/test-canvas-events.spec.ts

192 lines
4.9 KiB
TypeScript
Raw Normal View History

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',
})
})
})
})