* Add back stream idle mode
* Shut up codespell
* Correct serialization; only expose at user level
* cargo fmt
* tsc lint fmt
* Move engineStreamMachine as a global actor; tons of more work
* Fix up everything after bumping kittycad/lib
* Remove camera sync
* Use pause/play iconology
* Add back better ping indicator
* wip
* Fix streamIdleMode checkbox being wonky
* yarn fmt
* Massive extinction event for waitForExecutionDone; try to stop projects view switching from crashing
* Clear diagnostics when unmounting code editor!
* wip
* Rework initial root projects dir + deflake many projects tests
* More e2e fixes
* Deflake revolve some revolve tests
* Fix the rest of the mfing tests
* yarn fmt
* yarn lint
* yarn tsc
* Fix tsc after rebase
* wip
* less flaky point and click
* wip
* Fixup after rebase
* Fix more tests
* Fix 2 more
* Fix up named-views tests
* yarn fmt lint tsc
* Fix up new changes
* Get rid of 1 cyclic dependency
* Fix another cyclic mfer!
* fmt
* fmt tsc
* Fix zoom to fit being frigged
* a new list of circular deps
* Remove NetworkHealthIndicator test that was shit
* Fix the bad reload repeat issue kevin started on
* Fix zoom to fit at the right moments...
* Fix cache count numbers in editor test
* Remove a test race - poll window info.
* Qualify fail function
* Try something
* Use scene.connectionEstablished
* Hopefully fix snapshots at least
* Add app console.log
* Fix native menu tests more
* tsc lint
* Fix camera failure
* Try again
* Test attempt number 15345203, action!
* Add back old window detection heuristic
* Remove firstWindow to complete the work of 2342d04fe2
* Tweak some tests for MacOS
* Tweak "set appearance" test for MacOS
Revert this if it messes up any other platform's color checks!
* Are you serious? This was all that needed formatting?
* More color tweaks
Local MacOS and CI MacOS don't agree
* Fixes on apperance e2e test for stream idle branch (#6168)
pierremtb/stream-idle-revamp-appearance-fixes
* Another apperance fix
* Skip one native menu test to make stream idle green (#6169)
* pierremtb/stream-idle-revamp-more-fixes
* Fix lint
* Update snapshot for test_generate_settings_docs
---------
Co-authored-by: lee-at-zoo-corp <lee@zoo.dev>
Co-authored-by: Frank Noirot <frankjohnson1993@gmail.com>
Co-authored-by: Pierre Jacquier <pierrejacquier39@gmail.com>
Co-authored-by: Pierre Jacquier <pierre@zoo.dev>
		
	
		
			
				
	
	
		
			138 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import type { Page } from '@playwright/test'
 | 
						|
import type { EngineCommand } from '@src/lang/std/artifactGraph'
 | 
						|
import { uuidv4 } from '@src/lib/utils'
 | 
						|
 | 
						|
import type { HomePageFixture } from '@e2e/playwright/fixtures/homePageFixture'
 | 
						|
import type { SceneFixture } from '@e2e/playwright/fixtures/sceneFixture'
 | 
						|
import type { ToolbarFixture } from '@e2e/playwright/fixtures/toolbarFixture'
 | 
						|
import { getUtils } from '@e2e/playwright/test-utils'
 | 
						|
import { expect, test } from '@e2e/playwright/zoo-test'
 | 
						|
 | 
						|
test.describe(
 | 
						|
  'Can create sketches on all planes and their back sides',
 | 
						|
  { tag: ['@skipWin'] },
 | 
						|
  () => {
 | 
						|
    const sketchOnPlaneAndBackSideTest = async (
 | 
						|
      page: Page,
 | 
						|
      homePage: HomePageFixture,
 | 
						|
      scene: SceneFixture,
 | 
						|
      toolbar: ToolbarFixture,
 | 
						|
      plane: string,
 | 
						|
      clickCoords: { x: number; y: number }
 | 
						|
    ) => {
 | 
						|
      const u = await getUtils(page)
 | 
						|
      await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
 | 
						|
      await homePage.goToModelingScene()
 | 
						|
      const XYPlanRed: [number, number, number] = [98, 50, 51]
 | 
						|
      await scene.expectPixelColor(XYPlanRed, { x: 700, y: 300 }, 15)
 | 
						|
 | 
						|
      await u.openDebugPanel()
 | 
						|
 | 
						|
      const coord =
 | 
						|
        plane === '-XY' || plane === '-YZ' || plane === 'XZ' ? -100 : 100
 | 
						|
      const camCommand: EngineCommand = {
 | 
						|
        type: 'modeling_cmd_req',
 | 
						|
        cmd_id: uuidv4(),
 | 
						|
        cmd: {
 | 
						|
          type: 'default_camera_look_at',
 | 
						|
          center: { x: 0, y: 0, z: 0 },
 | 
						|
          vantage: { x: coord, y: coord, z: coord },
 | 
						|
          up: { x: 0, y: 0, z: 1 },
 | 
						|
        },
 | 
						|
      }
 | 
						|
      const updateCamCommand: EngineCommand = {
 | 
						|
        type: 'modeling_cmd_req',
 | 
						|
        cmd_id: uuidv4(),
 | 
						|
        cmd: {
 | 
						|
          type: 'default_camera_get_settings',
 | 
						|
        },
 | 
						|
      }
 | 
						|
 | 
						|
      const code = `@settings(defaultLengthUnit = in)sketch001 = startSketchOn(${plane})profile001 = startProfileAt([0.91, -1.22], sketch001)`
 | 
						|
 | 
						|
      await u.openDebugPanel()
 | 
						|
 | 
						|
      await u.clearCommandLogs()
 | 
						|
      await page.getByRole('button', { name: 'Start Sketch' }).click()
 | 
						|
 | 
						|
      await u.sendCustomCmd(camCommand)
 | 
						|
      await page.waitForTimeout(100)
 | 
						|
      await u.sendCustomCmd(updateCamCommand)
 | 
						|
 | 
						|
      await u.closeDebugPanel()
 | 
						|
 | 
						|
      await page.mouse.click(clickCoords.x, clickCoords.y)
 | 
						|
      await page.waitForTimeout(600) // wait for animation
 | 
						|
 | 
						|
      await toolbar.waitUntilSketchingReady()
 | 
						|
 | 
						|
      await expect(
 | 
						|
        page.getByRole('button', { name: 'line Line', exact: true })
 | 
						|
      ).toBeVisible()
 | 
						|
 | 
						|
      await u.closeDebugPanel()
 | 
						|
      await page.mouse.click(707, 393)
 | 
						|
 | 
						|
      await expect(page.locator('.cm-content')).toHaveText(code)
 | 
						|
 | 
						|
      await page
 | 
						|
        .getByRole('button', { name: 'line Line', exact: true })
 | 
						|
        .first()
 | 
						|
        .click()
 | 
						|
      await u.openAndClearDebugPanel()
 | 
						|
      await page.getByRole('button', { name: 'Exit Sketch' }).click()
 | 
						|
      await u.expectCmdLog('[data-message-type="execution-done"]')
 | 
						|
 | 
						|
      await u.clearCommandLogs()
 | 
						|
      await u.removeCurrentCode()
 | 
						|
    }
 | 
						|
 | 
						|
    const planeConfigs = [
 | 
						|
      {
 | 
						|
        plane: 'XY',
 | 
						|
        coords: { x: 600, y: 388 },
 | 
						|
        description: 'red plane',
 | 
						|
      },
 | 
						|
      {
 | 
						|
        plane: 'YZ',
 | 
						|
        coords: { x: 700, y: 250 },
 | 
						|
        description: 'green plane',
 | 
						|
      },
 | 
						|
      {
 | 
						|
        plane: 'XZ',
 | 
						|
        coords: { x: 684, y: 427 },
 | 
						|
        description: 'blue plane',
 | 
						|
      },
 | 
						|
      {
 | 
						|
        plane: '-XY',
 | 
						|
        coords: { x: 600, y: 118 },
 | 
						|
        description: 'back of red plane',
 | 
						|
      },
 | 
						|
      {
 | 
						|
        plane: '-YZ',
 | 
						|
        coords: { x: 700, y: 219 },
 | 
						|
        description: 'back of green plane',
 | 
						|
      },
 | 
						|
      {
 | 
						|
        plane: '-XZ',
 | 
						|
        coords: { x: 700, y: 80 },
 | 
						|
        description: 'back of blue plane',
 | 
						|
      },
 | 
						|
    ]
 | 
						|
 | 
						|
    for (const config of planeConfigs) {
 | 
						|
      test(config.plane, async ({ page, homePage, scene, toolbar }) => {
 | 
						|
        await sketchOnPlaneAndBackSideTest(
 | 
						|
          page,
 | 
						|
          homePage,
 | 
						|
          scene,
 | 
						|
          toolbar,
 | 
						|
          config.plane,
 | 
						|
          config.coords
 | 
						|
        )
 | 
						|
      })
 | 
						|
    }
 | 
						|
  }
 | 
						|
)
 |