Преглед на файлове

enhance(ui): polish details for the page title

charlie преди 1 година
родител
ревизия
c48c4c7ffc
променени са 1 файла, в които са добавени 95 реда и са изтрити 4 реда
  1. 95 4
      e2e-tests/logseq-api.spec.ts

+ 95 - 4
e2e-tests/logseq-api.spec.ts

@@ -8,6 +8,7 @@ async function createDBGraph(page: Page) {
   await page.click('text="Create db graph"')
   await page.waitForSelector('.new-graph')
   const name = `e2e-db-${Date.now()}`
+  await page.waitForTimeout(100)
   await page.keyboard.type(name)
   await page.locator('.new-graph > .ui__button').click()
   return name
@@ -20,11 +21,8 @@ test.skip('test db graph', async ({ page }) => {
   await page.pause()
 })
 
-test('block related apis',
+test('(File graph): block related apis',
   async ({ page }) => {
-    const name = await createDBGraph(page)
-    await page.waitForSelector(`a[title="logseq_db_${name}"]`)
-
     const callAPI = callPageAPI.bind(null, page)
 
     const bPageName = 'block-test-page'
@@ -113,6 +111,99 @@ test('block related apis',
     // await page.pause()
   })
 
+test('(DB graph): block related apis',
+  async ({ page }) => {
+    const name = await createDBGraph(page)
+    await page.waitForSelector(`a[title="logseq_db_${name}"]`)
+
+    const callAPI = callPageAPI.bind(null, page)
+
+    const bPageName = 'block-test-page'
+    await callAPI('create_page', bPageName, null, { createFirstBlock: false })
+    await callAPI('create_page', bPageName, null, { createFirstBlock: false })
+    await page.waitForSelector(`body[data-page="${bPageName}"]`)
+
+    let p = await callAPI('get_current_page')
+    const bp = await callAPI('append_block_in_page', bPageName, 'tests')
+
+    expect(p.name).toBe(bPageName)
+
+    p = await callAPI('get_page', bPageName)
+
+    expect(p.name).toBe(bPageName)
+
+    await callAPI('edit_block', bp.uuid)
+
+    const b = (await callAPI('get_current_block'))
+    expect(Object.keys(b)).toContain('uuid')
+
+    await page.waitForSelector('.block-editor > textarea')
+    await page.locator('.block-editor > textarea').fill('')
+    const content = 'test api'
+    await page.type('.block-editor > textarea', content)
+
+    const editingContent = await callAPI('get_editing_block_content')
+    expect(editingContent).toBe(content)
+
+    // create
+    let b1 = await callAPI('insert_block', b.uuid, content)
+    b1 = await callAPI('get_block', b1.uuid)
+
+    expect(b1.parent.id).toBe(b.id)
+
+    // update
+    const content1 = content + '+ update!'
+    await callAPI('update_block', b1.uuid, content1)
+    b1 = await callAPI('get_block', b1.uuid)
+
+    expect(b1.content).toBe(content1)
+
+    // remove
+    await callAPI('remove_block', b1.uuid)
+    b1 = await callAPI('get_block', b1.uuid)
+
+    expect(b1).toBeNull()
+
+    // traverse
+    b1 = await callAPI('insert_block', b.uuid, content1, { sibling: true })
+    const nb = await callAPI('get_next_sibling_block', b.uuid)
+    const pb = await callAPI('get_previous_sibling_block', b1.uuid)
+
+    expect(nb.uuid).toBe(b1.uuid)
+    expect(pb.uuid).toBe(b.uuid)
+
+    // move
+    await callAPI('move_block', b.uuid, b1.uuid)
+    const mb = await callAPI('get_next_sibling_block', b1.uuid)
+
+    expect(mb.uuid).toBe(b.uuid)
+
+    // properties
+    await callAPI('upsert_block_property', b1.uuid, 'a', 'a')
+    let prop1 = await callAPI('get_block_property', b1.uuid, 'a')
+
+    expect(prop1.title).toBe('a')
+
+    await callAPI('upsert_block_property', b1.uuid, 'a', 'b')
+    prop1 = await callAPI('get_block_property', b1.uuid, 'a')
+
+    expect(prop1.title).toBe('b')
+
+    await callAPI('remove_block_property', b1.uuid, 'a')
+    prop1 = await callAPI('get_block_property', b1.uuid, 'a')
+
+    expect(prop1).toBeNull()
+
+    await callAPI('upsert_block_property', b1.uuid, 'a', 'a')
+    await callAPI('upsert_block_property', b1.uuid, 'b', 'b')
+
+    prop1 = await callAPI('get_block_properties', b1.uuid)
+
+    expect(prop1).toEqual({ ':plugin.property/a': 'a', ':plugin.property/b': 'b' })
+
+    // await page.pause()
+  })
+
 /**
  * load local tests plugin
  */