@uql/core 0.4.80 → 0.4.83

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 (57) hide show
  1. package/README.md +11 -11
  2. package/dialect/abstractSqlDialect-spec.d.ts +49 -0
  3. package/dialect/abstractSqlDialect-spec.js +765 -0
  4. package/dialect/abstractSqlDialect.js +11 -17
  5. package/dialect/mysqlDialect.js +2 -2
  6. package/dialect/mysqlDialect.spec.d.ts +6 -0
  7. package/dialect/mysqlDialect.spec.js +33 -0
  8. package/dialect/postgresDialect.js +2 -2
  9. package/dialect/postgresDialect.spec.d.ts +1 -0
  10. package/dialect/postgresDialect.spec.js +139 -0
  11. package/dialect/sqliteDialect.spec.d.ts +1 -0
  12. package/dialect/sqliteDialect.spec.js +12 -0
  13. package/entity/decorator/definition.js +22 -24
  14. package/entity/decorator/definition.spec.d.ts +1 -0
  15. package/entity/decorator/definition.spec.js +725 -0
  16. package/entity/decorator/relation.spec.d.ts +1 -0
  17. package/entity/decorator/relation.spec.js +55 -0
  18. package/options.js +2 -2
  19. package/options.spec.d.ts +1 -0
  20. package/options.spec.js +50 -0
  21. package/package.json +3 -3
  22. package/querier/abstractQuerier-it.d.ts +41 -0
  23. package/querier/abstractQuerier-it.js +410 -0
  24. package/querier/abstractSqlQuerier-it.d.ts +9 -0
  25. package/querier/abstractSqlQuerier-it.js +19 -0
  26. package/querier/abstractSqlQuerier-spec.d.ts +53 -0
  27. package/querier/abstractSqlQuerier-spec.js +607 -0
  28. package/querier/abstractSqlQuerier.js +2 -3
  29. package/querier/decorator/injectQuerier.js +2 -3
  30. package/querier/decorator/injectQuerier.spec.d.ts +1 -0
  31. package/querier/decorator/injectQuerier.spec.js +108 -0
  32. package/querier/decorator/transactional.js +2 -2
  33. package/querier/decorator/transactional.spec.d.ts +1 -0
  34. package/querier/decorator/transactional.spec.js +241 -0
  35. package/repository/genericRepository.spec.d.ts +1 -0
  36. package/repository/genericRepository.spec.js +86 -0
  37. package/test/entityMock.d.ts +180 -0
  38. package/test/entityMock.js +451 -0
  39. package/test/index.d.ts +3 -0
  40. package/test/index.js +7 -0
  41. package/test/it.util.d.ts +4 -0
  42. package/test/it.util.js +60 -0
  43. package/test/spec.util.d.ts +13 -0
  44. package/test/spec.util.js +54 -0
  45. package/type/entity.d.ts +12 -17
  46. package/type/entity.js +1 -1
  47. package/type/utility.d.ts +3 -2
  48. package/type/utility.js +1 -1
  49. package/util/dialect.util.js +2 -3
  50. package/util/dialect.util.spec.d.ts +1 -0
  51. package/util/dialect.util.spec.js +23 -0
  52. package/util/object.util.spec.d.ts +1 -0
  53. package/util/object.util.spec.js +26 -0
  54. package/util/sql.util.spec.d.ts +1 -0
  55. package/util/sql.util.spec.js +164 -0
  56. package/util/string.util.spec.d.ts +1 -0
  57. package/util/string.util.spec.js +26 -0
