refactor: globalSetup to use CodeServer model
This commit is contained in:
@ -2,7 +2,8 @@ import { test, expect } from "@playwright/test"
|
||||
import * as fs from "fs"
|
||||
import { tmpdir } from "os"
|
||||
import * as path from "path"
|
||||
|
||||
import util from "util"
|
||||
import * as cp from "child_process"
|
||||
import { STORAGE } from "../utils/constants"
|
||||
import { CodeServer } from "./models/CodeServer"
|
||||
|
||||
@ -10,9 +11,11 @@ test.describe("Integrated Terminal", () => {
|
||||
// Create a new context with the saved storage state
|
||||
// so we don't have to logged in
|
||||
const options: any = {}
|
||||
const testFileName = "test.txt"
|
||||
const testFileName = "pipe"
|
||||
const testString = "new string test from e2e test"
|
||||
let codeServer: CodeServer
|
||||
let tmpFolderPath: string = ""
|
||||
let tmpFile: string = ""
|
||||
|
||||
// TODO@jsjoeio
|
||||
// Fix this once https://github.com/microsoft/playwright-test/issues/240
|
||||
@ -25,26 +28,34 @@ test.describe("Integrated Terminal", () => {
|
||||
}
|
||||
test.beforeEach(async ({ page }) => {
|
||||
codeServer = new CodeServer(page)
|
||||
await codeServer.navigate()
|
||||
})
|
||||
|
||||
test("should echo a string to a file", options, async ({ page }) => {
|
||||
await codeServer.setup()
|
||||
// NOTE@jsjoeio
|
||||
// We're not using tmpdir from src/node/constants
|
||||
// because Playwright doesn't fully support ES modules from
|
||||
// the erorrs I'm seeing
|
||||
const tmpFolderPath = fs.mkdtempSync(path.join(tmpdir(), "code-server-test"))
|
||||
const tmpFile = `${tmpFolderPath}${path.sep}${testFileName}`
|
||||
tmpFolderPath = fs.mkdtempSync(path.join(tmpdir(), "code-server-test"))
|
||||
tmpFile = path.join(tmpFolderPath, testFileName)
|
||||
})
|
||||
|
||||
test.afterEach(async () => {
|
||||
// Ensure directory was removed
|
||||
fs.rmdirSync(tmpFolderPath, { recursive: true })
|
||||
})
|
||||
|
||||
test("should echo a string to a file", options, async ({ page }) => {
|
||||
const command = `mkfifo '${tmpFile}' && cat '${tmpFile}'`
|
||||
const exec = util.promisify(cp.exec)
|
||||
const output = exec(command, { encoding: "utf8" })
|
||||
|
||||
// Open terminal and type in value
|
||||
await codeServer.focusTerminal()
|
||||
|
||||
// give the terminal a second to load
|
||||
await page.waitForTimeout(3000)
|
||||
await page.keyboard.type(`echo '${testString}' > ${tmpFile}`)
|
||||
// Wait for the typing to finish before hitting enter
|
||||
await page.waitForTimeout(500)
|
||||
await page.waitForLoadState("load")
|
||||
await page.keyboard.type(`echo '${testString}' > '${tmpFile}'`)
|
||||
await page.keyboard.press("Enter")
|
||||
await page.waitForTimeout(2000)
|
||||
|
||||
const { stdout } = await output
|
||||
expect(stdout).toMatch(testString)
|
||||
|
||||
// .access checks if the file exists without opening it
|
||||
// it doesn't return anything hence why we expect it to
|
||||
|
Reference in New Issue
Block a user