projects-close.spec.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. import { test, expect } from "../fixtures"
  2. import { createTestProject, seedProjects, cleanupTestProject, openSidebar } from "../actions"
  3. import { projectCloseHoverSelector, projectCloseMenuSelector, projectSwitchSelector } from "../selectors"
  4. import { dirSlug } from "../utils"
  5. test("can close a project via hover card close button", async ({ page, directory, gotoSession }) => {
  6. await page.setViewportSize({ width: 1400, height: 800 })
  7. const other = await createTestProject()
  8. const otherSlug = dirSlug(other)
  9. await seedProjects(page, { directory, extra: [other] })
  10. try {
  11. await gotoSession()
  12. await openSidebar(page)
  13. const otherButton = page.locator(projectSwitchSelector(otherSlug)).first()
  14. await expect(otherButton).toBeVisible()
  15. await otherButton.hover()
  16. const close = page.locator(projectCloseHoverSelector(otherSlug)).first()
  17. await expect(close).toBeVisible()
  18. await close.click()
  19. await expect(otherButton).toHaveCount(0)
  20. } finally {
  21. await cleanupTestProject(other)
  22. }
  23. })
  24. test("can close a project via project header more options menu", async ({ page, directory, gotoSession }) => {
  25. await page.setViewportSize({ width: 1400, height: 800 })
  26. const other = await createTestProject()
  27. const otherName = other.split("/").pop()
  28. const otherSlug = dirSlug(other)
  29. await seedProjects(page, { directory, extra: [other] })
  30. try {
  31. await gotoSession()
  32. await openSidebar(page)
  33. const otherButton = page.locator(projectSwitchSelector(otherSlug)).first()
  34. await expect(otherButton).toBeVisible()
  35. await otherButton.click()
  36. await expect(page).toHaveURL(new RegExp(`/${otherSlug}/session`))
  37. const header = page
  38. .locator(".group\\/project")
  39. .filter({ has: page.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`) })
  40. .first()
  41. await expect(header).toContainText(otherName)
  42. const trigger = header.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`).first()
  43. await expect(trigger).toHaveCount(1)
  44. await trigger.focus()
  45. await page.keyboard.press("Enter")
  46. const close = page
  47. .locator(projectCloseMenuSelector(otherSlug))
  48. .or(page.getByRole("menuitem", { name: "Close" }))
  49. .or(
  50. page
  51. .locator('[data-component="dropdown-menu-content"] [data-slot="dropdown-menu-item"]')
  52. .filter({ hasText: "Close" }),
  53. )
  54. .first()
  55. await expect(close).toBeVisible({ timeout: 10_000 })
  56. await close.click({ force: true })
  57. await expect(otherButton).toHaveCount(0)
  58. } finally {
  59. await cleanupTestProject(other)
  60. }
  61. })