@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.
Files changed (118) hide show
  1. package/README.md +903 -0
  2. package/dist/bin/cli-export.d.ts +7 -0
  3. package/dist/bin/cli-export.d.ts.map +1 -0
  4. package/dist/bin/cli-export.js +318 -0
  5. package/dist/bin/cli-export.js.map +1 -0
  6. package/dist/bin/cli-import.d.ts +7 -0
  7. package/dist/bin/cli-import.d.ts.map +1 -0
  8. package/dist/bin/cli-import.js +298 -0
  9. package/dist/bin/cli-import.js.map +1 -0
  10. package/dist/bin/server.d.ts +7 -0
  11. package/dist/bin/server.d.ts.map +1 -0
  12. package/dist/bin/server.js +92 -0
  13. package/dist/bin/server.js.map +1 -0
  14. package/dist/examples/sql-example.d.ts +7 -0
  15. package/dist/examples/sql-example.d.ts.map +1 -0
  16. package/dist/examples/sql-example.js +131 -0
  17. package/dist/examples/sql-example.js.map +1 -0
  18. package/dist/src/BulkOp.d.ts +74 -0
  19. package/dist/src/BulkOp.d.ts.map +1 -0
  20. package/dist/src/BulkOp.js +143 -0
  21. package/dist/src/BulkOp.js.map +1 -0
  22. package/dist/src/Collection.d.ts +232 -0
  23. package/dist/src/Collection.d.ts.map +1 -0
  24. package/dist/src/Collection.js +705 -0
  25. package/dist/src/Collection.js.map +1 -0
  26. package/dist/src/Cursor.d.ts +94 -0
  27. package/dist/src/Cursor.d.ts.map +1 -0
  28. package/dist/src/Cursor.js +259 -0
  29. package/dist/src/Cursor.js.map +1 -0
  30. package/dist/src/Database.d.ts +98 -0
  31. package/dist/src/Database.d.ts.map +1 -0
  32. package/dist/src/Database.js +198 -0
  33. package/dist/src/Database.js.map +1 -0
  34. package/dist/src/Operators.d.ts +73 -0
  35. package/dist/src/Operators.d.ts.map +1 -0
  36. package/dist/src/Operators.js +339 -0
  37. package/dist/src/Operators.js.map +1 -0
  38. package/dist/src/QueryCache.d.ts +87 -0
  39. package/dist/src/QueryCache.d.ts.map +1 -0
  40. package/dist/src/QueryCache.js +155 -0
  41. package/dist/src/QueryCache.js.map +1 -0
  42. package/dist/src/SQLExecutor.d.ts +60 -0
  43. package/dist/src/SQLExecutor.d.ts.map +1 -0
  44. package/dist/src/SQLExecutor.js +317 -0
  45. package/dist/src/SQLExecutor.js.map +1 -0
  46. package/dist/src/SQLParser.d.ts +181 -0
  47. package/dist/src/SQLParser.d.ts.map +1 -0
  48. package/dist/src/SQLParser.js +640 -0
  49. package/dist/src/SQLParser.js.map +1 -0
  50. package/dist/src/Schema.d.ts +92 -0
  51. package/dist/src/Schema.d.ts.map +1 -0
  52. package/dist/src/Schema.js +253 -0
  53. package/dist/src/Schema.js.map +1 -0
  54. package/dist/src/Transaction.d.ts +118 -0
  55. package/dist/src/Transaction.d.ts.map +1 -0
  56. package/dist/src/Transaction.js +233 -0
  57. package/dist/src/Transaction.js.map +1 -0
  58. package/dist/src/Utils.d.ts +68 -0
  59. package/dist/src/Utils.d.ts.map +1 -0
  60. package/dist/src/Utils.js +187 -0
  61. package/dist/src/Utils.js.map +1 -0
  62. package/dist/src/errors.d.ts +58 -0
  63. package/dist/src/errors.d.ts.map +1 -0
  64. package/dist/src/errors.js +85 -0
  65. package/dist/src/errors.js.map +1 -0
  66. package/dist/src/index.d.ts +39 -0
  67. package/dist/src/index.d.ts.map +1 -0
  68. package/dist/src/index.js +44 -0
  69. package/dist/src/index.js.map +1 -0
  70. package/dist/test/basic.test.d.ts +5 -0
  71. package/dist/test/basic.test.d.ts.map +1 -0
  72. package/dist/test/basic.test.js +283 -0
  73. package/dist/test/basic.test.js.map +1 -0
  74. package/dist/test/index.test.d.ts +5 -0
  75. package/dist/test/index.test.d.ts.map +1 -0
  76. package/dist/test/index.test.js +126 -0
  77. package/dist/test/index.test.js.map +1 -0
  78. package/dist/test/jsonb.test.d.ts +5 -0
  79. package/dist/test/jsonb.test.d.ts.map +1 -0
  80. package/dist/test/jsonb.test.js +165 -0
  81. package/dist/test/jsonb.test.js.map +1 -0
  82. package/dist/test/optimization.test.d.ts +6 -0
  83. package/dist/test/optimization.test.d.ts.map +1 -0
  84. package/dist/test/optimization.test.js +196 -0
  85. package/dist/test/optimization.test.js.map +1 -0
  86. package/dist/test/schema.test.d.ts +5 -0
  87. package/dist/test/schema.test.d.ts.map +1 -0
  88. package/dist/test/schema.test.js +197 -0
  89. package/dist/test/schema.test.js.map +1 -0
  90. package/dist/test/sql.test.d.ts +7 -0
  91. package/dist/test/sql.test.d.ts.map +1 -0
  92. package/dist/test/sql.test.js +21 -0
  93. package/dist/test/sql.test.js.map +1 -0
  94. package/package.json +73 -0
  95. package/src/BulkOp.js +181 -0
  96. package/src/BulkOp.ts +191 -0
  97. package/src/Collection.js +843 -0
  98. package/src/Collection.ts +896 -0
  99. package/src/Cursor.js +315 -0
  100. package/src/Cursor.ts +319 -0
  101. package/src/Database.js +244 -0
  102. package/src/Database.ts +268 -0
  103. package/src/Operators.js +382 -0
  104. package/src/Operators.ts +375 -0
  105. package/src/QueryCache.js +190 -0
  106. package/src/QueryCache.ts +208 -0
  107. package/src/SQLExecutor.ts +391 -0
  108. package/src/SQLParser.ts +814 -0
  109. package/src/Schema.js +292 -0
  110. package/src/Schema.ts +317 -0
  111. package/src/Transaction.js +291 -0
  112. package/src/Transaction.ts +313 -0
  113. package/src/Utils.js +205 -0
  114. package/src/Utils.ts +205 -0
  115. package/src/errors.js +93 -0
  116. package/src/errors.ts +93 -0
  117. package/src/index.js +90 -0
  118. 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,6 @@
1
+ /**
2
+ * 优化功能测试
3
+ * 测试批量操作、查询缓存、事务功能
4
+ */
5
+ export {};
6
+ //# sourceMappingURL=optimization.test.d.ts.map
@@ -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,5 @@
1
+ /**
2
+ * Schema 验证测试
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=schema.test.d.ts.map
@@ -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,7 @@
1
+ /**
2
+ * SQL 查询功能测试
3
+ * 注意:由于循环依赖问题,此测试使用编译后的 dist 代码
4
+ * 运行方式:node test/sql-runner.js
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=sql.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql.test.d.ts","sourceRoot":"","sources":["../../test/sql.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}