123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 |
- import { expect, Page } from '@playwright/test'
- import { test } from './fixtures'
- import { Block } from './types'
- import { IsMac, createRandomPage, newBlock, newInnerBlock, randomString, lastBlock, enterNextBlock } from './utils'
- /***
- * Test alias features
- * Test search refering features
- * Consider diacritics
- ***/
- let hotkeyOpenLink = 'Control+o'
- let hotkeyBack = 'Control+['
- if (IsMac) {
- hotkeyOpenLink = 'Meta+o'
- hotkeyBack = 'Meta+['
- }
- test('Search page and blocks (diacritics)', async ({ page, block }) => {
- const rand = randomString(20)
- // diacritic opening test
- await createRandomPage(page)
- await block.mustType('[[Einführung in die Allgemeine Sprachwissenschaft' + rand + ']] diacritic-block-1', { delay: 10 })
- await page.keyboard.press(hotkeyOpenLink)
- const pageTitle = page.locator('.page-title').first()
- expect(await pageTitle.innerText()).toEqual('Einführung in die Allgemeine Sprachwissenschaft' + rand)
- await page.waitForTimeout(500)
- // build target Page with diacritics
- await block.activeEditing(0)
- await block.mustType('Diacritic title test content', { delay: 10 })
- await block.enterNext()
- await block.mustType('[[Einführung in die Allgemeine Sprachwissenschaft' + rand + ']] diacritic-block-2', { delay: 10 })
- await page.keyboard.press(hotkeyBack)
- // check if diacritics are indexed
- await page.click('#search-button')
- await page.waitForSelector('[placeholder="Search or create page"]')
- await page.type('[placeholder="Search or create page"]', 'Einführung in die Allgemeine Sprachwissenschaft' + rand, { delay: 10 })
- await page.waitForTimeout(2000) // wait longer for search contents to render
- // 2 blocks + 1 page + 1 page content
- const searchResults = page.locator('#ui__ac-inner>div')
- await expect(searchResults).toHaveCount(5) // 1 page + 2 block + 2 page content
- await page.keyboard.press("Escape") // escape search box typing
- await page.waitForTimeout(500)
- await page.keyboard.press("Escape") // escape modal
- })
- test('Search CJK', async ({ page, block }) => {
- const rand = randomString(20)
- // diacritic opening test
- await createRandomPage(page)
- await block.mustType('[[今日daytime进度条' + rand + ']] diacritic-block-1', { delay: 10 })
- await page.keyboard.press(hotkeyOpenLink)
- const pageTitle = page.locator('.page-title').first()
- expect(await pageTitle.innerText()).toEqual('今日daytime进度条' + rand)
- await page.waitForTimeout(500)
- // check if diacritics are indexed
- await page.click('#search-button')
- await page.waitForSelector('[placeholder="Search or create page"]')
- await page.type('[placeholder="Search or create page"]', '进度', { delay: 10 })
- await page.waitForTimeout(2000) // wait longer for search contents to render
- // 2 blocks + 1 page + 1 page content
- const searchResults = page.locator('#ui__ac-inner>div')
- await expect(searchResults).toHaveCount(4) // 1 new page + 1 page + 1 block + 1 page content
- await page.keyboard.press("Escape") // escape search box typing
- await page.waitForTimeout(500)
- await page.keyboard.press("Escape") // escape modal
- })
- async function alias_test( block: Block, page: Page, page_name: string, search_kws: string[] ) {
- await createRandomPage(page)
- const rand = randomString(10)
- let target_name = page_name + ' target ' + rand
- let alias_name = page_name + ' alias ' + rand
- let alias_test_content_1 = randomString(20)
- let alias_test_content_2 = randomString(20)
- let alias_test_content_3 = randomString(20)
- await page.type('textarea >> nth=0', '[[' + target_name)
- await page.keyboard.press(hotkeyOpenLink)
- await lastBlock(page)
- // build target Page with alias
- // the target page will contains the content in
- // alias_test_content_1,
- // alias_test_content_2, and
- // alias_test_content_3 sequentialy, to validate the target page state
- await page.type('textarea >> nth=0', 'alias:: [[' + alias_name, {delay: 10})
- await page.keyboard.press('Enter', {delay: 200}) // Enter for finishing selection
- await page.keyboard.press('Enter', {delay: 200}) // double Enter for exit property editing
- await page.keyboard.press('Enter', {delay: 200}) // double Enter for exit property editing
- await page.waitForTimeout(200)
- await block.activeEditing(1)
- await page.type('textarea >> nth=0', alias_test_content_1)
- await lastBlock(page)
- page.keyboard.press(hotkeyBack)
- await page.waitForNavigation()
- await block.escapeEditing()
- // create alias ref in origin Page
- await block.activeEditing(0)
- await block.enterNext()
- await page.type('textarea >> nth=0', '[[' + alias_name, {delay: 20})
- await page.keyboard.press('Enter') // Enter for finishing selection
- await page.waitForTimeout(100)
- page.keyboard.press(hotkeyOpenLink)
- await page.waitForNavigation()
- await block.escapeEditing()
- // shortcut opening test
- await block.activeEditing(1)
- expect(await page.inputValue('textarea >> nth=0')).toBe(alias_test_content_1)
- await enterNextBlock(page)
- await page.type('textarea >> nth=0', alias_test_content_2)
- page.keyboard.press(hotkeyBack)
- await page.waitForNavigation()
- await block.escapeEditing()
- // pressing enter on alias opening test
- await block.activeEditing(1)
- await page.press('textarea >> nth=0', 'ArrowLeft')
- await page.press('textarea >> nth=0', 'ArrowLeft')
- await page.press('textarea >> nth=0', 'ArrowLeft')
- page.press('textarea >> nth=0', 'Enter')
- await page.waitForNavigation()
- await block.escapeEditing()
- await block.activeEditing(2)
- expect(await page.inputValue('textarea >> nth=0')).toBe(alias_test_content_2)
- await newInnerBlock(page)
- await page.type('textarea >> nth=0', alias_test_content_3)
- page.keyboard.press(hotkeyBack)
-
- await page.waitForNavigation()
- await block.escapeEditing()
- // clicking alias ref opening test
- await block.activeEditing(1)
- await block.enterNext()
- await page.waitForSelector('.page-blocks-inner .ls-block .page-ref >> nth=-1')
- await page.click('.page-blocks-inner .ls-block .page-ref >> nth=-1')
- await lastBlock(page)
- expect(await page.inputValue('textarea >> nth=0')).toBe(alias_test_content_3)
- // TODO: test alias from graph clicking
- // test alias from search
- for (let kw of search_kws) {
- let kw_name = kw + ' alias ' + rand
- await page.click('#search-button')
- await page.waitForSelector('[placeholder="Search or create page"]')
- await page.type('[placeholder="Search or create page"]', kw_name)
- await page.waitForTimeout(500)
- const results = await page.$$('#ui__ac-inner>div')
- expect(results.length).toEqual(5) // page + block + alias property + page content
- // test search results
- expect(await results[0].innerText()).toContain("Alias -> " + target_name)
- expect(await results[0].innerText()).toContain(alias_name)
- expect(await results[1].innerText()).toContain("[[" + alias_name + "]]")
- expect(await results[2].innerText()).toContain("[[" + alias_name + "]]")
- // test search entering (page)
- page.keyboard.press("Enter")
- await page.waitForNavigation()
- await page.waitForSelector('.ls-block span.inline')
- expect(await page.locator('.ls-block span.inline >> nth=2').innerHTML()).toBe(alias_test_content_3)
- // test search clicking (block)
- await page.click('#search-button')
- await page.waitForSelector('[placeholder="Search or create page"]')
- await page.type('[placeholder="Search or create page"]', kw_name)
- await page.waitForTimeout(500)
- page.click(":nth-match(.search-result, 3)")
- await page.waitForNavigation()
- await page.waitForSelector('.selected a.page-ref')
- expect(await page.locator('.selected a.page-ref').innerHTML()).toBe(alias_name)
- await page.keyboard.press(hotkeyBack)
- }
- // TODO: search clicking (alias property)
- }
- test('page diacritic alias', async ({ block, page }) => {
- await alias_test(block, page, "ü", ["ü", "ü", "Ü"])
- })
|