page-rename.spec.ts 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. import { expect, Page } from '@playwright/test'
  2. import { test } from './fixtures'
  3. import { IsMac, createPage, randomLowerString, newBlock, newInnerBlock, randomString, lastBlock } from './utils'
  4. /***
  5. * Test rename feature
  6. ***/
  7. async function rename_page(page: Page, new_name: string) {
  8. let selectAll = 'Control+a'
  9. if (IsMac) {
  10. selectAll = 'Meta+a'
  11. }
  12. await page.click('.ls-page-title .page-title')
  13. await page.waitForSelector('input[type="text"]')
  14. await page.keyboard.press(selectAll)
  15. await page.keyboard.press('Backspace')
  16. await page.type('.title input', new_name)
  17. await page.keyboard.press('Enter')
  18. await page.click('.ui__confirm-modal button')
  19. }
  20. async function page_rename_test(page: Page, original_page_name: string, new_page_name: string) {
  21. const rand = randomString(10)
  22. let original_name = original_page_name + rand
  23. let new_name = new_page_name + rand
  24. await createPage(page, original_name)
  25. // Rename page in UI
  26. await rename_page(page, new_name)
  27. expect(await page.innerText('.page-title .title')).toBe(new_name)
  28. // TODO: Test if page is renamed in re-entrance
  29. // TODO: Test if page is hierarchy
  30. }
  31. async function homepage_rename_test(page: Page, original_page_name: string, new_page_name: string) {
  32. const rand = randomString(10)
  33. let original_name = original_page_name + rand
  34. let new_name = new_page_name + rand
  35. await createPage(page, original_name)
  36. // Toggle settings
  37. await page.click('#main-content-container')
  38. await page.keyboard.press('t')
  39. await page.keyboard.press('s')
  40. await page.click('a[data-id="features"]')
  41. await page.click('#settings div:nth-child(1) a')
  42. await page.type('input', original_name)
  43. await page.click('[aria-label="Close"]')
  44. expect(await page.locator('.home-nav span.flex-1').innerText()).toBe(original_name);
  45. await rename_page(page, new_name)
  46. expect(await page.locator('.home-nav span.flex-1').innerText()).toBe(new_name);
  47. // Reenable journal
  48. await page.click('#main-content-container')
  49. await page.keyboard.press('t')
  50. await page.keyboard.press('s')
  51. await page.click('a[data-id="features"]')
  52. await page.click('#settings div:nth-child(1) a')
  53. await page.click('[aria-label="Close"]')
  54. }
  55. test('page rename test', async ({ page }) => {
  56. await homepage_rename_test(page, "abcd", "a/b/c/d")
  57. await page_rename_test(page, "abcd", "a.b.c.d")
  58. await page_rename_test(page, "abcd", "a/b/c/d")
  59. })
  60. // TODO introduce more samples when #4722 is fixed
  61. test('page title property test', async ({ page }) => {
  62. // Edit Title Property and Double Enter (ETPDE)
  63. // exit editing via insert new block
  64. let rand = randomLowerString(10)
  65. let original_name = "etpde old" + rand
  66. let new_name = "etpde new" + rand
  67. await createPage(page, original_name)
  68. // add some spaces to test if it is trimmed
  69. await page.type(':nth-match(textarea, 1)', 'title:: ' + new_name + " ")
  70. await page.press(':nth-match(textarea, 1)', 'Enter') // DWIM property mode creates new line
  71. await page.press(':nth-match(textarea, 1)', 'Enter')
  72. expect(await page.innerText('.page-title .title')).toBe(new_name)
  73. // Edit Title Property and Esc (ETPE)
  74. // exit editing via moving out focus
  75. rand = randomLowerString(10)
  76. original_name = "etpe old " + rand
  77. new_name = "etpe new " + rand
  78. await createPage(page, original_name)
  79. await page.type(':nth-match(textarea, 1)', 'title:: ' + new_name)
  80. await page.press(':nth-match(textarea, 1)', 'Escape')
  81. expect(await page.innerText('.page-title .title')).toBe(new_name)
  82. })