logseq/e2e-tests/basic.spec.ts

261 lines
7.8 KiB
TypeScript
Raw Normal View History

2021-11-29 07:15:45 +00:00
import { expect } from '@playwright/test'
import fs from 'fs/promises'
import path from 'path'
import { test } from './fixtures'
2022-04-09 03:01:24 +00:00
import { randomString, createRandomPage } from './utils'
2021-11-23 06:30:01 +00:00
test('toggle sidebar', async ({ page }) => {
let sidebar = page.locator('#left-sidebar')
// Left sidebar is toggled by `is-open` class
if (/is-open/.test(await sidebar.getAttribute('class'))) {
await page.click('#left-menu.button')
await expect(sidebar).not.toHaveClass(/is-open/)
} else {
await page.click('#left-menu.button')
2022-03-31 06:11:42 +00:00
await page.waitForTimeout(10)
await expect(sidebar).toHaveClass(/is-open/)
await page.click('#left-menu.button')
2022-03-31 06:11:42 +00:00
await page.waitForTimeout(10)
await expect(sidebar).not.toHaveClass(/is-open/)
}
await page.click('#left-menu.button')
2022-03-31 06:11:42 +00:00
await page.waitForTimeout(10)
await expect(sidebar).toHaveClass(/is-open/)
await page.waitForSelector('#left-sidebar .left-sidebar-inner', { state: 'visible' })
await page.waitForSelector('#left-sidebar a:has-text("New page")', { state: 'visible' })
2021-11-23 06:30:01 +00:00
})
2021-11-29 07:15:45 +00:00
test('search', async ({ page }) => {
2021-11-23 06:30:01 +00:00
await page.click('#search-button')
await page.waitForSelector('[placeholder="Search or create page"]')
await page.fill('[placeholder="Search or create page"]', 'welcome')
await page.waitForTimeout(500)
const results = await page.$$('#ui__ac-inner .block')
expect(results.length).toBeGreaterThanOrEqual(1)
})
test('create page and blocks, save to disk', async ({ page, block, graphDir }) => {
const pageTitle = await createRandomPage(page)
2021-11-23 06:30:01 +00:00
// do editing
await block.mustFill('this is my first bullet')
await block.enterNext()
2022-03-31 06:11:42 +00:00
await block.waitForBlocks(2)
2021-11-23 06:30:01 +00:00
await block.mustFill('this is my second bullet')
await block.clickNext()
2021-11-23 06:30:01 +00:00
await block.mustFill('this is my third bullet')
await block.indent()
await block.enterNext()
2021-11-23 06:30:01 +00:00
await page.keyboard.type('continue editing test')
await page.keyboard.press('Shift+Enter')
await page.keyboard.type('continue')
await block.enterNext()
expect(await block.unindent()).toBe(true)
expect(await block.unindent()).toBe(false)
await block.mustFill('test ok')
2021-11-23 06:30:01 +00:00
await page.keyboard.press('Escape')
await block.waitForBlocks(5)
2021-11-23 06:30:01 +00:00
// active edit, and create next block
await block.clickNext()
await page.fill('textarea >> nth=0', 'test')
for (let i = 0; i < 5; i++) {
await page.keyboard.press('Backspace', { delay: 100 })
}
2021-11-23 06:30:01 +00:00
await page.keyboard.press('Escape')
await block.waitForBlocks(5)
await page.waitForTimeout(2000) // wait for saving to disk
2022-04-02 13:57:59 +00:00
const contentOnDisk = await fs.readFile(
path.join(graphDir, `pages/${pageTitle}.md`),
'utf8'
)
expect(contentOnDisk.trim()).toEqual(`
- this is my first bullet
- this is my second bullet
2022-04-02 13:57:59 +00:00
- this is my third bullet
- continue editing test
continue
- test ok`.trim())
2021-11-23 06:30:01 +00:00
})
2022-04-02 13:57:59 +00:00
test('delete and backspace', async ({ page, block }) => {
await createRandomPage(page)
2021-11-23 06:30:01 +00:00
await block.mustFill('test')
2021-11-23 06:30:01 +00:00
// backspace
await page.keyboard.press('Backspace')
await page.keyboard.press('Backspace')
expect(await page.inputValue('textarea >> nth=0')).toBe('te')
2021-11-23 06:30:01 +00:00
// refill
await block.enterNext()
await block.mustType('test')
await page.keyboard.press('ArrowLeft', { delay: 50 })
await page.keyboard.press('ArrowLeft', { delay: 50 })
2021-11-23 06:30:01 +00:00
// delete
await page.keyboard.press('Delete', { delay: 50 })
expect(await page.inputValue('textarea >> nth=0')).toBe('tet')
await page.keyboard.press('Delete', { delay: 50 })
expect(await page.inputValue('textarea >> nth=0')).toBe('te')
await page.keyboard.press('Delete', { delay: 50 })
expect(await page.inputValue('textarea >> nth=0')).toBe('te')
2021-11-23 06:30:01 +00:00
// TODO: test delete & backspace across blocks
})
test('selection', async ({ page, block }) => {
await createRandomPage(page)
// add 5 blocks
await block.mustFill('line 1')
await block.enterNext()
await block.mustFill('line 2')
await block.enterNext()
expect(await block.indent()).toBe(true)
await block.mustFill('line 3')
await block.enterNext()
await block.mustFill('line 4')
expect(await block.indent()).toBe(true)
await block.enterNext()
await block.mustFill('line 5')
// shift+up select 3 blocks
2021-11-23 06:30:01 +00:00
await page.keyboard.down('Shift')
await page.keyboard.press('ArrowUp')
await page.keyboard.press('ArrowUp')
await page.keyboard.press('ArrowUp')
await page.keyboard.up('Shift')
await block.waitForSelectedBlocks(3)
2021-11-23 06:30:01 +00:00
await page.keyboard.press('Backspace')
await block.waitForBlocks(2)
2021-11-23 06:30:01 +00:00
})
test('template', async ({ page, block }) => {
const randomTemplate = randomString(6)
2021-11-23 06:30:01 +00:00
await createRandomPage(page)
2021-11-23 06:30:01 +00:00
await block.mustFill('template test\ntemplate:: ' + randomTemplate)
await page.keyboard.press('Enter')
await block.clickNext()
2021-11-23 06:30:01 +00:00
expect(await block.indent()).toBe(true)
await block.mustFill('line1')
await block.enterNext()
await block.mustFill('line2')
await block.enterNext()
2021-11-23 06:30:01 +00:00
expect(await block.indent()).toBe(true)
await block.mustFill('line3')
await block.enterNext()
2021-11-23 06:30:01 +00:00
expect(await block.unindent()).toBe(true)
expect(await block.unindent()).toBe(true)
expect(await block.unindent()).toBe(false) // already at the first level
2021-11-23 06:30:01 +00:00
await block.waitForBlocks(5)
2021-11-23 06:30:01 +00:00
// NOTE: use delay to type slower, to trigger auto-completion UI.
await block.mustType('/template')
2021-11-23 06:30:01 +00:00
await page.click('[title="Insert a created template here"]')
// type to search template name
await page.keyboard.type(randomTemplate.substring(0, 3), { delay: 100 })
2021-11-23 06:30:01 +00:00
const popupMenuItem = page.locator('.absolute >> text=' + randomTemplate)
await popupMenuItem.waitFor({ timeout: 2000 }) // wait for template search
await popupMenuItem.click()
2021-11-23 06:30:01 +00:00
await block.waitForBlocks(8)
2021-11-23 06:30:01 +00:00
})
test('auto completion square brackets', async ({ page, block }) => {
await createRandomPage(page)
// In this test, `type` is unsed instead of `fill`, to allow for auto-completion.
// [[]]
await block.mustType('This is a [', { toBe: 'This is a []'})
await block.mustType('[', { toBe: 'This is a [[]]'})
// wait for search popup
await page.waitForSelector('text="Search for a page"')
// re-enter edit mode
await page.press('textarea >> nth=0', 'Escape')
await page.click('.ls-block >> nth=-1')
await page.waitForSelector('textarea >> nth=0', { state: 'visible' })
// #3253
await page.press('textarea >> nth=0', 'ArrowLeft')
await page.press('textarea >> nth=0', 'ArrowLeft')
await page.press('textarea >> nth=0', 'Enter')
await page.waitForSelector('text="Search for a page"', { state: 'visible' })
// type more `]`s
await page.type('textarea >> nth=0', ']')
expect(await page.inputValue('textarea >> nth=0')).toBe('This is a [[]]')
await page.type('textarea >> nth=0', ']')
expect(await page.inputValue('textarea >> nth=0')).toBe('This is a [[]]')
await page.type('textarea >> nth=0', ']')
expect(await page.inputValue('textarea >> nth=0')).toBe('This is a [[]]]')
})
test('auto completion and auto pair', async ({ page, block }) => {
await createRandomPage(page)
await block.mustFill('Auto-completion test')
await block.enterNext()
2021-12-17 20:13:12 +00:00
// {{
await block.mustType('type {{', { toBe: 'type {{}}'})
2021-12-17 20:13:12 +00:00
// ((
await block.clickNext()
await block.mustType('type (', { toBe: 'type ()'})
await block.mustType('(', { toBe: 'type (())'})
2021-12-17 20:13:12 +00:00
// [[ #3251
await block.clickNext()
2021-12-17 20:13:12 +00:00
await block.mustType('type [', { toBe: 'type []'})
await block.mustType('[', { toBe: 'type [[]]'})
2022-04-21 05:07:30 +00:00
await block.escapeEditing() // escape any popup from `[[]]`
2021-12-17 20:13:12 +00:00
// ``
await block.clickNext()
await block.mustType('type `', { toBe: 'type ``'})
await block.mustType('code here', { toBe: 'type `code here`'})
2021-11-23 06:30:01 +00:00
})
2022-01-19 01:25:04 +00:00
test('invalid page props #3944', async ({ page, block }) => {
2022-01-19 01:25:04 +00:00
await createRandomPage(page)
await block.mustFill('public:: true\nsize:: 65535')
await page.press('textarea >> nth=0', 'Enter')
2022-04-09 03:01:24 +00:00
// Force rendering property block
await block.clickNext()
2022-01-19 01:25:04 +00:00
})