fix(y-indexeddb): test cases (#2832)

This commit is contained in:
Alex Yang
2023-06-20 22:01:47 +08:00
committed by GitHub
parent 3755661ff6
commit 58fd3857c0
5 changed files with 88 additions and 59 deletions
+15 -5
View File
@@ -17,7 +17,13 @@ import { IndexeddbPersistence } from 'y-indexeddb';
const Y = Workspace.Y;
// eslint-disable-next-line @typescript-eslint/no-restricted-imports
import { createIndexedDBProvider } from '../src/index.js';
import { createIndexedDBProvider } from '../dist/index.js';
// @ts-expect-error
globalThis.window = {
addEventListener: () => void 0,
removeEventListener: () => void 0,
};
async function yjs_create_persistence(n = 1e3) {
for (let i = 0; i < n; i++) {
@@ -48,20 +54,24 @@ async function yjs_single_persistence(n = 1e5) {
async function toeverything_create_provider(n = 1e3) {
for (let i = 0; i < n; i++) {
const yDoc = new Y.Doc();
const provider = createIndexedDBProvider('test', yDoc);
const yDoc = new Y.Doc({
guid: 'test',
});
const provider = createIndexedDBProvider(yDoc);
provider.connect();
await provider.whenSynced;
provider.disconnect();
}
}
async function toeverything_single_persistence(n = 1e5) {
const yDoc = new Y.Doc();
const yDoc = new Y.Doc({
guid: 'test',
});
const map = yDoc.getMap();
for (let i = 0; i < n; i++) {
map.set(`${i}`, i);
}
const provider = createIndexedDBProvider('test', yDoc, 'test');
const provider = createIndexedDBProvider(yDoc, 'test');
provider.connect();
await provider.whenSynced;
provider.disconnect();
+2 -2
View File
@@ -36,8 +36,8 @@
"idb": "^7.1.1"
},
"devDependencies": {
"@blocksuite/blocks": "0.0.0-20230613142146-d72d4600-nightly",
"@blocksuite/store": "0.0.0-20230613142146-d72d4600-nightly",
"@blocksuite/blocks": "0.0.0-20230620110032-d8041266-nightly",
"@blocksuite/store": "0.0.0-20230620110032-d8041266-nightly",
"vite": "^4.3.9",
"vite-plugin-dts": "^2.3.0",
"y-indexeddb": "^9.0.11"
@@ -29,12 +29,12 @@ function initEmptyPage(page: Page) {
title: new page.Text(''),
});
const surfaceBlockId = page.addBlock('affine:surface', {}, pageBlockId);
const frameBLockId = page.addBlock('affine:frame', {}, pageBlockId);
const paragraphBlockId = page.addBlock('affine:paragraph', {}, frameBLockId);
const frameBlockId = page.addBlock('affine:note', {}, pageBlockId);
const paragraphBlockId = page.addBlock('affine:paragraph', {}, frameBlockId);
return {
pageBlockId,
surfaceBlockId,
frameBLockId,
frameBlockId,
paragraphBlockId,
};
}
@@ -91,7 +91,7 @@ describe('indexeddb provider', () => {
const page = workspace.createPage({ id: 'page0' });
await page.waitForLoaded();
const pageBlockId = page.addBlock('affine:page', { title: '' });
const frameId = page.addBlock('affine:frame', {}, pageBlockId);
const frameId = page.addBlock('affine:note', {}, pageBlockId);
page.addBlock('affine:paragraph', {}, frameId);
}
await new Promise(resolve => setTimeout(resolve, 1000));
@@ -110,8 +110,20 @@ describe('indexeddb provider', () => {
data.updates.forEach(({ update }) => {
Workspace.Y.applyUpdate(testWorkspace.doc, update);
});
const binary = Workspace.Y.encodeStateAsUpdate(testWorkspace.doc);
expect(binary).toEqual(Workspace.Y.encodeStateAsUpdate(workspace.doc));
const subPage = testWorkspace.doc.spaces.get('space:page0');
{
assertExists(subPage);
await store.get(subPage.guid);
const data = (await store.get(subPage.guid)) as
| WorkspacePersist
| undefined;
assertExists(data);
await testWorkspace.getPage('page0')?.waitForLoaded();
data.updates.forEach(({ update }) => {
Workspace.Y.applyUpdate(subPage, update);
});
}
expect(workspace.doc.toJSON()).toEqual(testWorkspace.doc.toJSON());
}
const secondWorkspace = new Workspace({
@@ -122,9 +134,10 @@ describe('indexeddb provider', () => {
const provider2 = createIndexedDBProvider(secondWorkspace.doc, rootDBName);
provider2.connect();
await provider2.whenSynced;
expect(Workspace.Y.encodeStateAsUpdate(secondWorkspace.doc)).toEqual(
Workspace.Y.encodeStateAsUpdate(workspace.doc)
);
const page = secondWorkspace.getPage('page0');
assertExists(page);
await page.waitForLoaded();
expect(workspace.doc.toJSON()).toEqual(secondWorkspace.doc.toJSON());
});
test('disconnect suddenly', async () => {
@@ -150,7 +163,7 @@ describe('indexeddb provider', () => {
const page = workspace.createPage({ id: 'page0' });
await page.waitForLoaded();
const pageBlockId = page.addBlock('affine:page', { title: '' });
const frameId = page.addBlock('affine:frame', {}, pageBlockId);
const frameId = page.addBlock('affine:note', {}, pageBlockId);
page.addBlock('affine:paragraph', {}, frameId);
}
{
@@ -218,7 +231,7 @@ describe('indexeddb provider', () => {
const page = workspace.createPage({ id: 'page0' });
await page.waitForLoaded();
const pageBlockId = page.addBlock('affine:page', { title: '' });
const frameId = page.addBlock('affine:frame', {}, pageBlockId);
const frameId = page.addBlock('affine:note', {}, pageBlockId);
for (let i = 0; i < 99; i++) {
page.addBlock('affine:paragraph', {}, frameId);
}
+8 -3
View File
@@ -12,9 +12,9 @@ import type {
BlockSuiteBinaryDB,
IndexedDBProvider,
WorkspaceMilestone,
} from './shared';
import { dbVersion, DEFAULT_DB_NAME, upgradeDB } from './shared';
import { tryMigrate } from './utils';
} from './shared.js';
import { dbVersion, DEFAULT_DB_NAME, upgradeDB } from './shared.js';
import { tryMigrate } from './utils.js';
const indexeddbOrigin = Symbol('indexeddb-provider-origin');
const snapshotOrigin = Symbol('snapshot-origin');
@@ -268,6 +268,10 @@ export const createIndexedDBProvider = (
doc.on('update', createOrGetHandleUpdate(id, doc));
doc.on('destroy', createOrGetHandleDestroy(id, doc));
doc.on('subdocs', createOrGetHandleSubDocs(id, doc));
doc.subdocs.forEach(doc => {
trackDoc(doc.guid, doc);
});
}
function unTrackDoc(id: string, doc: Doc) {
@@ -343,6 +347,7 @@ export const createIndexedDBProvider = (
});
connected = true;
trackDoc(doc.guid, doc);
// only the runs `await` below, otherwise the logic is incorrect
const db = await dbPromise;
if (migrate) {
+39 -38
View File
@@ -2730,17 +2730,17 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/blocks@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/blocks@npm:0.0.0-20230613142146-d72d4600-nightly"
"@blocksuite/blocks@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/blocks@npm:0.0.0-20230620110032-d8041266-nightly"
dependencies:
"@blocksuite/connector": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/global": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/phasor": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/virgo": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/connector": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/global": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/phasor": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/virgo": 0.0.0-20230620110032-d8041266-nightly
"@floating-ui/dom": ^1.2.9
hotkeys-js: ^3.10.1
html-to-image: ^1.11.11
html2canvas: ^1.4.1
jspdf: ^2.5.1
jszip: ^3.10.1
lit: ^2.7.3
@@ -2749,10 +2749,11 @@ __metadata:
turndown: ^7.1.1
zod: ^3.21.4
peerDependencies:
"@blocksuite/lit": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/store": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/block-std": 0.6.0
"@blocksuite/lit": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/store": 0.0.0-20230620110032-d8041266-nightly
yjs: ^13
checksum: 949d37335c16b6c6fd224a9ce6f0e356d500e139010706351a277f5ec69ebab309016267d8ecbb8d95adcae8d0edad2c99fb763f3caf158cf28d6bb12b8613d3
checksum: 3abf726c70ecb07f4db65d187633c68689d98eb057639ef41a5452306420f84a840e8066f90926392bc37a16fb118069193807ef7cf997779b029d1e1d0bc2b0
languageName: node
linkType: hard
@@ -2763,10 +2764,10 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/connector@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/connector@npm:0.0.0-20230613142146-d72d4600-nightly"
checksum: c5fcbae09c72cd61ecf8d4366c720edad7704f7737d0635e420fc0359ab9f4fe5a964581eee8e908ac1cab23abfba8bd770490bf674a594dc53624d6da775d5d
"@blocksuite/connector@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/connector@npm:0.0.0-20230620110032-d8041266-nightly"
checksum: 2e117c45659e009946ae00652e280b1fc9ea53a81aa9e0671efe12974bc2ada4965c3f8bb481b88c31833c8baa006df2c366bec44fa8e83a2f4392d83370e3cb
languageName: node
linkType: hard
@@ -2802,9 +2803,9 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/global@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/global@npm:0.0.0-20230613142146-d72d4600-nightly"
"@blocksuite/global@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/global@npm:0.0.0-20230620110032-d8041266-nightly"
dependencies:
ansi-colors: ^4.1.3
zod: ^3.21.4
@@ -2813,7 +2814,7 @@ __metadata:
peerDependenciesMeta:
lit:
optional: true
checksum: 45ccaa08c14787da8e3be8cbde9f01a34afea8874da6eaf7900961f953bbc0e7bab13866037d1504a1e983a8cc9e0735f5d9b1e074f6e400b27f7efae00292dd
checksum: 658a9f24fd0190a5d00575e5788f5e9bdafd4cf97e2fad2223fd77da4ad8b8b8adef9bac3ecaab574fce261cb0a722550534ce773aecf88a12c85cd69c58e13d
languageName: node
linkType: hard
@@ -2853,17 +2854,17 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/phasor@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/phasor@npm:0.0.0-20230613142146-d72d4600-nightly"
"@blocksuite/phasor@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/phasor@npm:0.0.0-20230620110032-d8041266-nightly"
dependencies:
"@blocksuite/global": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/global": 0.0.0-20230620110032-d8041266-nightly
fractional-indexing: ^3.2.0
roughjs: ^4.5.2
peerDependencies:
nanoid: ^4
yjs: ^13
checksum: 24dbb806ab928c4b37dcf94ea14fbd1f23dfcf63c42e42b378ca78baa51ec713556fc4a6553c5bf505d59309cd29079ffa8abb575a7c4f04cbef2202714f07c9
checksum: f96bb00209075d83225ea9c98821533d13e00d027a56e15ffc6cd483d8fb877401274ed4c9334439b17ddf9bf9f54926c896203e4ed5b2083bacb026a9b7c4ac
languageName: node
linkType: hard
@@ -2891,12 +2892,12 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/store@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/store@npm:0.0.0-20230613142146-d72d4600-nightly"
"@blocksuite/store@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/store@npm:0.0.0-20230620110032-d8041266-nightly"
dependencies:
"@blocksuite/global": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/virgo": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/global": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/virgo": 0.0.0-20230620110032-d8041266-nightly
"@types/flexsearch": ^0.7.3
buffer: ^6.0.3
flexsearch: 0.7.21
@@ -2911,7 +2912,7 @@ __metadata:
zod: ^3.21.4
peerDependencies:
yjs: ^13
checksum: 1e6673b4c90ceb73176c552528d174126c036b445cc81c649e4e2fb694b87adbe12dcc3675117a088f5aadbe0410e380601914d05e26334879e12135c0843b17
checksum: a33bebde8a9852f0961a9aacb14e44f9987474ab8e9038189ec1ff00a6bce6c0e1322d8976f3aa5995de656cc15cd5b2c51829493a051a905160d24fd2dce23b
languageName: node
linkType: hard
@@ -2928,16 +2929,16 @@ __metadata:
languageName: node
linkType: hard
"@blocksuite/virgo@npm:0.0.0-20230613142146-d72d4600-nightly":
version: 0.0.0-20230613142146-d72d4600-nightly
resolution: "@blocksuite/virgo@npm:0.0.0-20230613142146-d72d4600-nightly"
"@blocksuite/virgo@npm:0.0.0-20230620110032-d8041266-nightly":
version: 0.0.0-20230620110032-d8041266-nightly
resolution: "@blocksuite/virgo@npm:0.0.0-20230620110032-d8041266-nightly"
dependencies:
"@blocksuite/global": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/global": 0.0.0-20230620110032-d8041266-nightly
zod: ^3.21.4
peerDependencies:
lit: ^2.7
yjs: ^13
checksum: f3b5ee207b90d7f960eb10c37eb6866f06c0a2ad1e8e8bc46cc131ef2958f70a5b78d3dbafb7b19063b624acb898486a9b1f7fd7f83aa3f6253904b23f3eab47
checksum: b16b266dc51422077b0bb6f524608e5e631aef7f7453babd1d5ec4efbdf1c00b20fbd388e55a73da3e19f565605c5dcb8df892e3ff80eec52b145ca5e8353d06
languageName: node
linkType: hard
@@ -9784,8 +9785,8 @@ __metadata:
version: 0.0.0-use.local
resolution: "@toeverything/y-indexeddb@workspace:packages/y-indexeddb"
dependencies:
"@blocksuite/blocks": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/store": 0.0.0-20230613142146-d72d4600-nightly
"@blocksuite/blocks": 0.0.0-20230620110032-d8041266-nightly
"@blocksuite/store": 0.0.0-20230620110032-d8041266-nightly
idb: ^7.1.1
vite: ^4.3.9
vite-plugin-dts: ^2.3.0
@@ -18324,7 +18325,7 @@ __metadata:
languageName: node
linkType: hard
"html2canvas@npm:^1.0.0-rc.5":
"html2canvas@npm:^1.0.0-rc.5, html2canvas@npm:^1.4.1":
version: 1.4.1
resolution: "html2canvas@npm:1.4.1"
dependencies: