| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- import { test, expect } from "../fixtures"
- import { createTestProject, seedProjects, cleanupTestProject, openSidebar } from "../actions"
- import { projectCloseHoverSelector, projectCloseMenuSelector, projectSwitchSelector } from "../selectors"
- import { dirSlug } from "../utils"
- test("can close a project via hover card close button", async ({ page, directory, gotoSession }) => {
- await page.setViewportSize({ width: 1400, height: 800 })
- const other = await createTestProject()
- const otherSlug = dirSlug(other)
- await seedProjects(page, { directory, extra: [other] })
- try {
- await gotoSession()
- await openSidebar(page)
- const otherButton = page.locator(projectSwitchSelector(otherSlug)).first()
- await expect(otherButton).toBeVisible()
- await otherButton.hover()
- const close = page.locator(projectCloseHoverSelector(otherSlug)).first()
- await expect(close).toBeVisible()
- await close.click()
- await expect(otherButton).toHaveCount(0)
- } finally {
- await cleanupTestProject(other)
- }
- })
- test("can close a project via project header more options menu", async ({ page, directory, gotoSession }) => {
- await page.setViewportSize({ width: 1400, height: 800 })
- const other = await createTestProject()
- const otherName = other.split("/").pop()
- const otherSlug = dirSlug(other)
- await seedProjects(page, { directory, extra: [other] })
- try {
- await gotoSession()
- await openSidebar(page)
- const otherButton = page.locator(projectSwitchSelector(otherSlug)).first()
- await expect(otherButton).toBeVisible()
- await otherButton.click()
- await expect(page).toHaveURL(new RegExp(`/${otherSlug}/session`))
- const header = page
- .locator(".group\\/project")
- .filter({ has: page.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`) })
- .first()
- await expect(header).toContainText(otherName)
- const trigger = header.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`).first()
- await expect(trigger).toHaveCount(1)
- await trigger.focus()
- await page.keyboard.press("Enter")
- const close = page
- .locator(projectCloseMenuSelector(otherSlug))
- .or(page.getByRole("menuitem", { name: "Close" }))
- .or(
- page
- .locator('[data-component="dropdown-menu-content"] [data-slot="dropdown-menu-item"]')
- .filter({ hasText: "Close" }),
- )
- .first()
- await expect(close).toBeVisible({ timeout: 10_000 })
- await close.click({ force: true })
- await expect(otherButton).toHaveCount(0)
- } finally {
- await cleanupTestProject(other)
- }
- })
|