projects-close.spec.ts 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import { test, expect } from "../fixtures"
  2. import { createTestProject, cleanupTestProject, openSidebar, clickMenuItem } 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, withProject }) => {
  6. await page.setViewportSize({ width: 1400, height: 800 })
  7. const other = await createTestProject()
  8. const otherSlug = dirSlug(other)
  9. try {
  10. await withProject(
  11. async () => {
  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. },
  21. { extra: [other] },
  22. )
  23. } finally {
  24. await cleanupTestProject(other)
  25. }
  26. })
  27. test("can close a project via project header more options menu", async ({ page, withProject }) => {
  28. await page.setViewportSize({ width: 1400, height: 800 })
  29. const other = await createTestProject()
  30. const otherName = other.split("/").pop() ?? other
  31. const otherSlug = dirSlug(other)
  32. try {
  33. await withProject(
  34. async () => {
  35. await openSidebar(page)
  36. const otherButton = page.locator(projectSwitchSelector(otherSlug)).first()
  37. await expect(otherButton).toBeVisible()
  38. await otherButton.click()
  39. await expect(page).toHaveURL(new RegExp(`/${otherSlug}/session`))
  40. const header = page
  41. .locator(".group\\/project")
  42. .filter({ has: page.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`) })
  43. .first()
  44. await expect(header).toContainText(otherName)
  45. const trigger = header.locator(`[data-action="project-menu"][data-project="${otherSlug}"]`).first()
  46. await expect(trigger).toHaveCount(1)
  47. await trigger.focus()
  48. await page.keyboard.press("Enter")
  49. const menu = page.locator('[data-component="dropdown-menu-content"]').first()
  50. await expect(menu).toBeVisible({ timeout: 10_000 })
  51. await clickMenuItem(menu, /^Close$/i, { force: true })
  52. await expect(otherButton).toHaveCount(0)
  53. },
  54. { extra: [other] },
  55. )
  56. } finally {
  57. await cleanupTestProject(other)
  58. }
  59. })