sidebar.spec.ts 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import { expect } from '@playwright/test'
  2. import { test } from './fixtures'
  3. import { createRandomPage, openLeftSidebar, searchAndJumpToPage } from './utils'
  4. /***
  5. * Test side bar features
  6. ***/
  7. test('favorite item and recent item test', async ({ page }) => {
  8. await openLeftSidebar(page)
  9. // add page to fav
  10. const fav_page_name = await createRandomPage(page)
  11. let favs = await page.$$('.favorite-item a')
  12. let previous_fav_count = favs.length
  13. await page.click('.ui__dropdown-trigger')
  14. await page.click(':nth-match(.ui__dropdown-trigger .dropdown-wrapper a, 1)')
  15. // click from another page
  16. const another_page_name = await createRandomPage(page)
  17. expect(await page.innerText(':nth-match(.favorite-item a, 1)')).toBe('◦' + fav_page_name)
  18. await page.click(":nth-match(.favorite-item, 1)")
  19. expect(await page.innerText('.page-title .title')).toBe(fav_page_name)
  20. expect(await page.innerText(':nth-match(.recent-item a, 1)')).toBe('◦' + fav_page_name)
  21. expect(await page.innerText(':nth-match(.recent-item a, 2)')).toBe('◦' + another_page_name)
  22. // remove fav
  23. await page.click('.ui__dropdown-trigger')
  24. await page.click(':nth-match(.ui__dropdown-trigger .dropdown-wrapper a, 1)')
  25. await page.waitForTimeout(1000)
  26. favs = await page.$$('.favorite-item a')
  27. expect(favs.length).toEqual(previous_fav_count)
  28. // click from fav page
  29. await page.click(':nth-match(.recent-item a, 2)')
  30. expect(await page.innerText('.page-title .title')).toBe(another_page_name)
  31. })
  32. test('recent is updated #4320', async ({ page }) => {
  33. const page1 = await createRandomPage(page)
  34. await page.fill('textarea >> nth=0', 'Random Thought')
  35. const page2 = await createRandomPage(page)
  36. await page.fill('textarea >> nth=0', 'Another Random Thought')
  37. const firstRecent = page.locator('.nav-content-item.recent li >> nth=0')
  38. expect(await firstRecent.textContent()).toContain(page2)
  39. const secondRecent = page.locator('.nav-content-item.recent li >> nth=1')
  40. expect(await secondRecent.textContent()).toContain(page1)
  41. // then jump back
  42. await searchAndJumpToPage(page, page1)
  43. expect(await firstRecent.textContent()).toContain(page1)
  44. expect(await secondRecent.textContent()).toContain(page2)
  45. })