mirror of
https://github.com/danog/code-server.git
synced 2025-01-22 21:41:14 +01:00
62b3a6fd9f
* Fix issue where HTTP error status codes are not read. * Fix issues surrounding sessions when accessed from a proxy. - Updated vscode args to match latest upstream. - Fixed issues surrounding trailing slashes affecting base paths. - Updated cookie names to better match upstream's usage, debuggability. * Bump vendor. * Update tests. * Fix issue where tests lack cookie key. Co-authored-by: Asher <ash@coder.com>
45 lines
1.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
import { Cookie } from "playwright"
|
|
import { CookieKeys } from "../../src/common/http"
|
|
import { hash } from "../../src/node/util"
|
|
import { PASSWORD, workspaceDir } from "./constants"
|
|
import { clean } from "./helpers"
|
|
import * as wtfnode from "./wtfnode"
|
|
|
|
/**
|
|
* Perform workspace cleanup and authenticate. This should be set up to run
|
|
* before our tests execute.
|
|
*/
|
|
export default async function () {
|
|
console.log("\n🚨 Running Global Setup for Playwright End-to-End Tests")
|
|
console.log(" Please hang tight...")
|
|
|
|
// Cleanup workspaces from previous tests.
|
|
await clean(workspaceDir)
|
|
|
|
if (process.env.WTF_NODE) {
|
|
wtfnode.setup()
|
|
}
|
|
|
|
// TODO: Replace this with a call to code-server to get the cookie. To avoid
|
|
// too much overhead we can do an http POST request and avoid spawning a
|
|
// browser for it.
|
|
const cookies: Cookie[] = [
|
|
{
|
|
domain: "localhost",
|
|
expires: -1,
|
|
httpOnly: false,
|
|
name: CookieKeys.Session,
|
|
path: "/",
|
|
sameSite: "Lax",
|
|
secure: false,
|
|
value: await hash(PASSWORD),
|
|
},
|
|
]
|
|
|
|
// Save storage state and store as an env variable
|
|
// More info: https://playwright.dev/docs/auth/#reuse-authentication-state
|
|
process.env.STORAGE = JSON.stringify({ cookies })
|
|
|
|
console.log("✅ Global Setup for Playwright End-to-End Tests is now complete.")
|
|
}
|