2022-12-21 20:04:59 +01:00
|
|
|
import { describe, test, expect } from "./baseFixture"
|
2022-12-21 23:13:59 +01:00
|
|
|
import { clean, getMaybeProxiedPathname } from "../utils/helpers"
|
2022-12-21 20:04:59 +01:00
|
|
|
|
|
|
|
const routes = ["/", "/vscode", "/vscode/"]
|
|
|
|
|
|
|
|
describe("VS Code Routes", ["--disable-workspace-trust"], {}, async () => {
|
|
|
|
const testName = "vscode-routes-default"
|
|
|
|
test.beforeAll(async () => {
|
|
|
|
await clean(testName)
|
|
|
|
})
|
|
|
|
|
|
|
|
test("should load all route variations", async ({ codeServerPage }) => {
|
|
|
|
for (const route of routes) {
|
|
|
|
await codeServerPage.navigate(route)
|
|
|
|
|
|
|
|
// Check there were no redirections
|
|
|
|
const url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe(route)
|
2022-12-21 20:04:59 +01:00
|
|
|
|
2022-12-21 20:18:38 +01:00
|
|
|
// TODO@jsjoeio
|
2022-12-21 20:04:59 +01:00
|
|
|
// now that we are in a proper browser instead of scraping the HTML we
|
|
|
|
// could possibly intercept requests to make sure assets are loading from
|
|
|
|
// the right spot.
|
|
|
|
//
|
|
|
|
// Check that page loaded from correct route
|
|
|
|
const html = await codeServerPage.page.innerHTML("html")
|
|
|
|
switch (route) {
|
|
|
|
case "/":
|
|
|
|
case "/vscode/":
|
|
|
|
expect(html).toMatch(/src="\.\/[a-z]+-[0-9a-z]+\/static\//)
|
|
|
|
break
|
|
|
|
case "/vscode":
|
|
|
|
expect(html).toMatch(/src="\.\/vscode\/[a-z]+-[0-9a-z]+\/static\//)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
const CODE_WORKSPACE_DIR = process.env.CODE_WORKSPACE_DIR || ""
|
|
|
|
describe("VS Code Routes with code-workspace", ["--disable-workspace-trust", CODE_WORKSPACE_DIR], {}, async () => {
|
|
|
|
test("should redirect to the passed in workspace using human-readable query", async ({ codeServerPage }) => {
|
|
|
|
const url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe("/")
|
2022-12-21 20:04:59 +01:00
|
|
|
expect(url.search).toBe(`?workspace=${CODE_WORKSPACE_DIR}`)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
const CODE_FOLDER_DIR = process.env.CODE_FOLDER_DIR || ""
|
|
|
|
describe("VS Code Routes with code-workspace", ["--disable-workspace-trust", CODE_FOLDER_DIR], {}, async () => {
|
|
|
|
test("should redirect to the passed in folder using human-readable query", async ({ codeServerPage }) => {
|
|
|
|
const url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe("/")
|
2022-12-21 20:04:59 +01:00
|
|
|
expect(url.search).toBe(`?folder=${CODE_FOLDER_DIR}`)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe(
|
|
|
|
"VS Code Routes with ignore-last-opened",
|
|
|
|
["--disable-workspace-trust", "--ignore-last-opened"],
|
|
|
|
{},
|
|
|
|
async () => {
|
|
|
|
test("should not redirect", async ({ codeServerPage }) => {
|
|
|
|
const folder = process.env.CODE_FOLDER_DIR
|
|
|
|
|
|
|
|
await codeServerPage.navigate(`/?folder=${folder}`)
|
|
|
|
await codeServerPage.navigate(`/`)
|
|
|
|
|
|
|
|
const url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe("/")
|
2022-12-21 20:04:59 +01:00
|
|
|
expect(url.search).toBe("")
|
|
|
|
})
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2022-12-21 20:18:38 +01:00
|
|
|
describe("VS Code Routes with no workspace or folder", ["--disable-workspace-trust"], {}, async () => {
|
|
|
|
test("should redirect to last query folder/workspace", async ({ codeServerPage }) => {
|
|
|
|
const folder = process.env.CODE_FOLDER_DIR
|
|
|
|
const workspace = process.env.CODE_WORKSPACE_DIR
|
|
|
|
await codeServerPage.navigate(`/?folder=${folder}&workspace=${workspace}`)
|
2022-12-21 20:04:59 +01:00
|
|
|
|
2022-12-21 20:18:38 +01:00
|
|
|
// If you visit again without query parameters it will re-attach them by
|
|
|
|
// redirecting. It should always redirect to the same route.
|
|
|
|
for (const route of routes) {
|
|
|
|
await codeServerPage.navigate(route)
|
|
|
|
const url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe(route)
|
2022-12-21 20:18:38 +01:00
|
|
|
expect(url.search).toBe(`?folder=${folder}&workspace=${workspace}`)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
2022-12-21 20:04:59 +01:00
|
|
|
|
2022-12-21 20:18:38 +01:00
|
|
|
describe("VS Code Routes with no workspace or folder", ["--disable-workspace-trust"], {}, async () => {
|
|
|
|
test("should not redirect if ew passed in", async ({ codeServerPage }) => {
|
|
|
|
const folder = process.env.CODE_FOLDER_DIR
|
|
|
|
const workspace = process.env.CODE_WORKSPACE_DIR
|
|
|
|
await codeServerPage.navigate(`/?folder=${folder}&workspace=${workspace}`)
|
2022-12-21 20:04:59 +01:00
|
|
|
|
2022-12-21 20:18:38 +01:00
|
|
|
// Closing the folder should stop the redirecting.
|
|
|
|
await codeServerPage.navigate("/?ew=true")
|
|
|
|
let url = new URL(codeServerPage.page.url())
|
2022-12-21 23:13:59 +01:00
|
|
|
const pathname = getMaybeProxiedPathname(url)
|
|
|
|
expect(pathname).toBe("/")
|
2022-12-21 20:18:38 +01:00
|
|
|
expect(url.search).toBe("?ew=true")
|
|
|
|
})
|
|
|
|
})
|