f9402a6318
* Add helper for navigating the quick picker This has problems similar to the menu except instead of closing it gets re-created which interrupts the hover call and causes the test to fail. Now it will keep trying just like the menu. * Add a test for opening a file * Add test for colliding state * Update VS Code This contains the colliding state fix.
58 lines
2.2 KiB
TypeScript
58 lines
2.2 KiB
TypeScript
import { promises as fs } from "fs"
|
|
import * as path from "path"
|
|
import { describe, test, expect } from "./baseFixture"
|
|
|
|
describe("CodeServer", true, [], () => {
|
|
test("should navigate to home page", async ({ codeServerPage }) => {
|
|
// We navigate codeServer before each test
|
|
// and we start the test with a storage state
|
|
// which means we should be logged in
|
|
// so it should be on the address
|
|
const url = codeServerPage.page.url()
|
|
// We use match because there may be a / at the end
|
|
// so we don't want it to fail if we expect http://localhost:8080 to match http://localhost:8080/
|
|
expect(url).toMatch(await codeServerPage.address())
|
|
})
|
|
|
|
test("should always see the code-server editor", async ({ codeServerPage }) => {
|
|
expect(await codeServerPage.isEditorVisible()).toBe(true)
|
|
})
|
|
|
|
test("should always have a connection", async ({ codeServerPage }) => {
|
|
expect(await codeServerPage.isConnected()).toBe(true)
|
|
})
|
|
|
|
test("should show the Integrated Terminal", async ({ codeServerPage }) => {
|
|
await codeServerPage.focusTerminal()
|
|
expect(await codeServerPage.page.isVisible("#terminal")).toBe(true)
|
|
})
|
|
|
|
test("should open a file", async ({ codeServerPage }) => {
|
|
const dir = await codeServerPage.workspaceDir
|
|
const file = path.join(dir, "foo")
|
|
await fs.writeFile(file, "bar")
|
|
await codeServerPage.openFile(file)
|
|
})
|
|
|
|
test("should not share state with other paths", async ({ codeServerPage }) => {
|
|
const dir = await codeServerPage.workspaceDir
|
|
const file = path.join(dir, "foo")
|
|
await fs.writeFile(file, "bar")
|
|
|
|
await codeServerPage.openFile(file)
|
|
|
|
// If we reload now VS Code will be unable to save the state changes so wait
|
|
// until those have been written to the database. It flushes every five
|
|
// seconds so we need to wait at least that long.
|
|
await codeServerPage.page.waitForTimeout(5500)
|
|
|
|
// The tab should re-open on refresh.
|
|
await codeServerPage.page.reload()
|
|
await codeServerPage.waitForTab(file)
|
|
|
|
// The tab should not re-open on a different path.
|
|
await codeServerPage.setup(true, "/vscode")
|
|
expect(await codeServerPage.tabIsVisible(file)).toBe(false)
|
|
})
|
|
})
|