2021-04-13 21:02:52 +02:00
|
|
|
import { test, expect } from "@playwright/test"
|
2021-04-01 23:52:46 +02:00
|
|
|
import { CODE_SERVER_ADDRESS, STORAGE } from "../utils/constants"
|
2021-03-16 22:43:29 +01:00
|
|
|
|
2021-04-13 21:02:52 +02:00
|
|
|
test.describe("Open Help > About", () => {
|
|
|
|
test.beforeEach(async ({ page }) => {
|
2021-03-16 22:43:29 +01:00
|
|
|
// Create a new context with the saved storage state
|
2021-04-01 23:52:46 +02:00
|
|
|
// so we don't have to logged in
|
2021-04-13 21:02:52 +02:00
|
|
|
// TODO@jsjoeio reset context and use storageState
|
2021-03-16 22:43:29 +01:00
|
|
|
const storageState = JSON.parse(STORAGE) || {}
|
2021-04-01 23:52:46 +02:00
|
|
|
await page.goto(CODE_SERVER_ADDRESS, { waitUntil: "networkidle" })
|
2021-03-16 22:43:29 +01:00
|
|
|
})
|
|
|
|
|
2021-04-13 21:02:52 +02:00
|
|
|
test("should see a 'Help' then 'About' button in the Application Menu that opens a dialog", async ({ page }) => {
|
2021-03-16 22:43:29 +01:00
|
|
|
// Make sure the editor actually loaded
|
|
|
|
expect(await page.isVisible("div.monaco-workbench"))
|
|
|
|
|
|
|
|
// Click the Application menu
|
|
|
|
await page.click("[aria-label='Application Menu']")
|
|
|
|
// See the Help button
|
|
|
|
const helpButton = "a.action-menu-item span[aria-label='Help']"
|
|
|
|
expect(await page.isVisible(helpButton))
|
|
|
|
|
|
|
|
// Hover the helpButton
|
|
|
|
await page.hover(helpButton)
|
|
|
|
|
|
|
|
// see the About button and click it
|
|
|
|
const aboutButton = "a.action-menu-item span[aria-label='About']"
|
|
|
|
expect(await page.isVisible(aboutButton))
|
|
|
|
// NOTE: it won't work unless you hover it first
|
|
|
|
await page.hover(aboutButton)
|
|
|
|
await page.click(aboutButton)
|
|
|
|
|
|
|
|
const codeServerText = "text=code-server"
|
|
|
|
expect(await page.isVisible(codeServerText))
|
|
|
|
})
|
|
|
|
})
|