@@ -0,0 +1,410 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractQuerierIt = void 0;
4
+ const entity_1 = require("@uql/core/entity");
5
+ const test_1 = require("@uql/core/test");
6
+ class AbstractQuerierIt {
7
+ constructor(pool) {
8
+ this.pool = pool;
9
+ }
10
+ async beforeAll() {
11
+ this.querier = await this.pool.getQuerier();
12
+ await this.dropTables();
13
+ await this.createTables();
14
+ await this.querier.release();
15
+ }
16
+ async beforeEach() {
17
+ this.querier = await this.pool.getQuerier();
18
+ await this.clearTables();
19
+ }
20
+ async afterEach() {
21
+ await this.querier.release();
22
+ }
23
+ async afterAll() {
24
+ await this.pool.end();
25
+ }
26
+ shouldGetRepository() {
27
+ const repository = this.querier.getRepository(test_1.User);
28
+ expect(repository).toBeDefined();
29
+ }
30
+ async shouldInsertMany() {
31
+ const ids = await this.querier.insertMany(test_1.User, [
32
+ {
33
+ name: 'Some Name A',
34
+ email: 'someemaila@example.com',
35
+ password: '123456789a!',
36
+ },
37
+ {
38
+ name: 'Some Name B',
39
+ email: 'someemailb@example.com',
40
+ password: '123456789b!',
41
+ },
42
+ ]);
43
+ expect(ids).toHaveLength(2);
44
+ for (const id of ids) {
45
+ expect(id).toBeDefined();
46
+ }
47
+ }
48
+ async shouldInsertOne() {
49
+ const creatorId = await this.querier.insertOne(test_1.User, {
50
+ name: 'Some Name C',
51
+ email: 'someemailc@example.com',
52
+ password: '123456789z!',
53
+ });
54
+ expect(creatorId).toBeDefined();
55
+ const companyId = await this.querier.insertOne(test_1.Company, {
56
+ name: 'Some Name C',
57
+ creatorId,
58
+ });
59
+ expect(companyId).toBeDefined();
60
+ const taxCategoryId = await this.querier.insertOne(test_1.TaxCategory, {
61
+ name: 'Some Name C',
62
+ description: 'Some Description Z',
63
+ creatorId,
64
+ companyId,
65
+ });
66
+ expect(taxCategoryId).toBeDefined();
67
+ }
68
+ async shouldInsertOneWithOnInsertId() {
69
+ const id1 = await this.querier.insertOne(test_1.TaxCategory, {
70
+ name: 'Some Name',
71
+ });
72
+ const id2 = await this.querier.insertOne(test_1.TaxCategory, {
73
+ pk: '123',
74
+ name: 'Some Name',
75
+ });
76
+ expect(id1).toBeDefined();
77
+ expect(id2).toBeDefined();
78
+ }
79
+ async shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {
80
+ const ids = await this.querier.insertMany(test_1.TaxCategory, [
81
+ {
82
+ name: 'Some Name A',
83
+ },
84
+ {
85
+ pk: '50',
86
+ name: 'Some Name B',
87
+ },
88
+ {
89
+ name: 'Some Name C',
90
+ },
91
+ {
92
+ pk: '70',
93
+ name: 'Some Name D',
94
+ },
95
+ ]);
96
+ expect(ids).toHaveLength(4);
97
+ for (const id of ids) {
98
+ expect(id).toBeDefined();
99
+ }
100
+ }
101
+ async shouldInsertManyWithAutoIncrementIdAsDefault() {
102
+ const ids = await this.querier.insertMany(test_1.LedgerAccount, [
103
+ {
104
+ name: 'Some Name A',
105
+ },
106
+ {
107
+ name: 'Some Name B',
108
+ },
109
+ {
110
+ name: 'Some Name C',
111
+ },
112
+ ]);
113
+ expect(ids).toHaveLength(3);
114
+ for (const id of ids) {
115
+ expect(id).toBeDefined();
116
+ }
117
+ const founds = await this.querier.findMany(test_1.LedgerAccount, {});
118
+ expect(founds.map(({ id }) => id)).toEqual(ids);
119
+ }
120
+ async shouldInsertOneAndCascadeOneToOne() {
121
+ const payload = {
122
+ name: 'Some Name D',
123
+ createdAt: 123,
124
+ profile: { picture: 'abc', createdAt: 123 },
125
+ };
126
+ const id = await this.querier.insertOne(test_1.User, payload);
127
+ expect(id).toBeDefined();
128
+ const found = await this.querier.findOneById(test_1.User, id, { $project: ['profile'] });
129
+ expect(found).toMatchObject({ id, profile: payload.profile });
130
+ }
131
+ async shouldInsertOneAndCascadeManyToOne() {
132
+ const payload = {
133
+ name: 'Centimeter',
134
+ createdAt: 123,
135
+ category: { name: 'Metric', createdAt: 123 },
136
+ };
137
+ const id = await this.querier.insertOne(test_1.MeasureUnit, payload);
138
+ expect(id).toBeDefined();
139
+ const found = await this.querier.findOneById(test_1.MeasureUnit, id, { $project: { category: true } });
140
+ expect(found).toMatchObject({ id, category: payload.category });
141
+ }
142
+ async shouldInsertOneAndCascadeOneToMany() {
143
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
144
+ const date = new Date();
145
+ const inventoryAdjustmentId = await this.querier.insertOne(test_1.InventoryAdjustment, {
146
+ description: 'some description',
147
+ date,
148
+ itemAdjustments,
149
+ });
150
+ expect(inventoryAdjustmentId).toBeDefined();
151
+ const inventoryAdjustmentFound = await this.querier.findOneById(test_1.InventoryAdjustment, inventoryAdjustmentId, {
152
+ $project: { itemAdjustments: true },
153
+ });
154
+ expect(inventoryAdjustmentFound).toMatchObject({
155
+ id: inventoryAdjustmentId,
156
+ itemAdjustments,
157
+ });
158
+ const itemAdjustmentsFound = await this.querier.findMany(test_1.ItemAdjustment, { $filter: { inventoryAdjustmentId } });
159
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
160
+ }
161
+ async shouldInsertOneAndCascadeOneToManyWithSpecificFields() {
162
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
163
+ const inventoryAdjustmentId = await this.querier.insertOne(test_1.InventoryAdjustment, {
164
+ description: 'some description',
165
+ itemAdjustments: itemAdjustments.slice(),
166
+ });
167
+ expect(inventoryAdjustmentId).toBeDefined();
168
+ const inventoryAdjustmentFound = await this.querier.findOneById(test_1.InventoryAdjustment, inventoryAdjustmentId, {
169
+ $project: { itemAdjustments: ['buyPrice'] },
170
+ });
171
+ expect(inventoryAdjustmentFound).toMatchObject({
172
+ id: inventoryAdjustmentId,
173
+ itemAdjustments,
174
+ });
175
+ const itemAdjustmentsFound = await this.querier.findMany(test_1.ItemAdjustment, { $filter: { inventoryAdjustmentId } });
176
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
177
+ }
178
+ async shouldUpdateOneAndCascadeOneToMany() {
179
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
180
+ const inventoryAdjustmentId = await this.querier.insertOne(test_1.InventoryAdjustment, {
181
+ description: 'some description',
182
+ });
183
+ expect(inventoryAdjustmentId).toBeDefined();
184
+ const changes = await this.querier.updateOneById(test_1.InventoryAdjustment, inventoryAdjustmentId, {
185
+ itemAdjustments,
186
+ });
187
+ expect(changes).toBe(1);
188
+ const inventoryAdjustmentFound = await this.querier.findOneById(test_1.InventoryAdjustment, inventoryAdjustmentId, {
189
+ $project: { itemAdjustments: ['buyPrice'] },
190
+ });
191
+ expect(inventoryAdjustmentFound).toMatchObject({
192
+ id: inventoryAdjustmentId,
193
+ itemAdjustments,
194
+ });
195
+ const itemAdjustmentsFound = await this.querier.findMany(test_1.ItemAdjustment, { $filter: { inventoryAdjustmentId } });
196
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
197
+ }
198
+ async shouldUpdateOneByIdAndCascadeOneToManyNull() {
199
+ const id = await this.querier.insertOne(test_1.InventoryAdjustment, { itemAdjustments: [{}, {}] });
200
+ await expect(this.querier.count(test_1.ItemAdjustment)).resolves.toBe(2);
201
+ await this.querier.updateOneById(test_1.InventoryAdjustment, id, {
202
+ itemAdjustments: null,
203
+ });
204
+ await expect(this.querier.count(test_1.ItemAdjustment)).resolves.toBe(0);
205
+ }
206
+ async shouldUpdateManyAndCascadeOneToManyNull() {
207
+ await this.querier.insertOne(test_1.InventoryAdjustment, { itemAdjustments: [{}, {}] });
208
+ await expect(this.querier.count(test_1.ItemAdjustment)).resolves.toBe(2);
209
+ await this.querier.updateMany(test_1.InventoryAdjustment, { $filter: {} }, {
210
+ itemAdjustments: null,
211
+ });
212
+ await expect(this.querier.count(test_1.ItemAdjustment)).resolves.toBe(0);
213
+ }
214
+ async shouldInsertOneAndCascadeManyToMany() {
215
+ const payload = {
216
+ name: 'item one',
217
+ createdAt: 1,
218
+ tags: [
219
+ {
220
+ name: 'tag one',
221
+ createdAt: 1,
222
+ },
223
+ {
224
+ name: 'tag two',
225
+ createdAt: 1,
226
+ },
227
+ ],
228
+ };
229
+ const id = await this.querier.insertOne(test_1.Item, payload);
230
+ expect(id).toBeDefined();
231
+ const foundItem = await this.querier.findOneById(test_1.Item, id, {
232
+ $project: { name: true, createdAt: true, tags: ['name', 'createdAt'] },
233
+ });
234
+ expect(foundItem).toMatchObject({
235
+ id,
236
+ ...payload,
237
+ });
238
+ const foundTags = await this.querier.findMany(test_1.Tag, {
239
+ $project: { name: true, createdAt: true, items: ['name', 'createdAt'] },
240
+ });
241
+ delete foundItem.tags;
242
+ expect(foundTags).toMatchObject(payload.tags.map((tag) => ({ ...tag, items: [foundItem] })));
243
+ }
244
+ async shouldUpdateOneAndCascadeManyToMany() {
245
+ const id = await this.querier.insertOne(test_1.Item, { createdAt: 1 });
246
+ const payload = {
247
+ name: 'item one',
248
+ updatedAt: 1,
249
+ tags: [
250
+ {
251
+ name: 'tag one',
252
+ createdAt: 1,
253
+ },
254
+ {
255
+ name: 'tag two',
256
+ createdAt: 1,
257
+ },
258
+ ],
259
+ };
260
+ await this.querier.updateOneById(test_1.Item, id, payload);
261
+ const found = await this.querier.findOneById(test_1.Item, id, {
262
+ $project: { name: true, updatedAt: true, tags: true },
263
+ });
264
+ expect(found).toMatchObject({
265
+ id,
266
+ ...payload,
267
+ });
268
+ }
269
+ async shouldFindMany() {
270
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
271
+ const users = await this.querier.findMany(test_1.User, {
272
+ $project: ['name'],
273
+ $skip: 1,
274
+ $limit: 2,
275
+ $sort: {
276
+ name: 1,
277
+ },
278
+ });
279
+ expect(users).toMatchObject([
280
+ {
281
+ name: 'Some Name B',
282
+ },
283
+ {
284
+ name: 'Some Name C',
285
+ },
286
+ ]);
287
+ }
288
+ async shouldFindOne() {
289
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
290
+ const found = await this.querier.findOne(test_1.User, {
291
+ $project: ['id', 'name', 'email', 'password'],
292
+ $filter: {
293
+ email: 'someemaila@example.com',
294
+ },
295
+ });
296
+ expect(found).toMatchObject({
297
+ name: 'Some Name A',
298
+ email: 'someemaila@example.com',
299
+ password: '123456789a!',
300
+ });
301
+ const notFound = await this.querier.findOne(test_1.User, {
302
+ $filter: {
303
+ name: 'some name',
304
+ },
305
+ });
306
+ expect(notFound).toBeUndefined();
307
+ }
308
+ async shouldCount() {
309
+ await expect(this.querier.count(test_1.User, {})).resolves.toBe(0);
310
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
311
+ await expect(this.querier.count(test_1.User)).resolves.toBe(3);
312
+ await expect(this.querier.count(test_1.User, { $filter: { companyId: null } })).resolves.toBe(3);
313
+ await expect(this.querier.count(test_1.User, { $filter: { companyId: 1 } })).resolves.toBe(0);
314
+ }
315
+ async shouldUpdateMany() {
316
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
317
+ await expect(this.querier.updateMany(test_1.User, { $filter: { companyId: 1 } }, { companyId: null })).resolves.toBe(0);
318
+ await expect(this.querier.updateMany(test_1.User, { $filter: { companyId: null } }, { companyId: 1 })).resolves.toBe(3);
319
+ await expect(this.querier.updateMany(test_1.User, { $filter: { companyId: 1 } }, { companyId: null })).resolves.toBe(3);
320
+ }
321
+ async shouldThrowWhenRollbackTransactionWithoutBeginTransaction() {
322
+ await expect(this.querier.rollbackTransaction()).rejects.toThrow('not a pending transaction');
323
+ }
324
+ async shouldThrowIfUnknownComparisonOperator() {
325
+ await expect(this.querier.findMany(test_1.User, {
326
+ $filter: { name: { $someInvalidOperator: 'some' } },
327
+ })).rejects.toThrow('unknown operator: $someInvalidOperator');
328
+ }
329
+ async shouldCommit() {
330
+ await expect(this.querier.count(test_1.User)).resolves.toBe(0);
331
+ await this.querier.beginTransaction();
332
+ await this.querier.insertOne(test_1.User, {});
333
+ await expect(this.querier.count(test_1.User)).resolves.toBe(1);
334
+ await this.querier.commitTransaction();
335
+ await expect(this.querier.count(test_1.User)).resolves.toBe(1);
336
+ }
337
+ async shouldRollback() {
338
+ await expect(this.querier.count(test_1.User)).resolves.toBe(0);
339
+ await this.querier.beginTransaction();
340
+ await this.querier.insertOne(test_1.User, {});
341
+ await expect(this.querier.count(test_1.User)).resolves.toBe(1);
342
+ await this.querier.rollbackTransaction();
343
+ await expect(this.querier.count(test_1.User)).resolves.toBe(0);
344
+ }
345
+ async shouldThrowWhenBeginTransactionAfterBeginTransaction() {
346
+ expect(this.querier.hasOpenTransaction).toBeFalsy();
347
+ await this.querier.beginTransaction();
348
+ expect(this.querier.hasOpenTransaction).toBe(true);
349
+ await expect(this.querier.beginTransaction()).rejects.toThrow('pending transaction');
350
+ await expect(this.querier.release()).rejects.toThrow('pending transaction');
351
+ await this.querier.rollbackTransaction();
352
+ }
353
+ async shouldProjectOneToMany() {
354
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
355
+ const [user, company] = await Promise.all([
356
+ this.querier.findOne(test_1.User, { $project: ['id'] }),
357
+ this.querier.findOne(test_1.Company, { $project: ['id'] }),
358
+ ]);
359
+ const [firstItemId, secondItemId] = await this.querier.insertMany(test_1.Item, [
360
+ {
361
+ name: 'some item name a',
362
+ creatorId: user.id,
363
+ companyId: company.id,
364
+ },
365
+ {
366
+ name: 'some item name b',
367
+ creatorId: user.id,
368
+ companyId: company.id,
369
+ },
370
+ ]);
371
+ const inventoryAdjustmentId = await this.querier.insertOne(test_1.InventoryAdjustment, {
372
+ description: 'some inventory adjustment',
373
+ creatorId: user.id,
374
+ companyId: company.id,
375
+ itemAdjustments: [
376
+ { buyPrice: 1000, itemId: firstItemId },
377
+ { buyPrice: 2000, itemId: secondItemId },
378
+ ],
379
+ });
380
+ const inventoryAdjustmentFound = await this.querier.findOneById(test_1.InventoryAdjustment, inventoryAdjustmentId, {
381
+ $project: { itemAdjustments: true, creator: true },
382
+ });
383
+ expect(inventoryAdjustmentFound).toMatchObject({
384
+ id: inventoryAdjustmentId,
385
+ itemAdjustments: [
386
+ { buyPrice: 1000, itemId: firstItemId },
387
+ { buyPrice: 2000, itemId: secondItemId },
388
+ ],
389
+ creator: {
390
+ email: 'someemaila@example.com',
391
+ name: 'Some Name A',
392
+ password: '123456789a!',
393
+ },
394
+ });
395
+ }
396
+ async shouldDeleteMany() {
397
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
398
+ await expect(this.querier.deleteMany(test_1.User, { $filter: { companyId: 1 } })).resolves.toBe(0);
399
+ await expect(this.querier.deleteMany(test_1.User, { $filter: { companyId: null } })).resolves.toBe(3);
400
+ }
401
+ async shouldThrowWhenCommitTransactionWithoutBeginTransaction() {
402
+ await expect(this.querier.commitTransaction()).rejects.toThrow('not a pending transaction');
403
+ }
404
+ async clearTables() {
405
+ const entities = (0, entity_1.getEntities)();
406
+ await Promise.all(entities.map((entity) => this.querier.deleteMany(entity, {})));
407
+ }
408
+ }
409
+ exports.AbstractQuerierIt = AbstractQuerierIt;
410
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier-it.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier-it.ts"],"names":[],"mappings":"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","sourcesContent":["import { Querier, QuerierPool } from '@uql/core/type';\nimport { getEntities } from '@uql/core/entity';\nimport { Company, InventoryAdjustment, Item, ItemAdjustment, LedgerAccount, MeasureUnit, Spec, Tag, TaxCategory, User } from '@uql/core/test';\n\nexport abstract class AbstractQuerierIt<Q extends Querier> implements Spec {\n  querier: Q;\n\n  constructor(readonly pool: QuerierPool<Q>) {}\n\n  async beforeAll() {\n    this.querier = await this.pool.getQuerier();\n    await this.dropTables();\n    await this.createTables();\n    await this.querier.release();\n  }\n\n  async beforeEach() {\n    this.querier = await this.pool.getQuerier();\n    await this.clearTables();\n  }\n\n  async afterEach() {\n    await this.querier.release();\n  }\n\n  async afterAll() {\n    await this.pool.end();\n  }\n\n  shouldGetRepository() {\n    const repository = this.querier.getRepository(User);\n    expect(repository).toBeDefined();\n  }\n\n  async shouldInsertMany() {\n    const ids = await this.querier.insertMany(User, [\n      {\n        name: 'Some Name A',\n        email: 'someemaila@example.com',\n        password: '123456789a!',\n      },\n      {\n        name: 'Some Name B',\n        email: 'someemailb@example.com',\n        password: '123456789b!',\n      },\n    ]);\n    expect(ids).toHaveLength(2);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n  }\n\n  async shouldInsertOne() {\n    const creatorId = await this.querier.insertOne(User, {\n      name: 'Some Name C',\n      email: 'someemailc@example.com',\n      password: '123456789z!',\n    });\n    expect(creatorId).toBeDefined();\n\n    const companyId = await this.querier.insertOne(Company, {\n      name: 'Some Name C',\n      creatorId,\n    });\n    expect(companyId).toBeDefined();\n\n    const taxCategoryId = await this.querier.insertOne(TaxCategory, {\n      name: 'Some Name C',\n      description: 'Some Description Z',\n      creatorId,\n      companyId,\n    });\n    expect(taxCategoryId).toBeDefined();\n  }\n\n  async shouldInsertOneWithOnInsertId() {\n    const id1 = await this.querier.insertOne(TaxCategory, {\n      name: 'Some Name',\n    });\n    const id2 = await this.querier.insertOne(TaxCategory, {\n      pk: '123',\n      name: 'Some Name',\n    });\n    expect(id1).toBeDefined();\n    expect(id2).toBeDefined();\n  }\n\n  async shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {\n    const ids = await this.querier.insertMany(TaxCategory, [\n      {\n        name: 'Some Name A',\n      },\n      {\n        pk: '50',\n        name: 'Some Name B',\n      },\n      {\n        name: 'Some Name C',\n      },\n      {\n        pk: '70',\n        name: 'Some Name D',\n      },\n    ]);\n    expect(ids).toHaveLength(4);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n  }\n\n  async shouldInsertManyWithAutoIncrementIdAsDefault() {\n    const ids = await this.querier.insertMany(LedgerAccount, [\n      {\n        name: 'Some Name A',\n      },\n      {\n        name: 'Some Name B',\n      },\n      {\n        name: 'Some Name C',\n      },\n    ]);\n    expect(ids).toHaveLength(3);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n    const founds = await this.querier.findMany(LedgerAccount, {});\n    expect(founds.map(({ id }) => id)).toEqual(ids);\n  }\n\n  async shouldInsertOneAndCascadeOneToOne() {\n    const payload: User = {\n      name: 'Some Name D',\n      createdAt: 123,\n      profile: { picture: 'abc', createdAt: 123 },\n    };\n    const id = await this.querier.insertOne(User, payload);\n    expect(id).toBeDefined();\n    const found = await this.querier.findOneById(User, id, { $project: ['profile'] });\n    expect(found).toMatchObject({ id, profile: payload.profile });\n  }\n\n  async shouldInsertOneAndCascadeManyToOne() {\n    const payload: MeasureUnit = {\n      name: 'Centimeter',\n      createdAt: 123,\n      category: { name: 'Metric', createdAt: 123 },\n    };\n\n    const id = await this.querier.insertOne(MeasureUnit, payload);\n\n    expect(id).toBeDefined();\n\n    const found = await this.querier.findOneById(MeasureUnit, id, { $project: { category: true } });\n\n    expect(found).toMatchObject({ id, category: payload.category });\n  }\n\n  async shouldInsertOneAndCascadeOneToMany() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const date = new Date();\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n      date,\n      itemAdjustments,\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $project: { itemAdjustments: true },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $filter: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldInsertOneAndCascadeOneToManyWithSpecificFields() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n      itemAdjustments: itemAdjustments.slice(),\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $project: { itemAdjustments: ['buyPrice'] },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $filter: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldUpdateOneAndCascadeOneToMany() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const changes = await this.querier.updateOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      itemAdjustments,\n    });\n\n    expect(changes).toBe(1);\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $project: { itemAdjustments: ['buyPrice'] },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $filter: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldUpdateOneByIdAndCascadeOneToManyNull() {\n    const id = await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });\n\n    await expect(this.querier.count(ItemAdjustment)).resolves.toBe(2);\n\n    await this.querier.updateOneById(InventoryAdjustment, id, {\n      itemAdjustments: null,\n    });\n\n    await expect(this.querier.count(ItemAdjustment)).resolves.toBe(0);\n  }\n\n  async shouldUpdateManyAndCascadeOneToManyNull() {\n    await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });\n\n    await expect(this.querier.count(ItemAdjustment)).resolves.toBe(2);\n\n    await this.querier.updateMany(\n      InventoryAdjustment,\n      { $filter: {} },\n      {\n        itemAdjustments: null,\n      }\n    );\n\n    await expect(this.querier.count(ItemAdjustment)).resolves.toBe(0);\n  }\n\n  async shouldInsertOneAndCascadeManyToMany() {\n    const payload: Item = {\n      name: 'item one',\n      createdAt: 1,\n      tags: [\n        {\n          name: 'tag one',\n          createdAt: 1,\n        },\n        {\n          name: 'tag two',\n          createdAt: 1,\n        },\n      ],\n    };\n\n    const id = await this.querier.insertOne(Item, payload);\n\n    expect(id).toBeDefined();\n\n    const foundItem = await this.querier.findOneById(Item, id, {\n      $project: { name: true, createdAt: true, tags: ['name', 'createdAt'] },\n    });\n\n    expect(foundItem).toMatchObject({\n      id,\n      ...payload,\n    });\n\n    const foundTags = await this.querier.findMany(Tag, {\n      $project: { name: true, createdAt: true, items: ['name', 'createdAt'] },\n    });\n\n    delete foundItem.tags;\n\n    expect(foundTags).toMatchObject(payload.tags.map((tag) => ({ ...tag, items: [foundItem] })));\n  }\n\n  async shouldUpdateOneAndCascadeManyToMany() {\n    const id = await this.querier.insertOne(Item, { createdAt: 1 });\n    const payload: Item = {\n      name: 'item one',\n      updatedAt: 1,\n      tags: [\n        {\n          name: 'tag one',\n          createdAt: 1,\n        },\n        {\n          name: 'tag two',\n          createdAt: 1,\n        },\n      ],\n    };\n\n    await this.querier.updateOneById(Item, id, payload);\n\n    const found = await this.querier.findOneById(Item, id, {\n      $project: { name: true, updatedAt: true, tags: true },\n    });\n\n    expect(found).toMatchObject({\n      id,\n      ...payload,\n    });\n  }\n\n  async shouldFindMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    const users = await this.querier.findMany(User, {\n      $project: ['name'],\n      $skip: 1,\n      $limit: 2,\n      $sort: {\n        name: 1,\n      },\n    });\n\n    expect(users).toMatchObject([\n      {\n        name: 'Some Name B',\n      },\n      {\n        name: 'Some Name C',\n      },\n    ]);\n  }\n\n  async shouldFindOne() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    const found = await this.querier.findOne(User, {\n      $project: ['id', 'name', 'email', 'password'],\n      $filter: {\n        email: 'someemaila@example.com',\n      },\n    });\n\n    expect(found).toMatchObject({\n      name: 'Some Name A',\n      email: 'someemaila@example.com',\n      password: '123456789a!',\n    });\n\n    const notFound = await this.querier.findOne(User, {\n      $filter: {\n        name: 'some name',\n      },\n    });\n\n    expect(notFound).toBeUndefined();\n  }\n\n  async shouldCount() {\n    await expect(this.querier.count(User, {})).resolves.toBe(0);\n\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    await expect(this.querier.count(User)).resolves.toBe(3);\n    await expect(this.querier.count(User, { $filter: { companyId: null } })).resolves.toBe(3);\n    await expect(this.querier.count(User, { $filter: { companyId: 1 } })).resolves.toBe(0);\n  }\n\n  async shouldUpdateMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    await expect(this.querier.updateMany(User, { $filter: { companyId: 1 } }, { companyId: null })).resolves.toBe(0);\n    await expect(this.querier.updateMany(User, { $filter: { companyId: null } }, { companyId: 1 })).resolves.toBe(3);\n    await expect(this.querier.updateMany(User, { $filter: { companyId: 1 } }, { companyId: null })).resolves.toBe(3);\n  }\n\n  async shouldThrowWhenRollbackTransactionWithoutBeginTransaction() {\n    await expect(this.querier.rollbackTransaction()).rejects.toThrow('not a pending transaction');\n  }\n\n  async shouldThrowIfUnknownComparisonOperator() {\n    await expect(\n      this.querier.findMany(User, {\n        $filter: { name: { $someInvalidOperator: 'some' } as any },\n      })\n    ).rejects.toThrow('unknown operator: $someInvalidOperator');\n  }\n\n  async shouldCommit() {\n    await expect(this.querier.count(User)).resolves.toBe(0);\n    await this.querier.beginTransaction();\n    await this.querier.insertOne(User, {});\n    await expect(this.querier.count(User)).resolves.toBe(1);\n    await this.querier.commitTransaction();\n    await expect(this.querier.count(User)).resolves.toBe(1);\n  }\n\n  async shouldRollback() {\n    await expect(this.querier.count(User)).resolves.toBe(0);\n    await this.querier.beginTransaction();\n    await this.querier.insertOne(User, {});\n    await expect(this.querier.count(User)).resolves.toBe(1);\n    await this.querier.rollbackTransaction();\n    await expect(this.querier.count(User)).resolves.toBe(0);\n  }\n\n  async shouldThrowWhenBeginTransactionAfterBeginTransaction() {\n    expect(this.querier.hasOpenTransaction).toBeFalsy();\n    await this.querier.beginTransaction();\n    expect(this.querier.hasOpenTransaction).toBe(true);\n    await expect(this.querier.beginTransaction()).rejects.toThrow('pending transaction');\n    await expect(this.querier.release()).rejects.toThrow('pending transaction');\n    await this.querier.rollbackTransaction();\n  }\n\n  async shouldProjectOneToMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    const [user, company] = await Promise.all([\n      this.querier.findOne(User, { $project: ['id'] }),\n      this.querier.findOne(Company, { $project: ['id'] }),\n    ]);\n\n    const [firstItemId, secondItemId] = await this.querier.insertMany(Item, [\n      {\n        name: 'some item name a',\n        creatorId: user.id,\n        companyId: company.id,\n      },\n      {\n        name: 'some item name b',\n        creatorId: user.id,\n        companyId: company.id,\n      },\n    ]);\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some inventory adjustment',\n      creatorId: user.id,\n      companyId: company.id,\n      itemAdjustments: [\n        { buyPrice: 1000, itemId: firstItemId },\n        { buyPrice: 2000, itemId: secondItemId },\n      ],\n    });\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $project: { itemAdjustments: true, creator: true },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments: [\n        { buyPrice: 1000, itemId: firstItemId },\n        { buyPrice: 2000, itemId: secondItemId },\n      ],\n      creator: {\n        email: 'someemaila@example.com',\n        name: 'Some Name A',\n        password: '123456789a!',\n      },\n    });\n  }\n\n  async shouldDeleteMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n    await expect(this.querier.deleteMany(User, { $filter: { companyId: 1 } })).resolves.toBe(0);\n    await expect(this.querier.deleteMany(User, { $filter: { companyId: null } })).resolves.toBe(3);\n  }\n\n  async shouldThrowWhenCommitTransactionWithoutBeginTransaction() {\n    await expect(this.querier.commitTransaction()).rejects.toThrow('not a pending transaction');\n  }\n\n  async clearTables() {\n    const entities = getEntities();\n    await Promise.all(entities.map((entity) => this.querier.deleteMany(entity, {})));\n  }\n\n  abstract createTables(): Promise<void>;\n\n  abstract dropTables(): Promise<void>;\n}\n"]}
@@ -0,0 +1,9 @@
1
+ import { QuerierPool } from '@uql/core/type';
2
+ import { AbstractQuerierIt } from './abstractQuerier-it';
3
+ import { AbstractSqlQuerier } from './abstractSqlQuerier';
4
+ export declare abstract class AbstractSqlQuerierIt extends AbstractQuerierIt<AbstractSqlQuerier> {
5
+ readonly idType: string;
6
+ constructor(pool: QuerierPool<AbstractSqlQuerier>, idType: string);
7
+ createTables(): Promise<void>;
8
+ dropTables(): Promise<void>;
9
+ }
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractSqlQuerierIt = void 0;
4
+ const test_1 = require("@uql/core/test");
5
+ const abstractQuerier_it_1 = require("./abstractQuerier-it");
6
+ class AbstractSqlQuerierIt extends abstractQuerier_it_1.AbstractQuerierIt {
7
+ constructor(pool, idType) {
8
+ super(pool);
9
+ this.idType = idType;
10
+ }
11
+ createTables() {
12
+ return (0, test_1.createTables)(this.querier, this.idType);
13
+ }
14
+ dropTables() {
15
+ return (0, test_1.dropTables)(this.querier);
16
+ }
17
+ }
18
+ exports.AbstractSqlQuerierIt = AbstractSqlQuerierIt;
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3RTcWxRdWVyaWVyLWl0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3F1ZXJpZXIvYWJzdHJhY3RTcWxRdWVyaWVyLWl0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHlDQUEwRDtBQUMxRCw2REFBeUQ7QUFHekQsTUFBc0Isb0JBQXFCLFNBQVEsc0NBQXFDO0lBQ3RGLFlBQVksSUFBcUMsRUFBVyxNQUFjO1FBQ3hFLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUQ4QyxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBRTFFLENBQUM7SUFFUSxZQUFZO1FBQ25CLE9BQU8sSUFBQSxtQkFBWSxFQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFUSxVQUFVO1FBQ2pCLE9BQU8sSUFBQSxpQkFBVSxFQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDO0NBQ0Y7QUFaRCxvREFZQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFF1ZXJpZXJQb29sIH0gZnJvbSAnQHVxbC9jb3JlL3R5cGUnO1xuaW1wb3J0IHsgY3JlYXRlVGFibGVzLCBkcm9wVGFibGVzIH0gZnJvbSAnQHVxbC9jb3JlL3Rlc3QnO1xuaW1wb3J0IHsgQWJzdHJhY3RRdWVyaWVySXQgfSBmcm9tICcuL2Fic3RyYWN0UXVlcmllci1pdCc7XG5pbXBvcnQgeyBBYnN0cmFjdFNxbFF1ZXJpZXIgfSBmcm9tICcuL2Fic3RyYWN0U3FsUXVlcmllcic7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFNxbFF1ZXJpZXJJdCBleHRlbmRzIEFic3RyYWN0UXVlcmllckl0PEFic3RyYWN0U3FsUXVlcmllcj4ge1xuICBjb25zdHJ1Y3Rvcihwb29sOiBRdWVyaWVyUG9vbDxBYnN0cmFjdFNxbFF1ZXJpZXI+LCByZWFkb25seSBpZFR5cGU6IHN0cmluZykge1xuICAgIHN1cGVyKHBvb2wpO1xuICB9XG5cbiAgb3ZlcnJpZGUgY3JlYXRlVGFibGVzKCkge1xuICAgIHJldHVybiBjcmVhdGVUYWJsZXModGhpcy5xdWVyaWVyLCB0aGlzLmlkVHlwZSk7XG4gIH1cblxuICBvdmVycmlkZSBkcm9wVGFibGVzKCkge1xuICAgIHJldHVybiBkcm9wVGFibGVzKHRoaXMucXVlcmllcik7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,53 @@
1
+ import { Spec } from '@uql/core/test';
2
+ import { QuerierPool } from '@uql/core/type';
3
+ import { AbstractSqlQuerier } from './abstractSqlQuerier';
4
+ export declare abstract class AbstractSqlQuerierSpec implements Spec {
5
+ readonly pool: QuerierPool<AbstractSqlQuerier>;
6
+ readonly idType: string;
7
+ querier: AbstractSqlQuerier;
8
+ constructor(pool: QuerierPool<AbstractSqlQuerier>, idType: string);
9
+ beforeAll(): Promise<void>;
10
+ beforeEach(): Promise<void>;
11
+ afterEach(): Promise<void>;
12
+ afterAll(): Promise<void>;
13
+ shouldFindOneById(): Promise<void>;
14
+ shouldFindOne(): Promise<void>;
15
+ shouldFindOneAndProjectOneToMany(): Promise<void>;
16
+ shouldFindAndProjectRaw(): Promise<void>;
17
+ shouldVirtualField(): Promise<void>;
18
+ shouldFind$exists(): Promise<void>;
19
+ shouldFind$nexists(): Promise<void>;
20
+ shouldFindOneAndProjectOneToManyOnly(): Promise<void>;
21
+ shouldFindOneAndProjectOneToManyWithSpecifiedFields(): Promise<void>;
22
+ shouldFindManyAndProjectOneToMany(): Promise<void>;
23
+ shouldFindOneAndProjectManyToMany(): Promise<void>;
24
+ shouldFindOneByIdAndProjectManyToMany(): Promise<void>;
25
+ shouldFindMany(): Promise<void>;
26
+ shouldFindManyAndCount(): Promise<void>;
27
+ shouldInsertOne(): Promise<void>;
28
+ shouldInsertOneAndCascadeOneToOne(): Promise<void>;
29
+ shouldInsertOneAndCascadeManyToOne(): Promise<void>;
30
+ shouldInsertOneAndCascadeOneToMany(): Promise<void>;
31
+ shouldUpdateMany(): Promise<void>;
32
+ shouldUpdateOneById(): Promise<void>;
33
+ shouldUpdateOneByIdAndCascadeOneToOne(): Promise<void>;
34
+ shouldUpdateOneByIdAndCascadeOneToOneNull(): Promise<void>;
35
+ shouldUpdateOneByIdAndCascadeOneToMany(): Promise<void>;
36
+ shouldUpdateOneByIdAndCascadeOneToManyNull(): Promise<void>;
37
+ shouldUpdateManyAndCascadeOneToManyNull(): Promise<void>;
38
+ shouldInsertOneAndCascadeManyToManyInserts(): Promise<void>;
39
+ shouldUpdateAndCascadeManyToManyInserts(): Promise<void>;
40
+ shouldUpdateAndCascadeManyToManyLinks(): Promise<void>;
41
+ shouldDeleteOneAndCascadeManyToManyDeletes(): Promise<void>;
42
+ shouldDeleteOneAndNoCascadeManyToManyDeletes(): Promise<void>;
43
+ shouldDeleteOneById(): Promise<void>;
44
+ shouldDeleteMany(): Promise<void>;
45
+ shouldCount(): Promise<void>;
46
+ shouldUseTransaction(): Promise<void>;
47
+ shouldUseTransactionCallback(): Promise<void>;
48
+ shouldThrowIfRollbackIfErrorInCallback(): Promise<void>;
49
+ shouldThrowIfTransactionIsPending(): Promise<void>;
50
+ shouldThrowIfCommitWithNoPendingTransaction(): Promise<void>;
51
+ shouldThrowIfRollbackWithNoPendingTransaction(): Promise<void>;
52
+ shouldThrowIfReleaseWithPendingTransaction(): Promise<void>;
53
+ }