* Re-enable 'code pane closed at start'
Relates to #4838
* Enable test on current branch
* Revert "Enable test on current branch"
This reverts commit 0d970b9ad6.
		
	
		
			
				
	
	
		
			163 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { test, expect, Page } from './zoo-test'
 | 
						|
import {
 | 
						|
  getUtils,
 | 
						|
  TEST_COLORS,
 | 
						|
  commonPoints,
 | 
						|
  PERSIST_MODELING_CONTEXT,
 | 
						|
} from './test-utils'
 | 
						|
import { HomePageFixture } from './fixtures/homePageFixture'
 | 
						|
 | 
						|
test.setTimeout(120000)
 | 
						|
 | 
						|
async function doBasicSketch(
 | 
						|
  page: Page,
 | 
						|
  homePage: HomePageFixture,
 | 
						|
  openPanes: string[]
 | 
						|
) {
 | 
						|
  const u = await getUtils(page)
 | 
						|
  await page.setBodyDimensions({ width: 1200, height: 500 })
 | 
						|
  const PUR = 400 / 37.5 //pixeltoUnitRatio
 | 
						|
 | 
						|
  await homePage.goToModelingScene()
 | 
						|
  await u.waitForPageLoad()
 | 
						|
  await page.waitForTimeout(1000)
 | 
						|
  await u.openDebugPanel()
 | 
						|
 | 
						|
  // If we have the code pane open, we should see the code.
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(``)
 | 
						|
  } else {
 | 
						|
    // Ensure we don't see the code.
 | 
						|
    await expect(u.codeLocator).not.toBeVisible()
 | 
						|
  }
 | 
						|
 | 
						|
  await expect(
 | 
						|
    page.getByRole('button', { name: 'Start Sketch' })
 | 
						|
  ).not.toBeDisabled()
 | 
						|
  await expect(page.getByRole('button', { name: 'Start Sketch' })).toBeVisible()
 | 
						|
 | 
						|
  // 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)
 | 
						|
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')`)
 | 
						|
  }
 | 
						|
  await u.closeDebugPanel()
 | 
						|
 | 
						|
  await page.waitForTimeout(1000) // TODO detect animation ending, or disable animation
 | 
						|
 | 
						|
  const startXPx = 600
 | 
						|
  await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 10)
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt(${commonPoints.startAt}, %)`)
 | 
						|
  }
 | 
						|
  await page.waitForTimeout(500)
 | 
						|
  await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 10)
 | 
						|
  await page.waitForTimeout(500)
 | 
						|
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt(${commonPoints.startAt}, %)
 | 
						|
  |> xLine(${commonPoints.num1}, %)`)
 | 
						|
  }
 | 
						|
  await page.waitForTimeout(500)
 | 
						|
  await page.mouse.click(startXPx + PUR * 20, 500 - PUR * 20)
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt(${commonPoints.startAt}, %)
 | 
						|
  |> xLine(${commonPoints.num1}, %)
 | 
						|
  |> yLine(${commonPoints.num1 + 0.01}, %)`)
 | 
						|
  } else {
 | 
						|
    await page.waitForTimeout(500)
 | 
						|
  }
 | 
						|
  await page.waitForTimeout(200)
 | 
						|
  await page.mouse.click(startXPx, 500 - PUR * 20)
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt(${commonPoints.startAt}, %)
 | 
						|
  |> xLine(${commonPoints.num1}, %)
 | 
						|
  |> yLine(${commonPoints.num1 + 0.01}, %)
 | 
						|
  |> xLine(${commonPoints.num2 * -1}, %)`)
 | 
						|
  }
 | 
						|
 | 
						|
  // deselect line tool
 | 
						|
  const btnLine = page.getByTestId('line')
 | 
						|
  const btnLineAriaPressed = await btnLine.getAttribute('aria-pressed')
 | 
						|
  if (btnLineAriaPressed === 'true') {
 | 
						|
    await btnLine.click()
 | 
						|
  }
 | 
						|
 | 
						|
  await page.waitForTimeout(100)
 | 
						|
 | 
						|
  const line1 = await u.getSegmentBodyCoords(`[data-overlay-index="${0}"]`, 0)
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect
 | 
						|
      .poll(async () => u.getGreatestPixDiff(line1, TEST_COLORS.WHITE))
 | 
						|
      .toBeLessThan(3)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
    await expect
 | 
						|
      .poll(async () => u.getGreatestPixDiff(line1, [249, 249, 249]))
 | 
						|
      .toBeLessThan(3)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
  }
 | 
						|
 | 
						|
  // click between first two clicks to get center of the line
 | 
						|
  await page.mouse.click(startXPx + PUR * 15, 500 - PUR * 10)
 | 
						|
  await page.waitForTimeout(100)
 | 
						|
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(
 | 
						|
      await u.getGreatestPixDiff(line1, TEST_COLORS.BLUE)
 | 
						|
    ).toBeLessThan(3)
 | 
						|
    await expect(await u.getGreatestPixDiff(line1, [0, 0, 255])).toBeLessThan(3)
 | 
						|
  }
 | 
						|
 | 
						|
  // hold down shift
 | 
						|
  await page.keyboard.down('Shift')
 | 
						|
  await page.waitForTimeout(100)
 | 
						|
 | 
						|
  // click between the latest two clicks to get center of the line
 | 
						|
  await page.mouse.click(startXPx + PUR * 10, 500 - PUR * 20)
 | 
						|
  await page.waitForTimeout(100)
 | 
						|
 | 
						|
  // selected two lines therefore there should be two cursors
 | 
						|
  if (openPanes.includes('code')) {
 | 
						|
    await expect(page.locator('.cm-cursor')).toHaveCount(2)
 | 
						|
    await page.waitForTimeout(100)
 | 
						|
  }
 | 
						|
 | 
						|
  await page.getByRole('button', { name: 'Length: open menu' }).click()
 | 
						|
  await page.getByRole('button', { name: 'Equal Length' }).click()
 | 
						|
 | 
						|
  // Open the code pane.
 | 
						|
  await u.openKclCodePanel()
 | 
						|
  await expect(u.codeLocator).toHaveText(`sketch001 = startSketchOn('XZ')
 | 
						|
  |> startProfileAt(${commonPoints.startAt}, %)
 | 
						|
  |> xLine(${commonPoints.num1}, %, $seg01)
 | 
						|
  |> yLine(${commonPoints.num1 + 0.01}, %)
 | 
						|
  |> xLine(-segLen(seg01), %)`)
 | 
						|
}
 | 
						|
 | 
						|
test.describe('Basic sketch', () => {
 | 
						|
  test.fixme('code pane open at start', async ({ page, homePage }) => {
 | 
						|
    await doBasicSketch(page, homePage, ['code'])
 | 
						|
  })
 | 
						|
 | 
						|
  test('code pane closed at start', async ({ page, homePage }) => {
 | 
						|
    // Load the app with the code panes
 | 
						|
    await page.addInitScript(async (persistModelingContext) => {
 | 
						|
      localStorage.setItem(
 | 
						|
        persistModelingContext,
 | 
						|
        JSON.stringify({ openPanes: [] })
 | 
						|
      )
 | 
						|
    }, PERSIST_MODELING_CONTEXT)
 | 
						|
    await doBasicSketch(page, homePage, [])
 | 
						|
  })
 | 
						|
})
 |