57 lines
1.9 KiB
TypeScript
57 lines
1.9 KiB
TypeScript
import { test, expect } from "./fixtures"
|
|
import { modKey, promptSelector } from "./utils"
|
|
|
|
test("smoke providers settings opens provider selector", async ({ page, gotoSession }) => {
|
|
await gotoSession()
|
|
|
|
const dialog = page.getByRole("dialog")
|
|
|
|
await page.keyboard.press(`${modKey}+Comma`).catch(() => undefined)
|
|
|
|
const opened = await dialog
|
|
.waitFor({ state: "visible", timeout: 3000 })
|
|
.then(() => true)
|
|
.catch(() => false)
|
|
|
|
if (!opened) {
|
|
await page.getByRole("button", { name: "Settings" }).first().click()
|
|
await expect(dialog).toBeVisible()
|
|
}
|
|
|
|
await dialog.getByRole("tab", { name: "Providers" }).click()
|
|
await expect(dialog.getByText("Connected providers", { exact: true })).toBeVisible()
|
|
await expect(dialog.getByText("Popular providers", { exact: true })).toBeVisible()
|
|
|
|
await dialog.getByRole("button", { name: "Show more providers" }).click()
|
|
|
|
const providerDialog = page.getByRole("dialog").filter({ has: page.getByPlaceholder("Search providers") })
|
|
|
|
await expect(providerDialog).toBeVisible()
|
|
await expect(providerDialog.getByPlaceholder("Search providers")).toBeVisible()
|
|
await expect(providerDialog.locator('[data-slot="list-item"]').first()).toBeVisible()
|
|
|
|
await page.keyboard.press("Escape")
|
|
await expect(providerDialog).toHaveCount(0)
|
|
await expect(page.locator(promptSelector)).toBeVisible()
|
|
|
|
const stillOpen = await dialog.isVisible().catch(() => false)
|
|
if (!stillOpen) return
|
|
|
|
await page.keyboard.press("Escape")
|
|
const closed = await dialog
|
|
.waitFor({ state: "detached", timeout: 1500 })
|
|
.then(() => true)
|
|
.catch(() => false)
|
|
if (closed) return
|
|
|
|
await page.keyboard.press("Escape")
|
|
const closedSecond = await dialog
|
|
.waitFor({ state: "detached", timeout: 1500 })
|
|
.then(() => true)
|
|
.catch(() => false)
|
|
if (closedSecond) return
|
|
|
|
await page.locator('[data-component="dialog-overlay"]').click({ position: { x: 5, y: 5 } })
|
|
await expect(dialog).toHaveCount(0)
|
|
})
|