projects-close.spec.ts 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import { test, expect } from "../fixtures"
  2. import { createTestProject, seedProjects, 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, 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() ?? other
  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 menu = page.locator('[data-component="dropdown-menu-content"]').first()
  47. await expect(menu).toBeVisible({ timeout: 10_000 })
  48. await clickMenuItem(menu, /^Close$/i, { force: true })
  49. await expect(otherButton).toHaveCount(0)
  50. } finally {
  51. await cleanupTestProject(other)
  52. }
  53. })