editor.spec.ts 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. import { expect } from '@playwright/test'
  2. import { test } from './fixtures'
  3. import { createRandomPage, enterNextBlock } from './utils'
  4. import { dispatch_kb_events } from './util/keyboard-events'
  5. import * as kb_events from './util/keyboard-events'
  6. test(
  7. "Press CJK Left Black Lenticular Bracket `【` by 2 times #3251 should trigger [[]], " +
  8. "but dont trigger RIME #3440 ",
  9. // cases should trigger [[]] #3251
  10. async ({ page, block }) => {
  11. for (let [idx, events] of [
  12. kb_events.win10_pinyin_left_full_square_bracket,
  13. kb_events.macos_pinyin_left_full_square_bracket
  14. // TODO: support #3741
  15. // kb_events.win10_legacy_pinyin_left_full_square_bracket,
  16. ].entries()) {
  17. await createRandomPage(page)
  18. let check_text = "#3251 test " + idx
  19. await block.mustFill(check_text + "【")
  20. await dispatch_kb_events(page, ':nth-match(textarea, 1)', events)
  21. expect(await page.inputValue(':nth-match(textarea, 1)')).toBe(check_text + '【')
  22. await block.mustFill(check_text + "【【")
  23. await dispatch_kb_events(page, ':nth-match(textarea, 1)', events)
  24. expect(await page.inputValue(':nth-match(textarea, 1)')).toBe(check_text + '[[]]')
  25. };
  26. // dont trigger RIME #3440
  27. for (let [idx, events] of [
  28. kb_events.macos_pinyin_selecting_candidate_double_left_square_bracket,
  29. kb_events.win10_RIME_selecting_candidate_double_left_square_bracket
  30. ].entries()) {
  31. await createRandomPage(page)
  32. let check_text = "#3440 test " + idx
  33. await block.mustFill(check_text)
  34. await dispatch_kb_events(page, ':nth-match(textarea, 1)', events)
  35. expect(await page.inputValue(':nth-match(textarea, 1)')).toBe(check_text)
  36. await dispatch_kb_events(page, ':nth-match(textarea, 1)', events)
  37. expect(await page.inputValue(':nth-match(textarea, 1)')).toBe(check_text)
  38. }
  39. })
  40. test('hashtag and quare brackets in same line #4178', async ({ page }) => {
  41. await createRandomPage(page)
  42. await page.type('textarea >> nth=0', '#foo bar')
  43. await enterNextBlock(page)
  44. await page.type('textarea >> nth=0', 'bar [[blah]]', { delay: 100 })
  45. for (let i = 0; i < 12; i++) {
  46. await page.press('textarea >> nth=0', 'ArrowLeft')
  47. }
  48. await page.type('textarea >> nth=0', ' ')
  49. await page.press('textarea >> nth=0', 'ArrowLeft')
  50. await page.type('textarea >> nth=0', '#')
  51. await page.waitForSelector('text="Search for a page"', { state: 'visible' })
  52. await page.type('textarea >> nth=0', 'fo')
  53. await page.click('.absolute >> text=' + 'foo')
  54. expect(await page.inputValue('textarea >> nth=0')).toBe(
  55. '#foo bar [[blah]]'
  56. )
  57. })
  58. test('disappeared children #4814', async ({ page, block }) => {
  59. await createRandomPage(page)
  60. await block.mustType('parent')
  61. await block.enterNext()
  62. expect(await block.indent()).toBe(true)
  63. for (let i = 0; i < 5; i++) {
  64. await block.mustType(i.toString())
  65. await block.enterNext()
  66. }
  67. // collapse
  68. await page.click('.block-control >> nth=0')
  69. // expand
  70. await page.click('.block-control >> nth=0')
  71. await block.waitForBlocks(7) // 1 + 5 + 1 empty
  72. // Ensures there's no active editor
  73. await expect(page.locator('.editor-inner')).toHaveCount(0, { timeout: 500 })
  74. })
  75. test.skip('backspace and cursor position #4897', async ({ page, block }) => {
  76. await createRandomPage(page)
  77. // Delete to previous block, and check cursor postion, with markup
  78. await block.mustFill('`012345`')
  79. await block.enterNext()
  80. await block.mustType('`abcdef', { toBe: '`abcdef`' }) // "`" auto-completes
  81. expect(await block.selectionStart()).toBe(7)
  82. expect(await block.selectionEnd()).toBe(7)
  83. for (let i = 0; i < 7; i++) {
  84. await page.keyboard.press('ArrowLeft')
  85. }
  86. expect(await block.selectionStart()).toBe(0)
  87. await page.keyboard.press('Backspace')
  88. await block.waitForBlocks(1) // wait for delete and re-render
  89. expect(await block.selectionStart()).toBe(8)
  90. })
  91. test.skip('next block and cursor position', async ({ page, block }) => {
  92. await createRandomPage(page)
  93. // Press Enter and check cursor postion, with markup
  94. await block.mustType('abcde`12345', { toBe: 'abcde`12345`' }) // "`" auto-completes
  95. for (let i = 0; i < 7; i++) {
  96. await page.keyboard.press('ArrowLeft')
  97. }
  98. expect(await block.selectionStart()).toBe(5) // after letter 'e'
  99. await block.enterNext()
  100. expect(await block.selectionStart()).toBe(0) // should at the beginning of the next block
  101. const locator = page.locator('textarea >> nth=0')
  102. await expect(locator).toHaveText('`12345`', { timeout: 1000 })
  103. })
  104. // FIXME: ClipboardItem is not defined when running with this test
  105. // test('copy & paste block ref and replace its content', async ({ page }) => {
  106. // await createRandomPage(page)
  107. // await page.type('textarea >> nth=0', 'Some random text')
  108. // if (IsMac) {
  109. // await page.keyboard.press('Meta+c')
  110. // } else {
  111. // await page.keyboard.press('Control+c')
  112. // }
  113. // await page.pause()
  114. // await page.press('textarea >> nth=0', 'Enter')
  115. // if (IsMac) {
  116. // await page.keyboard.press('Meta+v')
  117. // } else {
  118. // await page.keyboard.press('Control+v')
  119. // }
  120. // await page.keyboard.press('Escape')
  121. // const blockRef$ = page.locator('.block-ref >> text="Some random text"');
  122. // // Check if the newly created block-ref has the same referenced content
  123. // await expect(blockRef$).toHaveCount(1);
  124. // // Edit the last block
  125. // await blockRef$.press('Enter')
  126. // // Move cursor into the block ref
  127. // for (let i = 0; i < 4; i++) {
  128. // await page.press('textarea >> nth=0', 'ArrowLeft')
  129. // }
  130. // // Trigger replace-block-reference-with-content-at-point
  131. // if (IsMac) {
  132. // await page.keyboard.press('Meta+Shift+r')
  133. // } else {
  134. // await page.keyboard.press('Control+Shift+v')
  135. // }
  136. // })