summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authoradamelmore <[email protected]>2026-01-26 12:44:17 -0600
committeradamelmore <[email protected]>2026-01-26 12:51:35 -0600
commit8b17ac656cb428b1eee5f425deb195dc61f844ba (patch)
tree99867a37e70ca2b4b0cd7dcede4f821517eb55e1
parent18bfc740c839e9a6b931c7c5d0ed1a8bec98c904 (diff)
downloadopencode-8b17ac656cb428b1eee5f425deb195dc61f844ba.tar.gz
opencode-8b17ac656cb428b1eee5f425deb195dc61f844ba.zip
test(app): e2e test for sidebar nav
-rw-r--r--packages/app/e2e/sidebar-session-links.spec.ts61
1 files changed, 61 insertions, 0 deletions
diff --git a/packages/app/e2e/sidebar-session-links.spec.ts b/packages/app/e2e/sidebar-session-links.spec.ts
new file mode 100644
index 000000000..fab64736e
--- /dev/null
+++ b/packages/app/e2e/sidebar-session-links.spec.ts
@@ -0,0 +1,61 @@
+import { test, expect } from "./fixtures"
+import { modKey, promptSelector } from "./utils"
+
+type Locator = {
+ first: () => Locator
+ getAttribute: (name: string) => Promise<string | null>
+ scrollIntoViewIfNeeded: () => Promise<void>
+ click: () => Promise<void>
+}
+
+type Page = {
+ locator: (selector: string) => Locator
+ keyboard: {
+ press: (key: string) => Promise<void>
+ }
+}
+
+type Fixtures = {
+ page: Page
+ slug: string
+ sdk: {
+ session: {
+ create: (input: { title: string }) => Promise<{ data?: { id?: string } }>
+ delete: (input: { sessionID: string }) => Promise<unknown>
+ }
+ }
+ gotoSession: (sessionID?: string) => Promise<void>
+}
+
+test("sidebar session links navigate to the selected session", async ({ page, slug, sdk, gotoSession }: Fixtures) => {
+ const stamp = Date.now()
+
+ const one = await sdk.session.create({ title: `e2e sidebar nav 1 ${stamp}` }).then((r) => r.data)
+ const two = await sdk.session.create({ title: `e2e sidebar nav 2 ${stamp}` }).then((r) => r.data)
+
+ if (!one?.id) throw new Error("Session create did not return an id")
+ if (!two?.id) throw new Error("Session create did not return an id")
+
+ try {
+ await gotoSession(one.id)
+
+ const main = page.locator("main")
+ const collapsed = ((await main.getAttribute("class")) ?? "").includes("xl:border-l")
+ if (collapsed) {
+ await page.keyboard.press(`${modKey}+B`)
+ await expect(main).not.toHaveClass(/xl:border-l/)
+ }
+
+ const target = page.locator(`[data-session-id="${two.id}"] a`).first()
+ await expect(target).toBeVisible()
+ await target.scrollIntoViewIfNeeded()
+ await target.click()
+
+ await expect(page).toHaveURL(new RegExp(`/${slug}/session/${two.id}(?:\\?|#|$)`))
+ await expect(page.locator(promptSelector)).toBeVisible()
+ await expect(page.locator(`[data-session-id="${two.id}"] a`).first()).toHaveClass(/\bactive\b/)
+ } finally {
+ await sdk.session.delete({ sessionID: one.id }).catch(() => undefined)
+ await sdk.session.delete({ sessionID: two.id }).catch(() => undefined)
+ }
+})