* Move all tests over to electron * Pass the correct param to playwright-electron.sh * Add shebang to script and add macos-14-large as a target * Get sketch-tests.spec.ts passing in electron * Try out 4 workers * Got testing-segment-overlays passing * Pass testing-selections.spec.ts * Go back to fix up sketch-tests test * Pass various.spec.ts, by far the hardest one * Pass can-sketch-on-all-planes... with ease * Pass command bar tests * fmt * Completely fix code mirror text navigating for tests * Pass debug pane tests * Pass desktop export tests * Pass editor tests * Pass file tree tests * Pass onboarding tests * Corrected a fixme in file-tree.spec! * Painfully fix hardcoded coordinates in point-click.spec * Pass machine.spec tests * Pass projects, fought hard with filechooser * Pass regresion-tests.spec tests * Pass network and connection tests * Pass camera-movement.spec tests * Extreme time eaten by gizmo test fixes. All passing now. * Merge main (tests changed x_x) and pass all constraints.spec tests (pain) * Pass another painful spec suite: testing-settings * Pass perspective-toggle, interesting note * Pass samples loading tests * Pass app header tests * Pass text-to-cad tests * Pass segment-overlays (minor ache) and ability to switch to web if needed :) * Fix a ton of syntax changes and deflake 2 more tests (pain) * Correct all tsc errors * Remove to-electron script * Add an f-ton of shit because playwright doesnt want S P R E A D * Try CI again * Stop snapshots of exports (already test in e2e) * Fix flake in double click editor * Hopefully help CI flake * Fixmes, fixmes everywhere * One more fixme to settings * Skip another code pane flake * Port jess's projects.spec tests * fixup * Reuse electron window; difficult task * Rebased and refixed * Remove duplicate cases * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores) * Reduce the workers to something CI can handle * Lower it further, we need to think about the others * Update package.json Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> * Update package.json Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> * Fix the last tests and tsc errors * Timeout to 120 and windows-2022-16core * Fix windows runner detection, enable concurrency temporarily * Hopefully this time fix windows runner detection * Comment out Vector, add back removed camera test code * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * Fix camera tests again * Massively deflake a whole class of tests * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores) * Try new CI and fix small onboarding test * Derp * No github tuning * Try mac * Add back all the OS * Lord, hallow be thy name * A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores) * A snapshot a day keeps the bugs away! 📷🐛 (OS: windows-latest-8-cores) * One last try with window-16-cores * Trigger CI * Try AWS Windows runner * Passing on windows locally with a few skips * Skip more win tests, add back all three oses * A snapshot a day keeps the bugs away! 📷🐛 (OS: windows-16-cores) * Add two more fixmes * 2 more fixmes * skip segment overlays on win32 * Another fixme * Trigger CI * Trigger CI * Quick clean up * Move all tests over to electron * Pass the correct param to playwright-electron.sh * Add shebang to script and add macos-14-large as a target * Get sketch-tests.spec.ts passing in electron * Try out 4 workers * Got testing-segment-overlays passing * Pass testing-selections.spec.ts * Go back to fix up sketch-tests test * Pass various.spec.ts, by far the hardest one * Pass can-sketch-on-all-planes... with ease * Pass command bar tests * fmt * Completely fix code mirror text navigating for tests * Pass debug pane tests * Pass desktop export tests * Pass editor tests * Pass file tree tests * Pass onboarding tests * Corrected a fixme in file-tree.spec! * Painfully fix hardcoded coordinates in point-click.spec * Pass machine.spec tests * Pass projects, fought hard with filechooser * Pass regresion-tests.spec tests * Pass network and connection tests * Pass camera-movement.spec tests * Extreme time eaten by gizmo test fixes. All passing now. * Merge main (tests changed x_x) and pass all constraints.spec tests (pain) * Pass another painful spec suite: testing-settings * Pass perspective-toggle, interesting note * Pass samples loading tests * Pass app header tests * Pass text-to-cad tests * Pass segment-overlays (minor ache) and ability to switch to web if needed :) * Fix a ton of syntax changes and deflake 2 more tests (pain) * Correct all tsc errors * Remove to-electron script * Add an f-ton of shit because playwright doesnt want S P R E A D * Try CI again * Stop snapshots of exports (already test in e2e) * Fix flake in double click editor * Hopefully help CI flake * Fixmes, fixmes everywhere * One more fixme to settings * Skip another code pane flake * Port jess's projects.spec tests * fixup * Reuse electron window; difficult task * Rebased and refixed * Remove duplicate cases * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores) * Reduce the workers to something CI can handle * Lower it further, we need to think about the others * Update package.json Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> * Update package.json Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> * Fix the last tests and tsc errors * Timeout to 120 and windows-2022-16core * Fix windows runner detection, enable concurrency temporarily * Hopefully this time fix windows runner detection * Comment out Vector, add back removed camera test code * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest-8-cores) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * Fix camera tests again * Massively deflake a whole class of tests * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * A snapshot a day keeps the bugs away! 📷🐛 (OS: macos-14-large) * Try new CI and fix small onboarding test * Derp * No github tuning * Try mac * Add back all the OS * Lord, hallow be thy name * A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores) * A snapshot a day keeps the bugs away! 📷🐛 (OS: windows-latest-8-cores) * Try AWS Windows runner * Passing on windows locally with a few skips * Trigger CI * A snapshot a day keeps the bugs away! 📷🐛 (OS: namespace-profile-ubuntu-8-cores) * fmt, tsc, lint * Enable two fixmes again * Fix lint, codespell, fmt * Fix lint * Don't run e2e on draft, add back concurrency, clean up * One last windows skip --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com> Co-authored-by: Pierre Jacquier <pierre@zoo.dev>
		
			
				
	
	
		
			535 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			535 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { test, expect } from './zoo-test'
 | 
						|
