mirror of
https://github.com/danog/code-server.git
synced 2024-12-02 17:56:04 +01:00
da4de439e0
This uses the current dev build by default but can be overidden with CODE_SERVER_TEST_ENTRY (for example to test a release or some other version). Each instance has a separate state directory. This should make parallelization work. This also means you are no longer required to specify the password and address yourself (or the extension directory once we add a test extension). `yarn test:e2e` should just work as-is. Lastly, it means the tests are no longer subject to yarn watch randomly restarting.
45 lines
1.8 KiB
TypeScript
45 lines
1.8 KiB
TypeScript
import { PASSWORD } from "../utils/constants"
|
|
import { describe, test, expect } from "./baseFixture"
|
|
|
|
describe("logout", () => {
|
|
// Reset the browser so no cookies are persisted
|
|
// by emptying the storageState
|
|
test.use({
|
|
storageState: {},
|
|
})
|
|
|
|
test("should be able login and logout", async ({ codeServerPage }) => {
|
|
// Type in password
|
|
await codeServerPage.page.fill(".password", PASSWORD)
|
|
// Click the submit button and login
|
|
await codeServerPage.page.click(".submit")
|
|
await codeServerPage.page.waitForLoadState("networkidle")
|
|
// We do this because occassionally code-server doesn't load on Firefox
|
|
// but loads if you reload once or twice
|
|
await codeServerPage.reloadUntilEditorIsReady()
|
|
// Make sure the editor actually loaded
|
|
expect(await codeServerPage.isEditorVisible()).toBe(true)
|
|
|
|
// Click the Application menu
|
|
await codeServerPage.page.click("[aria-label='Application Menu']")
|
|
|
|
// See the Log out button
|
|
const logoutButton = "a.action-menu-item span[aria-label='Log out']"
|
|
expect(await codeServerPage.page.isVisible(logoutButton)).toBe(true)
|
|
|
|
await codeServerPage.page.hover(logoutButton)
|
|
// TODO(@jsjoeio)
|
|
// Look into how we're attaching the handlers for the logout feature
|
|
// We need to see how it's done upstream and add logging to the
|
|
// handlers themselves.
|
|
// They may be attached too slowly, hence why we need this timeout
|
|
await codeServerPage.page.waitForTimeout(2000)
|
|
|
|
// Recommended by Playwright for async navigation
|
|
// https://github.com/microsoft/playwright/issues/1987#issuecomment-620182151
|
|
await Promise.all([codeServerPage.page.waitForNavigation(), codeServerPage.page.click(logoutButton)])
|
|
const currentUrl = codeServerPage.page.url()
|
|
expect(currentUrl).toBe(`${await codeServerPage.address()}/login`)
|
|
})
|
|
})
|