@yanit/jsondb 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +903 -0
- package/dist/bin/cli-export.d.ts +7 -0
- package/dist/bin/cli-export.d.ts.map +1 -0
- package/dist/bin/cli-export.js +318 -0
- package/dist/bin/cli-export.js.map +1 -0
- package/dist/bin/cli-import.d.ts +7 -0
- package/dist/bin/cli-import.d.ts.map +1 -0
- package/dist/bin/cli-import.js +298 -0
- package/dist/bin/cli-import.js.map +1 -0
- package/dist/bin/server.d.ts +7 -0
- package/dist/bin/server.d.ts.map +1 -0
- package/dist/bin/server.js +92 -0
- package/dist/bin/server.js.map +1 -0
- package/dist/examples/sql-example.d.ts +7 -0
- package/dist/examples/sql-example.d.ts.map +1 -0
- package/dist/examples/sql-example.js +131 -0
- package/dist/examples/sql-example.js.map +1 -0
- package/dist/src/BulkOp.d.ts +74 -0
- package/dist/src/BulkOp.d.ts.map +1 -0
- package/dist/src/BulkOp.js +143 -0
- package/dist/src/BulkOp.js.map +1 -0
- package/dist/src/Collection.d.ts +232 -0
- package/dist/src/Collection.d.ts.map +1 -0
- package/dist/src/Collection.js +705 -0
- package/dist/src/Collection.js.map +1 -0
- package/dist/src/Cursor.d.ts +94 -0
- package/dist/src/Cursor.d.ts.map +1 -0
- package/dist/src/Cursor.js +259 -0
- package/dist/src/Cursor.js.map +1 -0
- package/dist/src/Database.d.ts +98 -0
- package/dist/src/Database.d.ts.map +1 -0
- package/dist/src/Database.js +198 -0
- package/dist/src/Database.js.map +1 -0
- package/dist/src/Operators.d.ts +73 -0
- package/dist/src/Operators.d.ts.map +1 -0
- package/dist/src/Operators.js +339 -0
- package/dist/src/Operators.js.map +1 -0
- package/dist/src/QueryCache.d.ts +87 -0
- package/dist/src/QueryCache.d.ts.map +1 -0
- package/dist/src/QueryCache.js +155 -0
- package/dist/src/QueryCache.js.map +1 -0
- package/dist/src/SQLExecutor.d.ts +60 -0
- package/dist/src/SQLExecutor.d.ts.map +1 -0
- package/dist/src/SQLExecutor.js +317 -0
- package/dist/src/SQLExecutor.js.map +1 -0
- package/dist/src/SQLParser.d.ts +181 -0
- package/dist/src/SQLParser.d.ts.map +1 -0
- package/dist/src/SQLParser.js +640 -0
- package/dist/src/SQLParser.js.map +1 -0
- package/dist/src/Schema.d.ts +92 -0
- package/dist/src/Schema.d.ts.map +1 -0
- package/dist/src/Schema.js +253 -0
- package/dist/src/Schema.js.map +1 -0
- package/dist/src/Transaction.d.ts +118 -0
- package/dist/src/Transaction.d.ts.map +1 -0
- package/dist/src/Transaction.js +233 -0
- package/dist/src/Transaction.js.map +1 -0
- package/dist/src/Utils.d.ts +68 -0
- package/dist/src/Utils.d.ts.map +1 -0
- package/dist/src/Utils.js +187 -0
- package/dist/src/Utils.js.map +1 -0
- package/dist/src/errors.d.ts +58 -0
- package/dist/src/errors.d.ts.map +1 -0
- package/dist/src/errors.js +85 -0
- package/dist/src/errors.js.map +1 -0
- package/dist/src/index.d.ts +39 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +44 -0
- package/dist/src/index.js.map +1 -0
- package/dist/test/basic.test.d.ts +5 -0
- package/dist/test/basic.test.d.ts.map +1 -0
- package/dist/test/basic.test.js +283 -0
- package/dist/test/basic.test.js.map +1 -0
- package/dist/test/index.test.d.ts +5 -0
- package/dist/test/index.test.d.ts.map +1 -0
- package/dist/test/index.test.js +126 -0
- package/dist/test/index.test.js.map +1 -0
- package/dist/test/jsonb.test.d.ts +5 -0
- package/dist/test/jsonb.test.d.ts.map +1 -0
- package/dist/test/jsonb.test.js +165 -0
- package/dist/test/jsonb.test.js.map +1 -0
- package/dist/test/optimization.test.d.ts +6 -0
- package/dist/test/optimization.test.d.ts.map +1 -0
- package/dist/test/optimization.test.js +196 -0
- package/dist/test/optimization.test.js.map +1 -0
- package/dist/test/schema.test.d.ts +5 -0
- package/dist/test/schema.test.d.ts.map +1 -0
- package/dist/test/schema.test.js +197 -0
- package/dist/test/schema.test.js.map +1 -0
- package/dist/test/sql.test.d.ts +7 -0
- package/dist/test/sql.test.d.ts.map +1 -0
- package/dist/test/sql.test.js +21 -0
- package/dist/test/sql.test.js.map +1 -0
- package/package.json +73 -0
- package/src/BulkOp.js +181 -0
- package/src/BulkOp.ts +191 -0
- package/src/Collection.js +843 -0
- package/src/Collection.ts +896 -0
- package/src/Cursor.js +315 -0
- package/src/Cursor.ts +319 -0
- package/src/Database.js +244 -0
- package/src/Database.ts +268 -0
- package/src/Operators.js +382 -0
- package/src/Operators.ts +375 -0
- package/src/QueryCache.js +190 -0
- package/src/QueryCache.ts +208 -0
- package/src/SQLExecutor.ts +391 -0
- package/src/SQLParser.ts +814 -0
- package/src/Schema.js +292 -0
- package/src/Schema.ts +317 -0
- package/src/Transaction.js +291 -0
- package/src/Transaction.ts +313 -0
- package/src/Utils.js +205 -0
- package/src/Utils.ts +205 -0
- package/src/errors.js +93 -0
- package/src/errors.ts +93 -0
- package/src/index.js +90 -0
- package/src/index.ts +106 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* JSONB 功能测试
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
5
|
+
import { Database } from '../src/index.js';
|
|
6
|
+
import { rmSync, existsSync, readFileSync } from 'fs';
|
|
7
|
+
import { join } from 'path';
|
|
8
|
+
const TEST_JSONB_PATH = join(process.cwd(), 'test-data', 'test-jsonb-db');
|
|
9
|
+
const TEST_NORMAL_PATH = join(process.cwd(), 'test-data', 'test-normal-db');
|
|
10
|
+
describe('JSONB Mode', () => {
|
|
11
|
+
let jsonbDb;
|
|
12
|
+
let normalDb;
|
|
13
|
+
beforeAll(async () => {
|
|
14
|
+
// 清理测试数据
|
|
15
|
+
if (existsSync(TEST_JSONB_PATH)) {
|
|
16
|
+
rmSync(TEST_JSONB_PATH, { recursive: true, force: true });
|
|
17
|
+
}
|
|
18
|
+
if (existsSync(TEST_NORMAL_PATH)) {
|
|
19
|
+
rmSync(TEST_NORMAL_PATH, { recursive: true, force: true });
|
|
20
|
+
}
|
|
21
|
+
// 创建 JSONB 模式数据库
|
|
22
|
+
jsonbDb = new Database(TEST_JSONB_PATH, { jsonb: true });
|
|
23
|
+
await jsonbDb.open();
|
|
24
|
+
// 创建普通模式数据库
|
|
25
|
+
normalDb = new Database(TEST_NORMAL_PATH, { jsonb: false });
|
|
26
|
+
await normalDb.open();
|
|
27
|
+
});
|
|
28
|
+
afterAll(async () => {
|
|
29
|
+
await jsonbDb.close();
|
|
30
|
+
await normalDb.close();
|
|
31
|
+
if (existsSync(TEST_JSONB_PATH)) {
|
|
32
|
+
rmSync(TEST_JSONB_PATH, { recursive: true, force: true });
|
|
33
|
+
}
|
|
34
|
+
if (existsSync(TEST_NORMAL_PATH)) {
|
|
35
|
+
rmSync(TEST_NORMAL_PATH, { recursive: true, force: true });
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
it('应该创建 JSONB 模式的集合', async () => {
|
|
39
|
+
const users = jsonbDb.collection('users');
|
|
40
|
+
expect(users.jsonb).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
it('应该创建普通模式的集合', async () => {
|
|
43
|
+
const users = normalDb.collection('users');
|
|
44
|
+
expect(users.jsonb).toBe(false);
|
|
45
|
+
});
|
|
46
|
+
it('应该在 JSONB 模式下插入文档', async () => {
|
|
47
|
+
const users = jsonbDb.collection('users');
|
|
48
|
+
const user = await users.insertOne({
|
|
49
|
+
name: 'Alice',
|
|
50
|
+
age: 25,
|
|
51
|
+
data: { nested: { value: 'test' } }
|
|
52
|
+
});
|
|
53
|
+
expect(user).toHaveProperty('_id');
|
|
54
|
+
expect(user.name).toBe('Alice');
|
|
55
|
+
});
|
|
56
|
+
it('应该在普通模式下插入文档', async () => {
|
|
57
|
+
const users = normalDb.collection('users');
|
|
58
|
+
const user = await users.insertOne({
|
|
59
|
+
name: 'Bob',
|
|
60
|
+
age: 30,
|
|
61
|
+
data: { nested: { value: 'test' } }
|
|
62
|
+
});
|
|
63
|
+
expect(user).toHaveProperty('_id');
|
|
64
|
+
expect(user.name).toBe('Bob');
|
|
65
|
+
});
|
|
66
|
+
it('JSONB 模式文件应该是二进制格式', async () => {
|
|
67
|
+
const content = readFileSync(join(TEST_JSONB_PATH, 'users.json'));
|
|
68
|
+
// JSONB 模式下,文件应该是二进制格式
|
|
69
|
+
// 前 4 字节是长度前缀 (uint32 BE)
|
|
70
|
+
expect(content.length).toBeGreaterThan(4);
|
|
71
|
+
// 验证长度前缀
|
|
72
|
+
const length = content.readUInt32BE(0);
|
|
73
|
+
expect(length).toBe(content.length - 4);
|
|
74
|
+
// 解码验证数据
|
|
75
|
+
const jsonBuffer = content.subarray(4);
|
|
76
|
+
const json = jsonBuffer.toString('utf-8');
|
|
77
|
+
const data = JSON.parse(json);
|
|
78
|
+
expect(data._documents).toHaveLength(1);
|
|
79
|
+
});
|
|
80
|
+
it('普通模式文件应该是文本 JSON', async () => {
|
|
81
|
+
const content = readFileSync(join(TEST_NORMAL_PATH, 'users.json'), 'utf-8');
|
|
82
|
+
// 普通模式下,内容应该是格式化的 JSON 文本
|
|
83
|
+
expect(content).toContain('\n');
|
|
84
|
+
expect(content).toContain(' '); // 有缩进
|
|
85
|
+
});
|
|
86
|
+
it('应该在 JSONB 模式下查询文档', async () => {
|
|
87
|
+
const users = jsonbDb.collection('users');
|
|
88
|
+
const allUsers = await users.find().toArray();
|
|
89
|
+
expect(allUsers).toHaveLength(1);
|
|
90
|
+
expect(allUsers[0].name).toBe('Alice');
|
|
91
|
+
const found = await users.findOne({ name: 'Alice' });
|
|
92
|
+
expect(found).toBeDefined();
|
|
93
|
+
expect(found.data).toBeDefined();
|
|
94
|
+
});
|
|
95
|
+
it('应该在普通模式下查询文档', async () => {
|
|
96
|
+
const users = normalDb.collection('users');
|
|
97
|
+
const allUsers = await users.find().toArray();
|
|
98
|
+
expect(allUsers).toHaveLength(1);
|
|
99
|
+
expect(allUsers[0].name).toBe('Bob');
|
|
100
|
+
const found = await users.findOne({ name: 'Bob' });
|
|
101
|
+
expect(found).toBeDefined();
|
|
102
|
+
expect(found.data).toBeDefined();
|
|
103
|
+
});
|
|
104
|
+
it('应该在 JSONB 模式下更新文档', async () => {
|
|
105
|
+
const users = jsonbDb.collection('users');
|
|
106
|
+
await users.updateOne({ name: 'Alice' }, { $set: { age: 26 } });
|
|
107
|
+
const updated = await users.findOne({ name: 'Alice' });
|
|
108
|
+
expect(updated.age).toBe(26);
|
|
109
|
+
});
|
|
110
|
+
it('应该在 JSONB 模式下使用聚合', async () => {
|
|
111
|
+
const users = jsonbDb.collection('users');
|
|
112
|
+
await users.insertMany([
|
|
113
|
+
{ name: 'Charlie', age: 35 },
|
|
114
|
+
{ name: 'David', age: 28 }
|
|
115
|
+
]);
|
|
116
|
+
const stats = await users.aggregate([
|
|
117
|
+
{ $group: { _id: null, avgAge: { $avg: '$age' } } }
|
|
118
|
+
]);
|
|
119
|
+
expect(stats[0].avgAge).toBe(29.666666666666668); // (26 + 35 + 28) / 3
|
|
120
|
+
});
|
|
121
|
+
it('应该比较 JSONB 和普通模式的空间效率', async () => {
|
|
122
|
+
const jsonbStats = await jsonbDb.collection('users').stats();
|
|
123
|
+
const normalStats = await normalDb.collection('users').stats();
|
|
124
|
+
// JSONB 模式使用二进制存储(带长度前缀)
|
|
125
|
+
expect(jsonbStats.jsonb).toBe(true);
|
|
126
|
+
expect(normalStats.jsonb).toBe(false);
|
|
127
|
+
// JSONB 模式是二进制格式,没有格式化和空格
|
|
128
|
+
// 但有 4 字节的长度前缀
|
|
129
|
+
// 对于大数据集,JSONB 更节省空间
|
|
130
|
+
console.log('JSONB size:', jsonbStats.size, 'Normal size:', normalStats.size);
|
|
131
|
+
console.log('JSONB 是二进制格式,普通模式是格式化 JSON');
|
|
132
|
+
});
|
|
133
|
+
it('应该支持 JSONB 模式的并发操作', async () => {
|
|
134
|
+
const tasks = jsonbDb.collection('tasks');
|
|
135
|
+
await Promise.all([
|
|
136
|
+
tasks.insertOne({ name: 'Task 1', status: 'pending' }),
|
|
137
|
+
tasks.insertOne({ name: 'Task 2', status: 'pending' }),
|
|
138
|
+
tasks.insertOne({ name: 'Task 3', status: 'pending' })
|
|
139
|
+
]);
|
|
140
|
+
const count = await tasks.countDocuments();
|
|
141
|
+
expect(count).toBe(3);
|
|
142
|
+
await Promise.all([
|
|
143
|
+
tasks.updateOne({ name: 'Task 1' }, { $set: { status: 'completed' } }),
|
|
144
|
+
tasks.updateOne({ name: 'Task 2' }, { $set: { status: 'in-progress' } }),
|
|
145
|
+
tasks.updateOne({ name: 'Task 3' }, { $set: { status: 'pending' } })
|
|
146
|
+
]);
|
|
147
|
+
const completed = await tasks.countDocuments({ status: 'completed' });
|
|
148
|
+
expect(completed).toBe(1);
|
|
149
|
+
});
|
|
150
|
+
it('应该支持 JSONB 模式的索引操作', async () => {
|
|
151
|
+
const books = jsonbDb.collection('books');
|
|
152
|
+
await books.insertMany([
|
|
153
|
+
{ title: 'Book 1', author: 'Author A', year: 2020 },
|
|
154
|
+
{ title: 'Book 2', author: 'Author B', year: 2021 }
|
|
155
|
+
]);
|
|
156
|
+
const index = await books.createIndex({ author: 1 });
|
|
157
|
+
expect(index.name).toBe('author_1');
|
|
158
|
+
const indexes = await books.listIndexes();
|
|
159
|
+
expect(indexes).toHaveLength(1);
|
|
160
|
+
await books.dropIndex('author_1');
|
|
161
|
+
const indexesAfterDrop = await books.listIndexes();
|
|
162
|
+
expect(indexesAfterDrop).toHaveLength(0);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
//# sourceMappingURL=jsonb.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonb.test.js","sourceRoot":"","sources":["../../test/jsonb.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimization.test.d.ts","sourceRoot":"","sources":["../../test/optimization.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 优化功能测试
|
|
3
|
+
* 测试批量操作、查询缓存、事务功能
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
6
|
+
import { Database, createBulkOp, createTransaction, withTransaction, QueryCache } from '../src/index.js';
|
|
7
|
+
import { rmSync, existsSync } from 'fs';
|
|
8
|
+
import { join } from 'path';
|
|
9
|
+
const TEST_DB_PATH = join(process.cwd(), 'test-data', 'test-optimization-db');
|
|
10
|
+
describe('BulkOperation 批量操作', () => {
|
|
11
|
+
let db;
|
|
12
|
+
let users;
|
|
13
|
+
beforeAll(async () => {
|
|
14
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
15
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
16
|
+
}
|
|
17
|
+
db = new Database(TEST_DB_PATH);
|
|
18
|
+
await db.open();
|
|
19
|
+
users = db.collection('users');
|
|
20
|
+
});
|
|
21
|
+
afterAll(async () => {
|
|
22
|
+
await db.close();
|
|
23
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
24
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
it('应该支持批量插入', async () => {
|
|
28
|
+
const bulkOp = createBulkOp(users);
|
|
29
|
+
const result = await bulkOp
|
|
30
|
+
.insert([
|
|
31
|
+
{ name: 'User 1', age: 20 },
|
|
32
|
+
{ name: 'User 2', age: 25 },
|
|
33
|
+
{ name: 'User 3', age: 30 }
|
|
34
|
+
])
|
|
35
|
+
.execute();
|
|
36
|
+
expect(result.insertedCount).toBe(3);
|
|
37
|
+
expect(result.insertedIds).toHaveLength(3);
|
|
38
|
+
});
|
|
39
|
+
it('应该支持批量更新', async () => {
|
|
40
|
+
const bulkOp = createBulkOp(users);
|
|
41
|
+
const result = await bulkOp
|
|
42
|
+
.update({ age: { $gte: 25 } }, { $set: { status: 'active' } })
|
|
43
|
+
.execute();
|
|
44
|
+
expect(result.updatedCount).toBeGreaterThanOrEqual(2);
|
|
45
|
+
});
|
|
46
|
+
it('应该支持批量删除', async () => {
|
|
47
|
+
const bulkOp = createBulkOp(users);
|
|
48
|
+
const result = await bulkOp
|
|
49
|
+
.delete({ age: { $lt: 25 } })
|
|
50
|
+
.execute();
|
|
51
|
+
expect(result.deletedCount).toBeGreaterThanOrEqual(1);
|
|
52
|
+
});
|
|
53
|
+
it('应该支持链式批量操作', async () => {
|
|
54
|
+
const bulkOp = createBulkOp(users);
|
|
55
|
+
const result = await bulkOp
|
|
56
|
+
.insert([{ name: 'User 4', age: 35 }])
|
|
57
|
+
.update({ name: 'User 4' }, { $set: { age: 36 } })
|
|
58
|
+
.execute();
|
|
59
|
+
expect(result.insertedCount).toBe(1);
|
|
60
|
+
expect(result.updatedCount).toBe(1);
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
describe('QueryCache 查询缓存', () => {
|
|
64
|
+
let cache;
|
|
65
|
+
beforeAll(() => {
|
|
66
|
+
cache = new QueryCache({ maxSize: 100, ttl: 5000 });
|
|
67
|
+
});
|
|
68
|
+
it('应该能设置和获取缓存', () => {
|
|
69
|
+
const key = cache.generateKey('users', { age: 25 });
|
|
70
|
+
cache.set(key, [{ name: 'Alice' }]);
|
|
71
|
+
const result = cache.get(key);
|
|
72
|
+
expect(result).toEqual([{ name: 'Alice' }]);
|
|
73
|
+
});
|
|
74
|
+
it('应该能生成不同的缓存键', () => {
|
|
75
|
+
const key1 = cache.generateKey('users', { age: 25 });
|
|
76
|
+
const key2 = cache.generateKey('users', { age: 30 });
|
|
77
|
+
const key3 = cache.generateKey('users', { age: 25 }, { limit: 10 });
|
|
78
|
+
expect(key1).not.toBe(key2);
|
|
79
|
+
expect(key1).not.toBe(key3);
|
|
80
|
+
});
|
|
81
|
+
it('应该能获取缓存统计', () => {
|
|
82
|
+
const stats = cache.getStats();
|
|
83
|
+
expect(stats).toHaveProperty('size');
|
|
84
|
+
expect(stats).toHaveProperty('hitRate');
|
|
85
|
+
});
|
|
86
|
+
it('应该能清空缓存', () => {
|
|
87
|
+
cache.clear();
|
|
88
|
+
const stats = cache.getStats();
|
|
89
|
+
expect(stats.size).toBe(0);
|
|
90
|
+
expect(stats.hits).toBe(0);
|
|
91
|
+
});
|
|
92
|
+
it('应该支持缓存过期', async () => {
|
|
93
|
+
const shortTtlCache = new QueryCache({ ttl: 100 });
|
|
94
|
+
const key = shortTtlCache.generateKey('test', { id: 1 });
|
|
95
|
+
shortTtlCache.set(key, { data: 'test' });
|
|
96
|
+
expect(shortTtlCache.get(key)).toEqual({ data: 'test' });
|
|
97
|
+
// 等待过期
|
|
98
|
+
await new Promise(resolve => setTimeout(resolve, 150));
|
|
99
|
+
expect(shortTtlCache.get(key)).toBeNull();
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
describe('Transaction 事务', () => {
|
|
103
|
+
let db;
|
|
104
|
+
let users;
|
|
105
|
+
let orders;
|
|
106
|
+
beforeAll(async () => {
|
|
107
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
108
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
109
|
+
}
|
|
110
|
+
db = new Database(TEST_DB_PATH);
|
|
111
|
+
await db.open();
|
|
112
|
+
users = db.collection('users');
|
|
113
|
+
orders = db.collection('orders');
|
|
114
|
+
});
|
|
115
|
+
afterAll(async () => {
|
|
116
|
+
await db.close();
|
|
117
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
118
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
it('应该支持事务提交', async () => {
|
|
122
|
+
const tx = createTransaction([users, orders]);
|
|
123
|
+
const result = await tx
|
|
124
|
+
.insert(users, { name: 'Tx User 1', email: 'tx1@test.com' })
|
|
125
|
+
.insert(orders, { userId: 1, amount: 100 })
|
|
126
|
+
.commit();
|
|
127
|
+
expect(result.success).toBe(true);
|
|
128
|
+
});
|
|
129
|
+
it('应该支持事务回滚', async () => {
|
|
130
|
+
const tx = createTransaction([users]);
|
|
131
|
+
await tx
|
|
132
|
+
.insert(users, { name: 'Tx User 2', email: 'tx2@test.com' })
|
|
133
|
+
.commit();
|
|
134
|
+
// 验证已提交
|
|
135
|
+
const count = await users.countDocuments({ email: 'tx2@test.com' });
|
|
136
|
+
expect(count).toBe(1);
|
|
137
|
+
});
|
|
138
|
+
it('应该支持 withTransaction 快捷方式', async () => {
|
|
139
|
+
const result = await withTransaction([orders], async (tx) => {
|
|
140
|
+
tx.insert(orders, { userId: 2, amount: 200 });
|
|
141
|
+
tx.insert(orders, { userId: 3, amount: 300 });
|
|
142
|
+
});
|
|
143
|
+
expect(result.success).toBe(true);
|
|
144
|
+
});
|
|
145
|
+
it('应该能获取事务状态', () => {
|
|
146
|
+
const tx = createTransaction([users]);
|
|
147
|
+
expect(tx.getStatus()).toBe('active');
|
|
148
|
+
});
|
|
149
|
+
it('应该支持多集合事务', async () => {
|
|
150
|
+
const initialUserCount = await users.countDocuments();
|
|
151
|
+
const initialOrderCount = await orders.countDocuments();
|
|
152
|
+
const tx = createTransaction([users, orders]);
|
|
153
|
+
await tx
|
|
154
|
+
.insert(users, { name: 'Multi User', email: 'multi@test.com' })
|
|
155
|
+
.insert(orders, { userId: 999, amount: 999 })
|
|
156
|
+
.commit();
|
|
157
|
+
expect(await users.countDocuments()).toBe(initialUserCount + 1);
|
|
158
|
+
expect(await orders.countDocuments()).toBe(initialOrderCount + 1);
|
|
159
|
+
});
|
|
160
|
+
});
|
|
161
|
+
describe('性能对比', () => {
|
|
162
|
+
let db;
|
|
163
|
+
let perfUsers;
|
|
164
|
+
beforeAll(async () => {
|
|
165
|
+
db = new Database(TEST_DB_PATH + '-perf');
|
|
166
|
+
await db.open();
|
|
167
|
+
perfUsers = db.collection('perfUsers');
|
|
168
|
+
});
|
|
169
|
+
afterAll(async () => {
|
|
170
|
+
await db.close();
|
|
171
|
+
if (existsSync(TEST_DB_PATH + '-perf')) {
|
|
172
|
+
rmSync(TEST_DB_PATH + '-perf', { recursive: true, force: true });
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
it('批量插入应该比单条插入快', async () => {
|
|
176
|
+
const count = 100;
|
|
177
|
+
// 单条插入
|
|
178
|
+
const singleStart = Date.now();
|
|
179
|
+
for (let i = 0; i < count; i++) {
|
|
180
|
+
await perfUsers.insertOne({ name: `Single ${i}`, type: 'single' });
|
|
181
|
+
}
|
|
182
|
+
const singleTime = Date.now() - singleStart;
|
|
183
|
+
// 批量插入
|
|
184
|
+
const bulkData = [];
|
|
185
|
+
for (let i = 0; i < count; i++) {
|
|
186
|
+
bulkData.push({ name: `Bulk ${i}`, type: 'bulk' });
|
|
187
|
+
}
|
|
188
|
+
const bulkStart = Date.now();
|
|
189
|
+
await perfUsers.insertMany(bulkData);
|
|
190
|
+
const bulkTime = Date.now() - bulkStart;
|
|
191
|
+
// 批量插入应该更快
|
|
192
|
+
expect(bulkTime).toBeLessThan(singleTime);
|
|
193
|
+
console.log(`单条插入:${singleTime}ms, 批量插入:${bulkTime}ms, 提升:${(singleTime / bulkTime).toFixed(2)}x`);
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
//# sourceMappingURL=optimization.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimization.test.js","sourceRoot":"","sources":["../../test/optimization.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.test.d.ts","sourceRoot":"","sources":["../../test/schema.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Schema 验证测试
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
5
|
+
import { Database, createSchema, ValidationError } from '../src/index.js';
|
|
6
|
+
import { rmSync, existsSync } from 'fs';
|
|
7
|
+
import { join } from 'path';
|
|
8
|
+
const TEST_DB_PATH = join(process.cwd(), 'test-data', 'test-schema-db');
|
|
9
|
+
describe('Schema Validation', () => {
|
|
10
|
+
let db;
|
|
11
|
+
beforeAll(async () => {
|
|
12
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
13
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
14
|
+
}
|
|
15
|
+
db = new Database(TEST_DB_PATH);
|
|
16
|
+
await db.open();
|
|
17
|
+
});
|
|
18
|
+
afterAll(async () => {
|
|
19
|
+
await db.close();
|
|
20
|
+
if (existsSync(TEST_DB_PATH)) {
|
|
21
|
+
rmSync(TEST_DB_PATH, { recursive: true, force: true });
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
it('应该创建 Schema', () => {
|
|
25
|
+
const userSchema = createSchema({
|
|
26
|
+
name: { type: 'string', required: true, minLength: 1, maxLength: 50 },
|
|
27
|
+
email: { type: 'string', required: true, pattern: /^[^\s@]+@[^\s@]+\.[^\s@]+$/ },
|
|
28
|
+
age: { type: 'number', required: true, min: 0, max: 150 },
|
|
29
|
+
status: { type: 'string', enum: ['active', 'inactive', 'pending'] },
|
|
30
|
+
tags: { type: 'array', items: { type: 'string' } },
|
|
31
|
+
metadata: { type: 'object' }
|
|
32
|
+
});
|
|
33
|
+
expect(userSchema).toBeDefined();
|
|
34
|
+
});
|
|
35
|
+
it('应该验证通过有效的数据', () => {
|
|
36
|
+
const userSchema = createSchema({
|
|
37
|
+
name: { type: 'string', required: true },
|
|
38
|
+
age: { type: 'number', min: 0 }
|
|
39
|
+
});
|
|
40
|
+
const result = userSchema.validate({ name: 'Alice', age: 25 });
|
|
41
|
+
expect(result.valid).toBe(true);
|
|
42
|
+
});
|
|
43
|
+
it('应该验证失败无效的数据', () => {
|
|
44
|
+
const userSchema = createSchema({
|
|
45
|
+
name: { type: 'string', required: true },
|
|
46
|
+
age: { type: 'number', min: 0, max: 150 }
|
|
47
|
+
});
|
|
48
|
+
const result = userSchema.validate({ name: 'Alice', age: -5 });
|
|
49
|
+
expect(result.valid).toBe(false);
|
|
50
|
+
expect(result.errors).toHaveLength(1);
|
|
51
|
+
expect(result.errors[0].field).toBe('age');
|
|
52
|
+
});
|
|
53
|
+
it('应该验证必填字段', () => {
|
|
54
|
+
const userSchema = createSchema({
|
|
55
|
+
name: { type: 'string', required: true },
|
|
56
|
+
email: { type: 'string', required: true }
|
|
57
|
+
});
|
|
58
|
+
const result = userSchema.validate({ name: 'Alice' });
|
|
59
|
+
expect(result.valid).toBe(false);
|
|
60
|
+
expect(result.errors.some(e => e.field === 'email')).toBe(true);
|
|
61
|
+
});
|
|
62
|
+
it('应该验证字符串长度', () => {
|
|
63
|
+
const userSchema = createSchema({
|
|
64
|
+
name: { type: 'string', minLength: 3, maxLength: 10 }
|
|
65
|
+
});
|
|
66
|
+
expect(userSchema.validate({ name: 'Al' }).valid).toBe(false);
|
|
67
|
+
expect(userSchema.validate({ name: 'Alice' }).valid).toBe(true);
|
|
68
|
+
expect(userSchema.validate({ name: 'Alexanderia' }).valid).toBe(false);
|
|
69
|
+
});
|
|
70
|
+
it('应该验证枚举值', () => {
|
|
71
|
+
const userSchema = createSchema({
|
|
72
|
+
status: { type: 'string', enum: ['active', 'inactive'] }
|
|
73
|
+
});
|
|
74
|
+
expect(userSchema.validate({ status: 'active' }).valid).toBe(true);
|
|
75
|
+
expect(userSchema.validate({ status: 'unknown' }).valid).toBe(false);
|
|
76
|
+
});
|
|
77
|
+
it('应该验证数组', () => {
|
|
78
|
+
const userSchema = createSchema({
|
|
79
|
+
tags: { type: 'array', items: { type: 'string' } }
|
|
80
|
+
});
|
|
81
|
+
expect(userSchema.validate({ tags: ['a', 'b'] }).valid).toBe(true);
|
|
82
|
+
expect(userSchema.validate({ tags: ['a', 123] }).valid).toBe(false);
|
|
83
|
+
});
|
|
84
|
+
it('应该在插入时验证', async () => {
|
|
85
|
+
const users = db.collection('users');
|
|
86
|
+
const userSchema = createSchema({
|
|
87
|
+
name: { type: 'string', required: true, minLength: 1 },
|
|
88
|
+
email: { type: 'string', required: true },
|
|
89
|
+
age: { type: 'number', min: 0, max: 150 }
|
|
90
|
+
});
|
|
91
|
+
users.setSchema(userSchema);
|
|
92
|
+
// 有效数据应该插入成功
|
|
93
|
+
const user = await users.insertOne({
|
|
94
|
+
name: 'Alice',
|
|
95
|
+
email: 'alice@example.com',
|
|
96
|
+
age: 25
|
|
97
|
+
});
|
|
98
|
+
expect(user.name).toBe('Alice');
|
|
99
|
+
});
|
|
100
|
+
it('应该在插入时拒绝无效数据', async () => {
|
|
101
|
+
const users = db.collection('users');
|
|
102
|
+
const userSchema = createSchema({
|
|
103
|
+
name: { type: 'string', required: true },
|
|
104
|
+
age: { type: 'number', min: 0, max: 150 }
|
|
105
|
+
});
|
|
106
|
+
users.setSchema(userSchema);
|
|
107
|
+
// 无效数据应该抛出异常
|
|
108
|
+
await expect(users.insertOne({
|
|
109
|
+
name: 'Bob',
|
|
110
|
+
age: 200 // 超过最大值
|
|
111
|
+
})).rejects.toThrow(ValidationError);
|
|
112
|
+
});
|
|
113
|
+
it('应该支持批量插入验证', async () => {
|
|
114
|
+
const products = db.collection('products');
|
|
115
|
+
const productSchema = createSchema({
|
|
116
|
+
name: { type: 'string', required: true },
|
|
117
|
+
price: { type: 'number', min: 0 },
|
|
118
|
+
stock: { type: 'number', min: 0, integer: true }
|
|
119
|
+
});
|
|
120
|
+
products.setSchema(productSchema);
|
|
121
|
+
// 有效数据
|
|
122
|
+
const result = await products.insertMany([
|
|
123
|
+
{ name: 'Product 1', price: 10.99, stock: 100 },
|
|
124
|
+
{ name: 'Product 2', price: 20.99, stock: 50 }
|
|
125
|
+
]);
|
|
126
|
+
expect(result.insertedCount).toBe(2);
|
|
127
|
+
// 无效数据应该失败
|
|
128
|
+
await expect(products.insertMany([
|
|
129
|
+
{ name: 'Product 3', price: -10 } // 负数价格
|
|
130
|
+
])).rejects.toThrow(ValidationError);
|
|
131
|
+
});
|
|
132
|
+
it('应该支持默认值', () => {
|
|
133
|
+
const userSchema = createSchema({
|
|
134
|
+
name: { type: 'string', required: true },
|
|
135
|
+
status: { type: 'string', default: 'active' },
|
|
136
|
+
role: { type: 'string', default: 'user' }
|
|
137
|
+
});
|
|
138
|
+
const doc = { name: 'Alice' };
|
|
139
|
+
const withDefaults = userSchema.applyDefaults(doc);
|
|
140
|
+
expect(withDefaults.status).toBe('active');
|
|
141
|
+
expect(withDefaults.role).toBe('user');
|
|
142
|
+
});
|
|
143
|
+
it('应该支持严格模式', () => {
|
|
144
|
+
const userSchema = createSchema({
|
|
145
|
+
name: { type: 'string' },
|
|
146
|
+
age: { type: 'number' }
|
|
147
|
+
}, { strict: true });
|
|
148
|
+
const result = userSchema.validate({
|
|
149
|
+
name: 'Alice',
|
|
150
|
+
age: 25,
|
|
151
|
+
extra: 'field' // 额外字段
|
|
152
|
+
});
|
|
153
|
+
expect(result.valid).toBe(false);
|
|
154
|
+
expect(result.errors.some(e => e.field === 'extra')).toBe(true);
|
|
155
|
+
});
|
|
156
|
+
it('应该支持自定义验证', () => {
|
|
157
|
+
const userSchema = createSchema({
|
|
158
|
+
name: { type: 'string' },
|
|
159
|
+
password: {
|
|
160
|
+
type: 'custom',
|
|
161
|
+
validate: (value) => {
|
|
162
|
+
const strValue = value;
|
|
163
|
+
if (strValue.length < 8) {
|
|
164
|
+
return '密码长度至少为 8 位';
|
|
165
|
+
}
|
|
166
|
+
if (!/[A-Z]/.test(strValue)) {
|
|
167
|
+
return '密码必须包含大写字母';
|
|
168
|
+
}
|
|
169
|
+
return true;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
expect(userSchema.validate({ password: 'short' }).valid).toBe(false);
|
|
174
|
+
expect(userSchema.validate({ password: 'alllowercase' }).valid).toBe(false);
|
|
175
|
+
expect(userSchema.validate({ password: 'ValidPass123' }).valid).toBe(true);
|
|
176
|
+
});
|
|
177
|
+
it('应该支持嵌套对象验证', () => {
|
|
178
|
+
const orderSchema = createSchema({
|
|
179
|
+
customer: {
|
|
180
|
+
type: 'object',
|
|
181
|
+
properties: {
|
|
182
|
+
name: { type: 'string', required: true },
|
|
183
|
+
email: { type: 'string' }
|
|
184
|
+
}
|
|
185
|
+
},
|
|
186
|
+
items: { type: 'array' }
|
|
187
|
+
});
|
|
188
|
+
expect(orderSchema.validate({
|
|
189
|
+
customer: { name: 'Alice', email: 'alice@example.com' },
|
|
190
|
+
items: []
|
|
191
|
+
}).valid).toBe(true);
|
|
192
|
+
expect(orderSchema.validate({
|
|
193
|
+
customer: { email: 'alice@example.com' } // 缺少 name
|
|
194
|
+
}).valid).toBe(false);
|
|
195
|
+
});
|
|
196
|
+
});
|
|
197
|
+
//# sourceMappingURL=schema.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.test.js","sourceRoot":"","sources":["../../test/schema.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql.test.d.ts","sourceRoot":"","sources":["../../test/sql.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
|