2026-01-04 19:46:37 +09:00
|
|
|
import { expect, test } from "@playwright/test"
|
|
|
|
|
|
|
|
|
|
test.describe("Settings", () => {
|
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
|
|
|
await page.goto("/", { waitUntil: "networkidle" })
|
|
|
|
|
await page
|
|
|
|
|
.locator("iframe")
|
|
|
|
|
.waitFor({ state: "visible", timeout: 30000 })
|
|
|
|
|
})
|
|
|
|
|
|
2026-01-04 19:58:48 +09:00
|
|
|
test("settings dialog opens", async ({ page }) => {
|
2026-01-04 19:46:37 +09:00
|
|
|
const settingsButton = page.locator(
|
|
|
|
|
'button[aria-label*="settings"], button:has(svg[class*="settings"])',
|
|
|
|
|
)
|
2026-01-04 19:58:48 +09:00
|
|
|
await expect(settingsButton).toBeVisible()
|
2026-01-04 19:46:37 +09:00
|
|
|
await settingsButton.click()
|
|
|
|
|
|
|
|
|
|
const dialog = page.locator('[role="dialog"]')
|
|
|
|
|
await expect(dialog).toBeVisible({ timeout: 5000 })
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
test("language selection is available", async ({ page }) => {
|
|
|
|
|
const settingsButton = page.locator(
|
|
|
|
|
'button[aria-label*="settings"], button:has(svg[class*="settings"])',
|
|
|
|
|
)
|
|
|
|
|
await settingsButton.click()
|
|
|
|
|
|
|
|
|
|
const dialog = page.locator('[role="dialog"]')
|
|
|
|
|
await expect(dialog).toBeVisible({ timeout: 5000 })
|
|
|
|
|
|
2026-01-04 19:58:48 +09:00
|
|
|
// Should have language selector showing English
|
2026-01-04 19:46:37 +09:00
|
|
|
await expect(dialog.locator('text="English"')).toBeVisible()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
test("draw.io theme toggle exists", async ({ page }) => {
|
|
|
|
|
const settingsButton = page.locator(
|
|
|
|
|
'button[aria-label*="settings"], button:has(svg[class*="settings"])',
|
|
|
|
|
)
|
|
|
|
|
await settingsButton.click()
|
|
|
|
|
|
|
|
|
|
const dialog = page.locator('[role="dialog"]')
|
|
|
|
|
await expect(dialog).toBeVisible({ timeout: 5000 })
|
|
|
|
|
|
2026-01-04 19:58:48 +09:00
|
|
|
// Should have draw.io theme option (sketch or minimal)
|
2026-01-04 19:46:37 +09:00
|
|
|
const themeText = dialog.locator("text=/sketch|minimal/i")
|
|
|
|
|
await expect(themeText.first()).toBeVisible()
|
|
|
|
|
})
|
|
|
|
|
})
|