* Visualize draft point when near axes (only works on XY rn due to quaternion rotation issue) * Slightly better quaternion rotation * Actually snap new profiles to the X and Y axis * Add snapping behavior while dragging * Fix flickering on non-XY planes * Add some fixture additions to support click-and-drag tests * Add new test to verify snapping behavior * Make the editor test fixture auto-open and close as needed * All feedback except absolute lines * Use `lineTo` for lines that have snapped * Get other existing tests passing after switching to `lineTo` when snapping * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest) * Re-run CI --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
		
			
				
	
	
		
			243 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			243 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { test, expect } from '@playwright/test'
 | 
						|
 | 
						|
import { commonPoints, getUtils, setup, tearDown } from './test-utils'
 | 
						|
 | 
						|
test.beforeEach(async ({ context, page }, testInfo) => {
 | 
						|
  await setup(context, page, testInfo)
 | 
						|
})
 | 
						|
 | 
						|
test.afterEach(async ({ page }, testInfo) => {
 | 
						|
  await tearDown(page, testInfo)
 | 
						|
})
 | 
						|
 | 
						|
test.describe('Test network and connection issues', () => {
 | 
						|
  test('simulate network down and network little widget', async ({
 | 
						|
    page,
 | 
						|
    browserName,
 | 
						|
  }) => {
 | 
						|
    // TODO: Don't skip Mac for these. After `window.tearDown` is working in Safari, these should work on webkit
 | 
						|
    test.skip(
 | 
						|
      browserName === 'webkit',
 | 
						|
      'Skip on Safari until `window.tearDown` is working there'
 | 
						|
    )
 | 
						|
    const u = await getUtils(page)
 | 
						|
    await page.setViewportSize({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await u.waitForAuthSkipAppStart()
 | 
						|
 | 
						|
    const networkToggle = page.getByTestId('network-toggle')
 | 
						|
 | 
						|
    // This is how we wait until the stream is online
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).not.toBeDisabled({ timeout: 15000 })
 | 
						|
 | 
						|
    const networkWidget = page.locator('[data-testid="network-toggle"]')
 | 
						|
    await expect(networkWidget).toBeVisible()
 | 
						|
    await networkWidget.hover()
 | 
						|
 | 
						|
    const networkPopover = page.locator('[data-testid="network-popover"]')
 | 
						|
    await expect(networkPopover).not.toBeVisible()
 | 
						|
 | 
						|
    // (First check) Expect the network to be up
 | 
						|
    await expect(networkToggle).toContainText('Connected')
 | 
						|
 | 
						|
    // Click the network widget
 | 
						|
    await networkWidget.click()
 | 
						|
 | 
						|
    // Check the modal opened.
 | 
						|
    await expect(networkPopover).toBeVisible()
 | 
						|
 | 
						|
    // Click off the modal.
 | 
						|
    await page.mouse.click(100, 100)
 | 
						|
    await expect(networkPopover).not.toBeVisible()
 | 
						|
 | 
						|
    // Turn off the network
 | 
						|
    await u.emulateNetworkConditions({
 | 
						|
      offline: true,
 | 
						|
      // values of 0 remove any active throttling. crbug.com/456324#c9
 | 
						|
      latency: 0,
 | 
						|
      downloadThroughput: -1,
 | 
						|
      uploadThroughput: -1,
 | 
						|
    })
 | 
						|
 | 
						|
    // Expect the network to be down
 | 
						|
    await expect(networkToggle).toContainText('Offline')
 | 
						|
 | 
						|
    // Click the network widget
 | 
						|
    await networkWidget.click()
 | 
						|
 | 
						|
    // Check the modal opened.
 | 
						|
    await expect(networkPopover).toBeVisible()
 | 
						|
 | 
						|
    // Click off the modal.
 | 
						|
    await page.mouse.click(0, 0)
 | 
						|
    await expect(networkPopover).not.toBeVisible()
 | 
						|
 | 
						|
    // Turn back on the network
 | 
						|
    await u.emulateNetworkConditions({
 | 
						|
      offline: false,
 | 
						|
      // values of 0 remove any active throttling. crbug.com/456324#c9
 | 
						|
      latency: 0,
 | 
						|
      downloadThroughput: -1,
 | 
						|
      uploadThroughput: -1,
 | 
						|
    })
 | 
						|
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).not.toBeDisabled({ timeout: 15000 })
 | 
						|
 | 
						|
    // (Second check) expect the network to be up
 | 
						|
    await expect(networkToggle).toContainText('Connected')
 | 
						|
  })
 | 
						|
 | 
						|
  test('Engine disconnect & reconnect in sketch mode', async ({
 | 
						|
    page,
 | 
						|
    browserName,
 | 
						|
  }) => {
 | 
						|
    // TODO: Don't skip Mac for these. After `window.tearDown` is working in Safari, these should work on webkit
 | 
						|
    test.skip(
 | 
						|
      browserName === 'webkit',
 | 
						|
      'Skip on Safari until `window.tearDown` is working there'
 | 
						|
    )
 | 
						|
    const networkToggle = page.getByTestId('network-toggle')
 | 
						|
 | 
						|
    const u = await getUtils(page)
 | 
						|
    await page.setViewportSize({ width: 1200, height: 500 })
 | 
						|
    const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
 | 
						|
    await u.waitForAuthSkipAppStart()
 | 
						|
    await u.openDebugPanel()
 | 
						|
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).not.toBeDisabled({ timeout: 15000 })
 | 
						|
 | 
						|
    // click on "Start Sketch" button
 | 
						|
    await u.clearCommandLogs()
 | 
						|
    await page.getByRole('button', { name: 'Start Sketch' }).click()
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
 | 
						|
    // select a plane
 | 
						|
    await page.mouse.click(700, 200)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')`
 | 
						|
    )
 | 
						|
    await u.closeDebugPanel()
 | 
						|
 | 
						|
    await page.waitForTimeout(500) // TODO detect animation ending, or disable animation
 | 
						|
 | 
						|
    const startXPx = 600
 | 
						|
    await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10)
 | 
						|
    await expect(page.locator('.cm-content'))
 | 
						|
      .toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
    |> startProfileAt(${commonPoints.startAt}, %)`)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
 | 
						|
    await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 10)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content'))
 | 
						|
      .toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
    |> startProfileAt(${commonPoints.startAt}, %)
 | 
						|
    |> line([${commonPoints.num1}, 0], %)`)
 | 
						|
 | 
						|
    // Expect the network to be up
 | 
						|
    await expect(networkToggle).toContainText('Connected')
 | 
						|
 | 
						|
    // simulate network down
 | 
						|
    await u.emulateNetworkConditions({
 | 
						|
      offline: true,
 | 
						|
      // values of 0 remove any active throttling. crbug.com/456324#c9
 | 
						|
      latency: 0,
 | 
						|
      downloadThroughput: -1,
 | 
						|
      uploadThroughput: -1,
 | 
						|
    })
 | 
						|
 | 
						|
    // Expect the network to be down
 | 
						|
    await expect(networkToggle).toContainText('Offline')
 | 
						|
 | 
						|
    // Ensure we are not in sketch mode
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Exit Sketch' })
 | 
						|
    ).not.toBeVisible()
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).toBeVisible()
 | 
						|
 | 
						|
    // simulate network up
 | 
						|
    await u.emulateNetworkConditions({
 | 
						|
      offline: false,
 | 
						|
      // values of 0 remove any active throttling. crbug.com/456324#c9
 | 
						|
      latency: 0,
 | 
						|
      downloadThroughput: -1,
 | 
						|
      uploadThroughput: -1,
 | 
						|
    })
 | 
						|
 | 
						|
    // Wait for the app to be ready for use
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).not.toBeDisabled({ timeout: 15000 })
 | 
						|
 | 
						|
    // Expect the network to be up
 | 
						|
    await expect(networkToggle).toContainText('Connected')
 | 
						|
    await expect(page.getByTestId('loading-stream')).not.toBeAttached()
 | 
						|
 | 
						|
    // Click off the code pane.
 | 
						|
    await page.mouse.click(100, 100)
 | 
						|
 | 
						|
    // select a line
 | 
						|
    await page.getByText(`startProfileAt(${commonPoints.startAt}, %)`).click()
 | 
						|
 | 
						|
    // enter sketch again
 | 
						|
    await u.doAndWaitForCmd(
 | 
						|
      () => page.getByRole('button', { name: 'Edit Sketch' }).click(),
 | 
						|
      'default_camera_get_settings'
 | 
						|
    )
 | 
						|
    await page.waitForTimeout(150)
 | 
						|
 | 
						|
    // Click the line tool
 | 
						|
    await page.getByRole('button', { name: 'line Line', exact: true }).click()
 | 
						|
 | 
						|
    await page.waitForTimeout(150)
 | 
						|
 | 
						|
    // Ensure we can continue sketching
 | 
						|
    await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20)
 | 
						|
    await expect.poll(u.normalisedEditorCode)
 | 
						|
      .toBe(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt([12.34, -12.34], %)
 | 
						|
  |> line([12.34, 0], %)
 | 
						|
  |> line([-12.34, 12.34], %)
 | 
						|
 | 
						|
`)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
    await page.mouse.click(startXPx, 500 - PUR * 20)
 | 
						|
 | 
						|
    await expect.poll(u.normalisedEditorCode)
 | 
						|
      .toBe(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt([12.34, -12.34], %)
 | 
						|
  |> line([12.34, 0], %)
 | 
						|
  |> line([-12.34, 12.34], %)
 | 
						|
  |> lineTo([0, -12.34], %)
 | 
						|
 | 
						|
`)
 | 
						|
 | 
						|
    // Unequip line tool
 | 
						|
    await page.keyboard.press('Escape')
 | 
						|
    // Make sure we didn't pop out of sketch mode.
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Exit Sketch' })
 | 
						|
    ).toBeVisible()
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'line Line', exact: true })
 | 
						|
    ).not.toHaveAttribute('aria-pressed', 'true')
 | 
						|
 | 
						|
    // Exit sketch
 | 
						|
    await page.keyboard.press('Escape')
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Exit Sketch' })
 | 
						|
    ).not.toBeVisible()
 | 
						|
  })
 | 
						|
})
 |