mirror of
https://github.com/toeverything/AFFiNE.git
synced 2025-01-09 02:06:59 +03:00
27af9b4d1a
![image.png](https://graphite-user-uploaded-assets-prod.s3.amazonaws.com/T2klNLEk0wxLh4NRDzhk/cd2e982a-f78a-4cc3-b090-ee4c0090e19d.png) Above image shows the performance on querying a 20k rows of updates table, which is super slow at 150+ms. After adding index for doc_id the performance should be greatly improved. After: ![image.png](https://graphite-user-uploaded-assets-prod.s3.amazonaws.com/T2klNLEk0wxLh4NRDzhk/45ea4389-1833-4dc5-bd64-84d8c99cd647.png) fix TOV-866
57 lines
1.5 KiB
TypeScript
57 lines
1.5 KiB
TypeScript
import path from 'node:path';
|
|
|
|
import { removeWithRetry } from '@affine-test/kit/utils/utils';
|
|
import fs from 'fs-extra';
|
|
import { v4 } from 'uuid';
|
|
import { afterAll, afterEach, beforeAll, expect, test, vi } from 'vitest';
|
|
|
|
const tmpDir = path.join(__dirname, 'tmp');
|
|
const appDataPath = path.join(tmpDir, 'app-data');
|
|
|
|
beforeAll(() => {
|
|
vi.doMock('@affine/electron/helper/main-rpc', () => ({
|
|
mainRPC: {
|
|
getPath: async () => appDataPath,
|
|
},
|
|
}));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await removeWithRetry(tmpDir);
|
|
});
|
|
|
|
afterAll(() => {
|
|
vi.doUnmock('@affine/electron/helper/main-rpc');
|
|
});
|
|
|
|
test('can create new db file if not exists', async () => {
|
|
const { openWorkspaceDatabase } = await import(
|
|
'@affine/electron/helper/db/workspace-db-adapter'
|
|
);
|
|
const workspaceId = v4();
|
|
const db = await openWorkspaceDatabase(workspaceId);
|
|
const dbPath = path.join(
|
|
appDataPath,
|
|
`workspaces/${workspaceId}`,
|
|
`storage.db`
|
|
);
|
|
expect(await fs.exists(dbPath)).toBe(true);
|
|
await db.destroy();
|
|
});
|
|
|
|
test('on destroy, check if resources have been released', async () => {
|
|
const { openWorkspaceDatabase } = await import(
|
|
'@affine/electron/helper/db/workspace-db-adapter'
|
|
);
|
|
const workspaceId = v4();
|
|
const db = await openWorkspaceDatabase(workspaceId);
|
|
const updateSub = {
|
|
complete: vi.fn(),
|
|
next: vi.fn(),
|
|
};
|
|
db.update$ = updateSub as any;
|
|
await db.destroy();
|
|
expect(db.adapter.db).toBe(null);
|
|
expect(updateSub.complete).toHaveBeenCalled();
|
|
});
|