Files
modeling-app/e2e/playwright/temporary-workspace.spec.ts
Zookeeper Lee acb43fc82c Prompt for temporary workspace when loading external sample or share link code (#7393)
* Prompt for temporary workspace when loading external sample

* Always go into temporary workspace when loading sample

* Always go into temporary workspace even on external links

* x

* Add tests

* Fix typo

* Update snapshots

* Update snapshots

* Fix tests that now strip code param

* Fix test

* Weird...

* fmt

* x

* Add await

* agh

* Do not clear query parameters, causes more problems than not

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2025-06-16 22:52:13 -04:00

118 lines
4.3 KiB
TypeScript

import { expect, test } from '@e2e/playwright/zoo-test'
import { stringToBase64 } from '@src/lib/base64'
test.describe('Temporary workspace', () => {
test(
'Opening a share link creates a temporary environment that is not saved',
{ tag: ['@web'] },
async ({ page, editor, scene, cmdBar, homePage }) => {
await test.step('Pre-condition: editor is empty', async () => {
await homePage.goToModelingScene()
await scene.settled(cmdBar)
await editor.expectEditor.toContain('')
})
await test.step('Go to share link, check new content present, make a change', async () => {
const code = `sketch001 = startSketchOn(XY)
profile001 = startProfile(sketch001, at = [-124.89, -186.4])
|> line(end = [391.31, 444.04])
|> line(end = [96.21, -493.07])
|> line(endAbsolute = [profileStartX(%), profileStartY(%)])
|> close()
extrude001 = extrude(profile001, length = 5)
`
const codeQueryParam = encodeURIComponent(stringToBase64(code))
const targetURL = `?create-file=true&browser=test&code=${codeQueryParam}&ask-open-desktop=true`
await page.goto(page.url() + targetURL)
await expect.poll(() => page.url()).toContain(targetURL)
const button = page.getByRole('button', { name: 'Continue to web app' })
await button.click()
await editor.expectEditor.toContain(code, { shouldNormalise: true })
await editor.scrollToText('-124.89', true)
await page.keyboard.press('9')
await page.keyboard.press('9')
})
await test.step('Post-condition: empty editor once again (original state)', async () => {
await homePage.goToModelingScene()
await scene.settled(cmdBar)
const code = await page.evaluate(() =>
window.localStorage.getItem('persistCode')
)
await expect(code).toContain('')
})
}
)
test(
'Opening a sample link creates a temporary environment that is not saved',
{ tag: ['@web'] },
async ({ page, editor, scene, cmdBar, homePage }) => {
await test.step('Pre-condition: editor is empty', async () => {
await homePage.goToModelingScene()
await scene.settled(cmdBar)
await editor.expectEditor.toContain('')
})
await test.step('Load sample, make an edit', async () => {
await page.goto(
`${page.url()}/?cmd=add-kcl-file-to-project&groupId=application&projectName=browser&source=kcl-samples&sample=brake-rotor/main.kcl`
)
await editor.scrollToText('114.3', true)
await page.keyboard.press('9')
await page.keyboard.press('9')
})
await test.step('Post-condition: empty editor once again (original state)', async () => {
await homePage.goToModelingScene()
await scene.settled(cmdBar)
const code = await page.evaluate(() =>
window.localStorage.getItem('persistCode')
)
await expect(code).toContain('')
})
}
)
test(
'Hitting save will save the temporary workspace',
{ tag: ['@web'] },
async ({ page, editor, scene, cmdBar, homePage }) => {
const buttonSaveTemporaryWorkspace = page.getByTestId('tws-save')
await test.step('Pre-condition: editor is empty', async () => {
await homePage.goToModelingScene()
await scene.settled(cmdBar)
await editor.expectEditor.toContain('')
})
await test.step('Load sample, make an edit, *save*', async () => {
await page.goto(
`${page.url()}/?cmd=add-kcl-file-to-project&groupId=application&projectName=browser&source=kcl-samples&sample=brake-rotor/main.kcl`
)
await homePage.goToModelingScene()
await scene.settled(cmdBar)
await editor.scrollToText('114.3')
await editor.replaceCode('114.3', '999.9133')
await editor.expectEditor.toContain('999.9133')
await buttonSaveTemporaryWorkspace.click()
await expect(buttonSaveTemporaryWorkspace).not.toBeVisible()
await editor.expectEditor.toContain('999.9133')
})
await test.step('Post-condition: has the edits in localStorage', async () => {
const code = await page.evaluate(() =>
window.localStorage.getItem('persistCode')
)
await expect(code).toContain('999.9133')
})
}
)
})