130 lines
3.8 KiB
TypeScript
130 lines
3.8 KiB
TypeScript
import { test, expect, Page } from './zoo-test'
|
|
import { HomePageFixture } from './fixtures/homePageFixture'
|
|
import { getUtils } from './test-utils'
|
|
import { EngineCommand } from 'lang/std/artifactGraph'
|
|
import { uuidv4 } from 'lib/utils'
|
|
|
|
test.describe(
|
|
'Can create sketches on all planes and their back sides',
|
|
{ tag: ['@skipWin'] },
|
|
() => {
|
|
const sketchOnPlaneAndBackSideTest = async (
|
|
page: Page,
|
|
homePage: HomePageFixture,
|
|
plane: string,
|
|
clickCoords: { x: number; y: number }
|
|
) => {
|
|
const u = await getUtils(page)
|
|
const PUR = 400 / 37.5 //pixeltoUnitRatio
|
|
await page.setBodyDimensions({ width: 1200, height: 500 })
|
|
|
|
await homePage.goToModelingScene()
|
|
// FIXME: Cannot use scene.waitForExecutionDone() since there is no KCL code
|
|
await page.waitForTimeout(10000)
|
|
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 = `sketch001 = startSketchOn('${plane}')profile001 = startProfileAt([0.9, -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(300) // wait for animation
|
|
|
|
await expect(
|
|
page.getByRole('button', { name: 'line Line', exact: true })
|
|
).toBeVisible()
|
|
|
|
// draw a line
|
|
const startXPx = 600
|
|
|
|
await u.closeDebugPanel()
|
|
await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10)
|
|
|
|
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()
|
|
}
|
|
test('XY', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(
|
|
page,
|
|
homePage,
|
|
'XY',
|
|
{ x: 600, y: 388 } // red plane
|
|
// { x: 600, y: 400 }, // red plane // clicks grid helper and that causes problems, should fix so that these coords work too.
|
|
)
|
|
})
|
|
|
|
test('YZ', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(page, homePage, 'YZ', {
|
|
x: 700,
|
|
y: 250,
|
|
}) // green plane
|
|
})
|
|
|
|
test('XZ', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(page, homePage, '-XZ', {
|
|
x: 700,
|
|
y: 80,
|
|
}) // blue plane
|
|
})
|
|
|
|
test('-XY', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(page, homePage, '-XY', {
|
|
x: 600,
|
|
y: 118,
|
|
}) // back of red plane
|
|
})
|
|
|
|
test('-YZ', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(page, homePage, '-YZ', {
|
|
x: 700,
|
|
y: 219,
|
|
}) // back of green plan
|
|
})
|
|
|
|
test('-XZ', async ({ page, homePage }) => {
|
|
await sketchOnPlaneAndBackSideTest(page, homePage, 'XZ', {
|
|
x: 700,
|
|
y: 427,
|
|
}) // back of blue plane
|
|
})
|
|
}
|
|
)
|