import { getUtils } from './test-utils'
 | 
						|
 | 
						|
test.describe('Copilot ghost text', () => {
 | 
						|
  // eslint-disable-next-line jest/valid-title
 | 
						|
  test.skip(true, 'Needs to get covered again')
 | 
						|
 | 
						|
  test('completes code in empty file', async ({ page, homePage }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // We should be able to hit Tab to accept the completion.
 | 
						|
    await page.keyboard.press('Tab')
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
 | 
						|
    // Hit enter a few times.
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)    `
 | 
						|
    )
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
  })
 | 
						|
 | 
						|
  test.skip('copilot disabled in sketch mode no select plane', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    // Click sketch mode.
 | 
						|
    await page.getByRole('button', { name: 'Start Sketch' }).click()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    // Exit sketch mode.
 | 
						|
    await page.getByRole('button', { name: 'Exit Sketch' }).click()
 | 
						|
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // We should be able to hit Tab to accept the completion.
 | 
						|
    await page.keyboard.press('Tab')
 | 
						|
    await expect(page.locator('.cm-content')).toContainText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
  })
 | 
						|
 | 
						|
  test('copilot disabled in sketch mode after selecting plane', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    // Click sketch mode.
 | 
						|
    await expect(
 | 
						|
      page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
    ).not.toBeDisabled()
 | 
						|
    await page.getByRole('button', { name: 'Start Sketch' }).click()
 | 
						|
 | 
						|
    // select a plane
 | 
						|
    await page.mouse.click(700, 200)
 | 
						|
    await page.waitForTimeout(700) // wait for animation
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')`
 | 
						|
    )
 | 
						|
 | 
						|
    // Escape to exit the tool.
 | 
						|
    await u.openDebugPanel()
 | 
						|
    await u.closeDebugPanel()
 | 
						|
    await page.keyboard.press('Escape')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')`
 | 
						|
    )
 | 
						|
 | 
						|
    // Escape again to exit sketch mode.
 | 
						|
    await u.openDebugPanel()
 | 
						|
    await u.closeDebugPanel()
 | 
						|
    await page.keyboard.press('Escape')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // We should be able to hit Tab to accept the completion.
 | 
						|
    await page.keyboard.press('Tab')
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
 | 
						|
    // Hit enter a few times.
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `sketch001 = startSketchOn('XZ')fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)    `
 | 
						|
    )
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
  })
 | 
						|
 | 
						|
  test('ArrowUp in code rejects the suggestion', async ({ page, homePage }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.press('ArrowUp')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
  })
 | 
						|
 | 
						|
  test('ArrowDown in code rejects the suggestion', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.press('ArrowDown')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
  })
 | 
						|
 | 
						|
  test('ArrowLeft in code rejects the suggestion', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.press('ArrowLeft')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
  })
 | 
						|
 | 
						|
  test('ArrowRight in code rejects the suggestion', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.press('ArrowRight')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
  })
 | 
						|
 | 
						|
  test('Enter in code scoots it down', async ({ page, homePage }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
  })
 | 
						|
 | 
						|
  test('Ctrl+shift+z in code rejects the suggestion', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Going elsewhere in the code should hide the ghost text.
 | 
						|
    await page.keyboard.down('ControlOrMeta')
 | 
						|
    await page.keyboard.down('Shift')
 | 
						|
    await page.keyboard.press('KeyZ')
 | 
						|
    await page.keyboard.up('ControlOrMeta')
 | 
						|
    await page.keyboard.up('Shift')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
  })
 | 
						|
 | 
						|
  test('Ctrl+z in code rejects the suggestion and undos the last code', async ({
 | 
						|
    page,
 | 
						|
    homePage,
 | 
						|
  }) => {
 | 
						|
    const u = await getUtils(page)
 | 
						|
    // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
    await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
    await homePage.goToModelingScene()
 | 
						|
 | 
						|
    await page.waitForTimeout(800)
 | 
						|
    await u.codeLocator.click()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    await page.keyboard.type('{thing: "blah"}', { delay: 0 })
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(`{thing: "blah"}`)
 | 
						|
 | 
						|
    // We wanna make sure the code saves.
 | 
						|
    await page.waitForTimeout(800)
 | 
						|
 | 
						|
    // Ctrl+z
 | 
						|
    await page.keyboard.down('ControlOrMeta')
 | 
						|
    await page.keyboard.press('KeyZ')
 | 
						|
    await page.keyboard.up('ControlOrMeta')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
    // Ctrl+shift+z
 | 
						|
    await page.keyboard.down('ControlOrMeta')
 | 
						|
    await page.keyboard.down('Shift')
 | 
						|
    await page.keyboard.press('KeyZ')
 | 
						|
    await page.keyboard.up('ControlOrMeta')
 | 
						|
    await page.keyboard.up('Shift')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(`{thing: "blah"}`)
 | 
						|
 | 
						|
    // We wanna make sure the code saves.
 | 
						|
    await page.waitForTimeout(800)
 | 
						|
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
    await page.keyboard.press('Enter')
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
    await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
      `{thing: "blah"}fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
    )
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
      `fn cube = (pos, scale) => {`
 | 
						|
    )
 | 
						|
 | 
						|
    // Once for the enter.
 | 
						|
    await page.keyboard.down('ControlOrMeta')
 | 
						|
    await page.keyboard.press('KeyZ')
 | 
						|
    await page.keyboard.up('ControlOrMeta')
 | 
						|
 | 
						|
    // Once for the text.
 | 
						|
    await page.keyboard.down('ControlOrMeta')
 | 
						|
    await page.keyboard.press('KeyZ')
 | 
						|
    await page.keyboard.up('ControlOrMeta')
 | 
						|
 | 
						|
    await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
    // TODO when we make codemirror a widget, we can test this.
 | 
						|
    //await expect(page.locator('.cm-content')).toHaveText(``) })
 | 
						|
 | 
						|
    test('delete in code rejects the suggestion', async ({
 | 
						|
      page,
 | 
						|
      homePage,
 | 
						|
    }) => {
 | 
						|
      const u = await getUtils(page)
 | 
						|
      // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
      await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
      await homePage.goToModelingScene()
 | 
						|
 | 
						|
      await u.codeLocator.click()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
      await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
      await page.waitForTimeout(500)
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
      )
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {`
 | 
						|
      )
 | 
						|
 | 
						|
      // Going elsewhere in the code should hide the ghost text.
 | 
						|
      await page.keyboard.press('Delete')
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
    })
 | 
						|
 | 
						|
    test('backspace in code rejects the suggestion', async ({
 | 
						|
      page,
 | 
						|
      homePage,
 | 
						|
    }) => {
 | 
						|
      const u = await getUtils(page)
 | 
						|
      // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
      await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
      await homePage.goToModelingScene()
 | 
						|
 | 
						|
      await u.codeLocator.click()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
      await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
      await page.waitForTimeout(500)
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
      )
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {`
 | 
						|
      )
 | 
						|
 | 
						|
      // Going elsewhere in the code should hide the ghost text.
 | 
						|
      await page.keyboard.press('Backspace')
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
    })
 | 
						|
 | 
						|
    test('focus outside code pane rejects the suggestion', async ({
 | 
						|
      page,
 | 
						|
      homePage,
 | 
						|
    }) => {
 | 
						|
      const u = await getUtils(page)
 | 
						|
      // const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
      await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
      await homePage.goToModelingScene()
 | 
						|
 | 
						|
      await u.codeLocator.click()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
 | 
						|
      await expect(page.locator('.cm-ghostText')).not.toBeVisible()
 | 
						|
      await page.waitForTimeout(500)
 | 
						|
      await page.keyboard.press('Enter')
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toBeVisible()
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {  sg = startSketchOn('XY')    |> startProfileAt(pos, %)    |> line([0, scale], %)    |> line([scale, 0], %)    |> line([0, -scale], %)  return sg}part001 = cube([0,0], 20)    |> close(%)    |> extrude(20, %)`
 | 
						|
      )
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).toHaveText(
 | 
						|
        `fn cube = (pos, scale) => {`
 | 
						|
      )
 | 
						|
 | 
						|
      // Going outside the editor should hide the ghost text.
 | 
						|
      await page.mouse.move(0, 0)
 | 
						|
      await page
 | 
						|
        .getByRole('button', { name: 'Start Sketch' })
 | 
						|
        .waitFor({ state: 'visible' })
 | 
						|
      await page.getByRole('button', { name: 'Start Sketch' }).click()
 | 
						|
      await expect(page.locator('.cm-ghostText').first()).not.toBeVisible()
 | 
						|
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(``)
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 |