@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,765 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractSqlDialectSpec = void 0;
4
+ const test_1 = require("@uql/core/test");
5
+ const util_1 = require("@uql/core/util");
6
+ class AbstractSqlDialectSpec {
7
+ constructor(dialect) {
8
+ this.dialect = dialect;
9
+ }
10
+ shouldBeValidEscapeCharacter() {
11
+ expect(this.dialect.escapeIdChar).toBe('`');
12
+ }
13
+ shouldBeginTransaction() {
14
+ expect(this.dialect.beginTransactionCommand).toBe('BEGIN TRANSACTION');
15
+ }
16
+ shouldInsertMany() {
17
+ expect(this.dialect.insert(test_1.User, [
18
+ {
19
+ name: 'Some name 1',
20
+ email: 'someemail1@example.com',
21
+ createdAt: 123,
22
+ },
23
+ {
24
+ name: 'Some name 2',
25
+ email: 'someemail2@example.com',
26
+ createdAt: 456,
27
+ },
28
+ {
29
+ name: 'Some name 3',
30
+ email: 'someemail3@example.com',
31
+ createdAt: 789,
32
+ },
33
+ ])).toBe('INSERT INTO `User` (`name`, `email`, `createdAt`) VALUES' +
34
+ " ('Some name 1', 'someemail1@example.com', 123)" +
35
+ ", ('Some name 2', 'someemail2@example.com', 456)" +
36
+ ", ('Some name 3', 'someemail3@example.com', 789)");
37
+ }
38
+ shouldInsertOne() {
39
+ expect(this.dialect.insert(test_1.User, {
40
+ name: 'Some Name',
41
+ email: 'someemail@example.com',
42
+ createdAt: 123,
43
+ })).toBe("INSERT INTO `User` (`name`, `email`, `createdAt`) VALUES ('Some Name', 'someemail@example.com', 123)");
44
+ expect(this.dialect.insert(test_1.InventoryAdjustment, {
45
+ date: new Date(2021, 11, 31, 23, 59, 59, 999),
46
+ createdAt: 123,
47
+ })).toBe("INSERT INTO `InventoryAdjustment` (`date`, `createdAt`) VALUES ('2021-12-31 23:59:59.999', 123)");
48
+ }
49
+ shouldInsertWithOnInsertId() {
50
+ expect(this.dialect.insert(test_1.TaxCategory, {
51
+ name: 'Some Name',
52
+ createdAt: 123,
53
+ })).toMatch(/^INSERT INTO `TaxCategory` \(`name`, `createdAt`, `pk`\) VALUES \('Some Name', 123, '.+'\)$/);
54
+ }
55
+ shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {
56
+ expect(this.dialect.insert(test_1.TaxCategory, [
57
+ {
58
+ name: 'Some Name A',
59
+ },
60
+ {
61
+ pk: '50',
62
+ name: 'Some Name B',
63
+ },
64
+ {
65
+ name: 'Some Name C',
66
+ },
67
+ {
68
+ pk: '70',
69
+ name: 'Some Name D',
70
+ },
71
+ ])).toMatch(/^INSERT INTO `TaxCategory` \(`name`, `createdAt`, `pk`\) VALUES \('Some Name A', \d+, '.+'\), \('Some Name B', \d+, '50'\), \('Some Name C', \d+, '.+'\), \('Some Name D', \d+, '70'\)$/);
72
+ }
73
+ shouldUpdate() {
74
+ expect(this.dialect.update(test_1.User, { $filter: { name: 'some', creatorId: 123 } }, {
75
+ name: 'Some Text',
76
+ updatedAt: 321,
77
+ })).toBe("UPDATE `User` SET `name` = 'Some Text', `updatedAt` = 321 WHERE `name` = 'some' AND `creatorId` = 123");
78
+ }
79
+ shouldFind() {
80
+ expect(this.dialect.find(test_1.User, {
81
+ $project: ['id'],
82
+ $filter: { id: 123, name: 'abc' },
83
+ })).toBe("SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'");
84
+ expect(this.dialect.find(test_1.Profile, {
85
+ $project: ['id', 'picture', 'companyId'],
86
+ $filter: { id: 123, picture: 'abc' },
87
+ })).toBe("SELECT `pk` `id`, `image` `picture`, `companyId` FROM `user_profile` WHERE `pk` = 123 AND `image` = 'abc'");
88
+ expect(this.dialect.find(test_1.MeasureUnit, {
89
+ $project: ['id'],
90
+ $filter: { id: 123, name: 'abc' },
91
+ })).toBe("SELECT `id` FROM `MeasureUnit` WHERE `id` = 123 AND `name` = 'abc' AND `deletedAt` IS NULL");
92
+ }
93
+ shouldBeSecure() {
94
+ expect(this.dialect.find(test_1.User, {
95
+ $project: ['id', 'something'],
96
+ $filter: {
97
+ id: 1,
98
+ something: 1,
99
+ },
100
+ $sort: {
101
+ id: 1,
102
+ something: 1,
103
+ },
104
+ $group: ['id', 'something'],
105
+ })).toBe('SELECT `id` FROM `User` WHERE `id` = 1 AND `something` = 1 GROUP BY `id`, `something` ORDER BY `id`, `something`');
106
+ expect(this.dialect.insert(test_1.User, {
107
+ name: 'Some Name',
108
+ something: 'anything',
109
+ createdAt: 1,
110
+ })).toBe("INSERT INTO `User` (`name`, `createdAt`) VALUES ('Some Name', 1)");
111
+ expect(this.dialect.update(test_1.User, {
112
+ $filter: { something: 'anything' },
113
+ }, {
114
+ name: 'Some Name',
115
+ something: 'anything',
116
+ updatedAt: 1,
117
+ })).toBe("UPDATE `User` SET `name` = 'Some Name', `updatedAt` = 1 WHERE `something` = 'anything'");
118
+ expect(this.dialect.delete(test_1.User, {
119
+ $filter: { something: 'anything' },
120
+ })).toBe("DELETE FROM `User` WHERE `something` = 'anything'");
121
+ }
122
+ shouldFind$and() {
123
+ const sql = "SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'";
124
+ expect(this.dialect.find(test_1.User, {
125
+ $project: ['id'],
126
+ $filter: { $and: [{ id: 123, name: 'abc' }] },
127
+ })).toBe(sql);
128
+ expect(this.dialect.find(test_1.User, {
129
+ $project: { id: 1 },
130
+ $filter: { $and: [{ id: 123 }], name: 'abc' },
131
+ })).toBe(sql);
132
+ }
133
+ shouldFind$or() {
134
+ expect(this.dialect.find(test_1.User, {
135
+ $project: ['id'],
136
+ $filter: { $or: [{ id: 123 }, { name: 'abc' }] },
137
+ })).toBe("SELECT `id` FROM `User` WHERE `id` = 123 OR `name` = 'abc'");
138
+ expect(this.dialect.find(test_1.User, {
139
+ $project: ['id'],
140
+ $filter: { $or: [{ id: 123 }] },
141
+ })).toBe('SELECT `id` FROM `User` WHERE `id` = 123');
142
+ expect(this.dialect.find(test_1.User, {
143
+ $project: { id: 1 },
144
+ $filter: { $or: [{ id: 123, name: 'abc' }] },
145
+ })).toBe("SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'");
146
+ expect(this.dialect.find(test_1.User, {
147
+ $project: ['id'],
148
+ $filter: { $or: [{ id: 123 }], name: 'abc' },
149
+ })).toBe("SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'");
150
+ }
151
+ shouldFind$not() {
152
+ expect(this.dialect.find(test_1.User, {
153
+ $project: ['id'],
154
+ $filter: { $not: [{ name: 'Some' }] },
155
+ })).toBe("SELECT `id` FROM `User` WHERE NOT `name` = 'Some'");
156
+ expect(this.dialect.find(test_1.Company, {
157
+ $project: ['id'],
158
+ $filter: { id: { $not: 123 } },
159
+ })).toBe('SELECT `id` FROM `Company` WHERE NOT `id` = 123');
160
+ expect(this.dialect.find(test_1.Company, {
161
+ $project: ['id'],
162
+ $filter: { id: { $not: [123, 456] } },
163
+ })).toBe('SELECT `id` FROM `Company` WHERE NOT `id` IN (123, 456)');
164
+ expect(this.dialect.find(test_1.Company, {
165
+ $project: ['id'],
166
+ $filter: { id: 123, name: { $not: { $startsWith: 'a' } } },
167
+ })).toBe("SELECT `id` FROM `Company` WHERE `id` = 123 AND NOT `name` LIKE 'a%'");
168
+ expect(this.dialect.find(test_1.Company, {
169
+ $project: ['id'],
170
+ $filter: { name: { $not: { $startsWith: 'a', $endsWith: 'z' } } },
171
+ })).toBe("SELECT `id` FROM `Company` WHERE NOT (`name` LIKE 'a%' AND `name` LIKE '%z')");
172
+ expect(this.dialect.find(test_1.User, {
173
+ $project: { id: true },
174
+ $filter: { $not: [{ name: { $like: 'Some', $ne: 'Something' } }] },
175
+ })).toBe("SELECT `id` FROM `User` WHERE NOT (`name` LIKE 'Some' AND `name` <> 'Something')");
176
+ expect(this.dialect.find(test_1.User, {
177
+ $project: { id: true },
178
+ $filter: { $not: [{ name: 'abc' }, { creatorId: 1 }] },
179
+ })).toBe("SELECT `id` FROM `User` WHERE NOT (`name` = 'abc' AND `creatorId` = 1)");
180
+ expect(this.dialect.find(test_1.Tax, {
181
+ $project: ['id'],
182
+ $filter: { companyId: 1, name: { $not: { $startsWith: 'a' } } },
183
+ })).toBe("SELECT `id` FROM `Tax` WHERE `companyId` = 1 AND NOT `name` LIKE 'a%'");
184
+ }
185
+ shouldFind$nor() {
186
+ expect(this.dialect.find(test_1.User, {
187
+ $project: ['id'],
188
+ $filter: { $nor: [{ name: 'Some' }] },
189
+ })).toBe("SELECT `id` FROM `User` WHERE NOT `name` = 'Some'");
190
+ expect(this.dialect.find(test_1.User, {
191
+ $project: { id: true },
192
+ $filter: { $nor: [{ name: { $like: 'Some', $ne: 'Something' } }] },
193
+ })).toBe("SELECT `id` FROM `User` WHERE NOT (`name` LIKE 'Some' AND `name` <> 'Something')");
194
+ expect(this.dialect.find(test_1.User, {
195
+ $project: { id: true },
196
+ $filter: { $nor: [{ name: 'abc' }, { creatorId: 1 }] },
197
+ })).toBe("SELECT `id` FROM `User` WHERE NOT (`name` = 'abc' OR `creatorId` = 1)");
198
+ }
199
+ shouldFind$orAnd$and() {
200
+ expect(this.dialect.find(test_1.User, {
201
+ $project: ['id'],
202
+ $filter: { creatorId: 1, $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }], id: 1 },
203
+ })).toBe("SELECT `id` FROM `User` WHERE `creatorId` = 1 AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com') AND `id` = 1");
204
+ expect(this.dialect.find(test_1.User, {
205
+ $project: ['id'],
206
+ $filter: {
207
+ creatorId: 1,
208
+ $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }],
209
+ id: 1,
210
+ email: 'e',
211
+ },
212
+ })).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 1' +
213
+ " AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com') AND `id` = 1 AND `email` = 'e'");
214
+ expect(this.dialect.find(test_1.User, {
215
+ $project: ['id'],
216
+ $filter: {
217
+ creatorId: 1,
218
+ $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }],
219
+ id: 1,
220
+ email: 'e',
221
+ },
222
+ $sort: { name: 1, createdAt: -1 },
223
+ $skip: 50,
224
+ $limit: 10,
225
+ })).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 1' +
226
+ " AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com')" +
227
+ " AND `id` = 1 AND `email` = 'e'" +
228
+ ' ORDER BY `name`, `createdAt` DESC LIMIT 10 OFFSET 50');
229
+ expect(this.dialect.find(test_1.User, {
230
+ $project: ['id'],
231
+ $filter: {
232
+ $or: [
233
+ {
234
+ creatorId: 1,
235
+ id: 1,
236
+ email: 'e',
237
+ },
238
+ { name: ['a', 'b', 'c'], email: 'abc@example.com' },
239
+ ],
240
+ },
241
+ $sort: [
242
+ { field: 'name', sort: 'asc' },
243
+ { field: 'createdAt', sort: 'desc' },
244
+ ],
245
+ $skip: 50,
246
+ $limit: 10,
247
+ })).toBe("SELECT `id` FROM `User` WHERE (`creatorId` = 1 AND `id` = 1 AND `email` = 'e')" +
248
+ " OR (`name` IN ('a', 'b', 'c') AND `email` = 'abc@example.com')" +
249
+ ' ORDER BY `name`, `createdAt` DESC LIMIT 10 OFFSET 50');
250
+ }
251
+ shouldFindSingle$filter() {
252
+ expect(this.dialect.find(test_1.User, {
253
+ $project: ['id'],
254
+ $filter: { name: 'some' },
255
+ $limit: 3,
256
+ })).toBe("SELECT `id` FROM `User` WHERE `name` = 'some' LIMIT 3");
257
+ }
258
+ shouldFindMultipleComparisonOperators() {
259
+ expect(this.dialect.find(test_1.User, {
260
+ $project: ['id'],
261
+ $filter: { $or: [{ name: { $eq: 'other', $ne: 'other unwanted' } }, { companyId: 1 }] },
262
+ })).toBe("SELECT `id` FROM `User` WHERE (`name` = 'other' AND `name` <> 'other unwanted') OR `companyId` = 1");
263
+ expect(this.dialect.find(test_1.User, {
264
+ $project: ['id'],
265
+ $filter: { createdAt: { $gte: 123, $lte: 999 } },
266
+ $limit: 10,
267
+ })).toBe('SELECT `id` FROM `User` WHERE (`createdAt` >= 123 AND `createdAt` <= 999) LIMIT 10');
268
+ expect(this.dialect.find(test_1.User, {
269
+ $project: ['id'],
270
+ $filter: { createdAt: { $gt: 123, $lt: 999 } },
271
+ $limit: 10,
272
+ })).toBe('SELECT `id` FROM `User` WHERE (`createdAt` > 123 AND `createdAt` < 999) LIMIT 10');
273
+ }
274
+ shouldFind$ne() {
275
+ expect(this.dialect.find(test_1.User, {
276
+ $project: ['id'],
277
+ $filter: { name: 'some', companyId: { $ne: 5 } },
278
+ $limit: 20,
279
+ })).toBe("SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` <> 5 LIMIT 20");
280
+ }
281
+ shouldFindIsNull() {
282
+ expect(this.dialect.find(test_1.User, {
283
+ $project: ['id'],
284
+ $filter: { creatorId: 123, companyId: null },
285
+ $limit: 5,
286
+ })).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 123 AND `companyId` IS NULL LIMIT 5');
287
+ expect(this.dialect.find(test_1.User, {
288
+ $project: { id: true },
289
+ $filter: { creatorId: 123, companyId: { $ne: null } },
290
+ $limit: 5,
291
+ })).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 123 AND `companyId` IS NOT NULL LIMIT 5');
292
+ }
293
+ shouldFind$in() {
294
+ const sql = "SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` IN (1, 2, 3) LIMIT 10";
295
+ expect(this.dialect.find(test_1.User, {
296
+ $project: ['id'],
297
+ $filter: { name: 'some', companyId: [1, 2, 3] },
298
+ $limit: 10,
299
+ })).toBe(sql);
300
+ expect(this.dialect.find(test_1.User, {
301
+ $project: ['id'],
302
+ $filter: { name: 'some', companyId: { $in: [1, 2, 3] } },
303
+ $limit: 10,
304
+ })).toBe(sql);
305
+ }
306
+ shouldFind$nin() {
307
+ expect(this.dialect.find(test_1.User, {
308
+ $project: ['id'],
309
+ $filter: { name: 'some', companyId: { $nin: [1, 2, 3] } },
310
+ $limit: 10,
311
+ })).toBe("SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` NOT IN (1, 2, 3) LIMIT 10");
312
+ }
313
+ shouldFind$projectFields() {
314
+ expect(this.dialect.find(test_1.User, { $project: { id: true, company: true } })).toBe('SELECT `User`.`id`, `company`.`id` `company.id`, `company`.`companyId` `company.companyId`, `company`.`creatorId` `company.creatorId`' +
315
+ ', `company`.`createdAt` `company.createdAt`, `company`.`updatedAt` `company.updatedAt`' +
316
+ ', `company`.`name` `company.name`, `company`.`description` `company.description`' +
317
+ ' FROM `User` LEFT JOIN `Company` `company` ON `company`.`id` = `User`.`companyId`');
318
+ }
319
+ shouldFind$projectOneToOne() {
320
+ expect(this.dialect.find(test_1.User, {
321
+ $project: { id: true, name: true, profile: ['id', 'picture'] },
322
+ })).toBe('SELECT `User`.`id`, `User`.`name`, `profile`.`pk` `profile.id`, `profile`.`image` `profile.picture` FROM `User`' +
323
+ ' LEFT JOIN `user_profile` `profile` ON `profile`.`creatorId` = `User`.`id`');
324
+ expect(this.dialect.find(test_1.User, { $project: { profile: true } })).toBe('SELECT `User`.`id`, `profile`.`companyId` `profile.companyId`' +
325
+ ', `profile`.`creatorId` `profile.creatorId`, `profile`.`createdAt` `profile.createdAt`' +
326
+ ', `profile`.`updatedAt` `profile.updatedAt`' +
327
+ ', `profile`.`pk` `profile.id`, `profile`.`image` `profile.picture`' +
328
+ ' FROM `User` LEFT JOIN `user_profile` `profile` ON `profile`.`creatorId` = `User`.`id`');
329
+ }
330
+ shouldFind$projectManyToOne() {
331
+ expect(this.dialect.find(test_1.Item, {
332
+ $project: {
333
+ id: true,
334
+ name: true,
335
+ code: true,
336
+ tax: { $project: ['id', 'name'], $required: true },
337
+ measureUnit: { $project: ['id', 'name', 'categoryId'] },
338
+ },
339
+ $limit: 100,
340
+ })).toBe('SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +
341
+ ', `tax`.`id` `tax.id`, `tax`.`name` `tax.name`' +
342
+ ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +
343
+ ' FROM `Item`' +
344
+ ' INNER JOIN `Tax` `tax` ON `tax`.`id` = `Item`.`taxId`' +
345
+ ' LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +
346
+ ' LIMIT 100');
347
+ }
348
+ shouldFind$projectWithAllFieldsAndSpecificFieldsAndFilter() {
349
+ expect(this.dialect.find(test_1.Item, {
350
+ $project: {
351
+ id: true,
352
+ name: true,
353
+ measureUnit: { $project: ['id', 'name'], $filter: { name: { $ne: 'unidad' } }, $required: true },
354
+ tax: ['id', 'name'],
355
+ },
356
+ $filter: { salePrice: { $gte: 1000 }, name: { $istartsWith: 'A' } },
357
+ $sort: { tax: { name: 1 }, measureUnit: { name: 1 }, createdAt: -1 },
358
+ $limit: 100,
359
+ })).toBe('SELECT `Item`.`id`, `Item`.`name`' +
360
+ ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`' +
361
+ ', `tax`.`id` `tax.id`, `tax`.`name` `tax.name`' +
362
+ ' FROM `Item`' +
363
+ " INNER JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId` AND `measureUnit`.`name` <> 'unidad' AND `measureUnit`.`deletedAt` IS NULL" +
364
+ ' LEFT JOIN `Tax` `tax` ON `tax`.`id` = `Item`.`taxId`' +
365
+ " WHERE `Item`.`salePrice` >= 1000 AND LOWER(`Item`.`name`) LIKE 'a%'" +
366
+ ' ORDER BY `tax`.`name`, `measureUnit`.`name`, `Item`.`createdAt` DESC LIMIT 100');
367
+ }
368
+ shouldVirtualField() {
369
+ expect(this.dialect.find(test_1.Item, {
370
+ $project: {
371
+ id: 1,
372
+ },
373
+ $filter: {
374
+ tagsCount: { $gte: 10 },
375
+ },
376
+ })).toBe('SELECT `id` FROM `Item` WHERE (SELECT COUNT(*) `count` FROM `ItemTag` WHERE `ItemTag`.`itemId` = `id`) >= 10');
377
+ expect(this.dialect.find(test_1.Item, {
378
+ $project: {
379
+ id: 1,
380
+ name: 1,
381
+ code: 1,
382
+ tagsCount: 1,
383
+ measureUnit: {
384
+ $project: { id: 1, name: 1, categoryId: 1, category: ['name'] },
385
+ },
386
+ },
387
+ $limit: 100,
388
+ })).toBe('SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +
389
+ ', (SELECT COUNT(*) `count` FROM `ItemTag` WHERE `ItemTag`.`itemId` = `Item`.`id`) `tagsCount`' +
390
+ ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +
391
+ ', `measureUnit.category`.`id` `measureUnit.category.id`, `measureUnit.category`.`name` `measureUnit.category.name`' +
392
+ ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +
393
+ ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +
394
+ ' LIMIT 100');
395
+ }
396
+ shouldFind$projectDeep() {
397
+ expect(this.dialect.find(test_1.Item, {
398
+ $project: {
399
+ id: 1,
400
+ name: 1,
401
+ code: 1,
402
+ measureUnit: {
403
+ $project: { id: 1, name: 1, categoryId: 1, category: ['name'] },
404
+ },
405
+ },
406
+ $limit: 100,
407
+ })).toBe('SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +
408
+ ', `measureUnit`.`id` `measureUnit.id`' +
409
+ ', `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +
410
+ ', `measureUnit.category`.`id` `measureUnit.category.id`, `measureUnit.category`.`name` `measureUnit.category.name`' +
411
+ ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +
412
+ ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +
413
+ ' LIMIT 100');
414
+ expect(this.dialect.find(test_1.Item, {
415
+ $project: {
416
+ id: true,
417
+ name: true,
418
+ code: true,
419
+ measureUnit: {
420
+ $project: { id: true, name: true, category: { $project: { id: true, name: true } } },
421
+ },
422
+ },
423
+ $limit: 100,
424
+ })).toBe('SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`, `measureUnit`.`id` `measureUnit.id`' +
425
+ ', `measureUnit`.`name` `measureUnit.name`, `measureUnit.category`.`id` `measureUnit.category.id`' +
426
+ ', `measureUnit.category`.`name` `measureUnit.category.name`' +
427
+ ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +
428
+ ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +
429
+ ' LIMIT 100');
430
+ expect(this.dialect.find(test_1.ItemAdjustment, {
431
+ $project: {
432
+ id: true,
433
+ buyPrice: true,
434
+ number: true,
435
+ item: {
436
+ $project: {
437
+ id: true,
438
+ name: true,
439
+ measureUnit: {
440
+ $project: { id: true, name: true, category: ['id', 'name'] },
441
+ },
442
+ },
443
+ $required: true,
444
+ },
445
+ },
446
+ $limit: 100,
447
+ })).toBe('SELECT `ItemAdjustment`.`id`, `ItemAdjustment`.`buyPrice`, `ItemAdjustment`.`number`' +
448
+ ', `item`.`id` `item.id`, `item`.`name` `item.name`' +
449
+ ', `item.measureUnit`.`id` `item.measureUnit.id`, `item.measureUnit`.`name` `item.measureUnit.name`' +
450
+ ', `item.measureUnit.category`.`id` `item.measureUnit.category.id`, `item.measureUnit.category`.`name` `item.measureUnit.category.name`' +
451
+ ' FROM `ItemAdjustment`' +
452
+ ' INNER JOIN `Item` `item` ON `item`.`id` = `ItemAdjustment`.`itemId`' +
453
+ ' LEFT JOIN `MeasureUnit` `item.measureUnit` ON `item.measureUnit`.`id` = `item`.`measureUnitId`' +
454
+ ' LEFT JOIN `MeasureUnitCategory` `item.measureUnit.category` ON `item.measureUnit.category`.`id` = `item.measureUnit`.`categoryId`' +
455
+ ' LIMIT 100');
456
+ }
457
+ shouldFind$group() {
458
+ expect(this.dialect.find(test_1.User, {
459
+ $group: ['companyId'],
460
+ })).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `name`, `email`, `password` FROM `User` GROUP BY `companyId`');
461
+ expect(this.dialect.find(test_1.User, {
462
+ $project: ['companyId', (0, util_1.raw)('COUNT(*)', 'count')],
463
+ $group: ['companyId'],
464
+ $having: {
465
+ count: {
466
+ $gte: 10,
467
+ },
468
+ },
469
+ })).toBe('SELECT `companyId`, COUNT(*) `count` FROM `User` GROUP BY `companyId` HAVING `count` >= 10');
470
+ expect(this.dialect.find(test_1.User, {
471
+ $project: ['id', 'name'],
472
+ $filter: { companyId: 1 },
473
+ $group: ['companyId'],
474
+ $skip: 50,
475
+ $limit: 100,
476
+ $sort: { name: 'desc' },
477
+ })).toBe('SELECT `id`, `name` FROM `User` WHERE `companyId` = 1 GROUP BY `companyId` ORDER BY `name` DESC LIMIT 100 OFFSET 50');
478
+ }
479
+ shouldFind$limit() {
480
+ expect(this.dialect.find(test_1.User, {
481
+ $project: ['id'],
482
+ $filter: 9,
483
+ $limit: 1,
484
+ })).toBe('SELECT `id` FROM `User` WHERE `id` = 9 LIMIT 1');
485
+ expect(this.dialect.find(test_1.User, {
486
+ $project: { id: 1, name: 1, creatorId: 1 },
487
+ $filter: 9,
488
+ $limit: 1,
489
+ })).toBe('SELECT `id`, `name`, `creatorId` FROM `User` WHERE `id` = 9 LIMIT 1');
490
+ expect(this.dialect.find(test_1.User, {
491
+ $project: ['id'],
492
+ $filter: { name: 'something', creatorId: 123 },
493
+ $limit: 1,
494
+ })).toBe("SELECT `id` FROM `User` WHERE `name` = 'something' AND `creatorId` = 123 LIMIT 1");
495
+ expect(this.dialect.find(test_1.User, {
496
+ $project: ['id', 'name', 'creatorId'],
497
+ $limit: 25,
498
+ })).toBe('SELECT `id`, `name`, `creatorId` FROM `User` LIMIT 25');
499
+ }
500
+ shouldFind$skip() {
501
+ expect(this.dialect.find(test_1.User, {
502
+ $project: { id: 1, name: 1, creatorId: 1 },
503
+ $skip: 30,
504
+ })).toBe('SELECT `id`, `name`, `creatorId` FROM `User` OFFSET 30');
505
+ }
506
+ shouldFind$project() {
507
+ expect(this.dialect.find(test_1.User, {
508
+ $project: { password: false },
509
+ })).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `name`, `email` FROM `User`');
510
+ expect(this.dialect.find(test_1.User, {
511
+ $project: { name: 0, password: 0 },
512
+ })).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `email` FROM `User`');
513
+ expect(this.dialect.find(test_1.User, {
514
+ $project: { id: 1, name: 1, password: 0 },
515
+ })).toBe('SELECT `id`, `name` FROM `User`');
516
+ expect(this.dialect.find(test_1.User, {
517
+ $project: { id: 1, name: 0, password: 0 },
518
+ })).toBe('SELECT `id` FROM `User`');
519
+ expect(this.dialect.find(test_1.User, {
520
+ $project: [(0, util_1.raw)('*'), (0, util_1.raw)('LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt', 'hotness')],
521
+ $filter: { name: 'something' },
522
+ })).toBe("SELECT *, LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt `hotness` FROM `User` WHERE `name` = 'something'");
523
+ }
524
+ shouldDelete() {
525
+ expect(this.dialect.delete(test_1.User, { $filter: 123 })).toBe('DELETE FROM `User` WHERE `id` = 123');
526
+ expect(() => this.dialect.delete(test_1.User, { $filter: 123 }, { softDelete: true })).toThrow("'User' has not enabled 'softDelete'");
527
+ expect(this.dialect.delete(test_1.User, { $filter: 123 }, { softDelete: false })).toBe('DELETE FROM `User` WHERE `id` = 123');
528
+ expect(this.dialect.delete(test_1.MeasureUnit, { $filter: 123 })).toMatch(/^UPDATE `MeasureUnit` SET `deletedAt` = \d+ WHERE `id` = 123 AND `deletedAt` IS NULL$/);
529
+ expect(this.dialect.delete(test_1.MeasureUnit, { $filter: 123 }, { softDelete: true })).toMatch(/^UPDATE `MeasureUnit` SET `deletedAt` = \d+ WHERE `id` = 123 AND `deletedAt` IS NULL$/);
530
+ expect(this.dialect.delete(test_1.MeasureUnit, { $filter: 123 }, { softDelete: false })).toBe('DELETE FROM `MeasureUnit` WHERE `id` = 123');
531
+ }
532
+ shouldFind$projectRaw() {
533
+ expect(this.dialect.find(test_1.Item, {
534
+ $project: {
535
+ companyId: true,
536
+ total: (0, util_1.raw)(({ escapedPrefix, dialect }) => `SUM(${escapedPrefix}${dialect.escapeId('salePrice')})`),
537
+ },
538
+ $group: ['companyId'],
539
+ })).toBe('SELECT `companyId`, SUM(`salePrice`) `total` FROM `Item` GROUP BY `companyId`');
540
+ expect(this.dialect.find(test_1.ItemAdjustment, {
541
+ $project: {
542
+ item: {
543
+ $project: {
544
+ companyId: true,
545
+ total: (0, util_1.raw)(({ escapedPrefix, dialect }) => `SUM(${escapedPrefix}${dialect.escapeId('salePrice')})`),
546
+ },
547
+ $required: true,
548
+ },
549
+ },
550
+ $group: ['companyId'],
551
+ })).toBe('SELECT `ItemAdjustment`.`id`, `item`.`id` `item.id`, `item`.`companyId` `item.companyId`, SUM(`item`.`salePrice`) `item.total`' +
552
+ ' FROM `ItemAdjustment` INNER JOIN `Item` `item` ON `item`.`id` = `ItemAdjustment`.`itemId` GROUP BY `companyId`');
553
+ expect(this.dialect.find(test_1.User, {
554
+ $project: ['companyId', (0, util_1.raw)('COUNT(*)', 'count')],
555
+ $group: ['companyId'],
556
+ $having: {
557
+ count: {
558
+ $gte: 10,
559
+ },
560
+ },
561
+ })).toBe('SELECT `companyId`, COUNT(*) `count` FROM `User` GROUP BY `companyId` HAVING `count` >= 10');
562
+ expect(this.dialect.find(test_1.User, {
563
+ $project: [(0, util_1.raw)(() => 'createdAt', 'hotness')],
564
+ $filter: { name: 'something' },
565
+ })).toBe("SELECT createdAt `hotness` FROM `User` WHERE `name` = 'something'");
566
+ expect(this.dialect.find(test_1.User, {
567
+ $project: [(0, util_1.raw)('*'), (0, util_1.raw)('LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt', 'hotness')],
568
+ $filter: { name: 'something' },
569
+ })).toBe("SELECT *, LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt `hotness` FROM `User` WHERE `name` = 'something'");
570
+ }
571
+ shouldFind$filterRaw() {
572
+ expect(this.dialect.find(test_1.Item, {
573
+ $project: ['id'],
574
+ $filter: { $and: [{ companyId: 1 }, (0, util_1.raw)('SUM(salePrice) > 500')] },
575
+ $group: ['creatorId'],
576
+ })).toBe('SELECT `id` FROM `Item` WHERE `companyId` = 1 AND SUM(salePrice) > 500 GROUP BY `creatorId`');
577
+ expect(this.dialect.find(test_1.Item, {
578
+ $project: ['id'],
579
+ $filter: { $or: [{ companyId: 1 }, 5, (0, util_1.raw)('SUM(salePrice) > 500')] },
580
+ })).toBe('SELECT `id` FROM `Item` WHERE `companyId` = 1 OR `id` = 5 OR SUM(salePrice) > 500');
581
+ expect(this.dialect.find(test_1.Item, {
582
+ $project: ['id'],
583
+ $filter: { $and: [(0, util_1.raw)('SUM(`salePrice`) > 500')] },
584
+ $group: ['companyId'],
585
+ })).toBe('SELECT `id` FROM `Item` WHERE SUM(`salePrice`) > 500 GROUP BY `companyId`');
586
+ expect(this.dialect.find(test_1.Item, {
587
+ $project: ['id'],
588
+ $filter: { $or: [1, (0, util_1.raw)('SUM(salePrice) > 500')] },
589
+ })).toBe('SELECT `id` FROM `Item` WHERE `id` = 1 OR SUM(salePrice) > 500');
590
+ expect(this.dialect.find(test_1.Item, {
591
+ $project: ['id'],
592
+ $filter: { $or: [(0, util_1.raw)('SUM(salePrice) > 500'), 1, { companyId: 1 }] },
593
+ })).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 OR `id` = 1 OR `companyId` = 1');
594
+ expect(this.dialect.find(test_1.Item, {
595
+ $project: ['id'],
596
+ $filter: { $and: [(0, util_1.raw)('SUM(salePrice) > 500')] },
597
+ $group: ['creatorId'],
598
+ })).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 GROUP BY `creatorId`');
599
+ expect(this.dialect.find(test_1.Item, {
600
+ $project: ['id'],
601
+ $filter: (0, util_1.raw)('SUM(salePrice) > 500'),
602
+ $group: ['creatorId'],
603
+ })).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 GROUP BY `creatorId`');
604
+ expect(this.dialect.find(test_1.Item, {
605
+ $project: ['id'],
606
+ $filter: { $or: [[1, 2], { code: 'abc' }] },
607
+ $group: ['creatorId'],
608
+ })).toBe("SELECT `id` FROM `Item` WHERE `id` IN (1, 2) OR `code` = 'abc' GROUP BY `creatorId`");
609
+ }
610
+ shouldFind$startsWith() {
611
+ expect(this.dialect.find(test_1.User, {
612
+ $project: ['id'],
613
+ $filter: { name: { $startsWith: 'Some' } },
614
+ $sort: [
615
+ { field: 'name', sort: 'asc' },
616
+ { field: 'createdAt', sort: 'desc' },
617
+ ],
618
+ $skip: 0,
619
+ $limit: 50,
620
+ })).toBe("SELECT `id` FROM `User` WHERE `name` LIKE 'Some%' ORDER BY `name`, `createdAt` DESC LIMIT 50 OFFSET 0");
621
+ expect(this.dialect.find(test_1.User, {
622
+ $project: { id: true },
623
+ $filter: { name: { $startsWith: 'Some', $ne: 'Something' } },
624
+ $sort: { name: 1, id: -1 },
625
+ $skip: 0,
626
+ $limit: 50,
627
+ })).toBe("SELECT `id` FROM `User` WHERE (`name` LIKE 'Some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
628
+ }
629
+ shouldFind$istartsWith() {
630
+ expect(this.dialect.find(test_1.User, {
631
+ $project: ['id'],
632
+ $filter: { name: { $istartsWith: 'Some' } },
633
+ $sort: { name: 1, id: -1 },
634
+ $skip: 0,
635
+ $limit: 50,
636
+ })).toBe("SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE 'some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
637
+ expect(this.dialect.find(test_1.User, {
638
+ $project: { id: true },
639
+ $filter: { name: { $istartsWith: 'Some', $ne: 'Something' } },
640
+ $sort: { name: 1, id: -1 },
641
+ $skip: 0,
642
+ $limit: 50,
643
+ })).toBe("SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE 'some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
644
+ }
645
+ shouldFind$endsWith() {
646
+ expect(this.dialect.find(test_1.User, {
647
+ $project: ['id'],
648
+ $filter: { name: { $endsWith: 'Some' } },
649
+ $sort: { name: 1, id: -1 },
650
+ $skip: 0,
651
+ $limit: 50,
652
+ })).toBe("SELECT `id` FROM `User` WHERE `name` LIKE '%Some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
653
+ expect(this.dialect.find(test_1.User, {
654
+ $project: ['id'],
655
+ $filter: { name: { $endsWith: 'Some', $ne: 'Something' } },
656
+ $sort: { name: 1, id: -1 },
657
+ $skip: 0,
658
+ $limit: 50,
659
+ })).toBe("SELECT `id` FROM `User` WHERE (`name` LIKE '%Some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
660
+ }
661
+ shouldFind$iendsWith() {
662
+ expect(this.dialect.find(test_1.User, {
663
+ $project: ['id'],
664
+ $filter: { name: { $iendsWith: 'Some' } },
665
+ $sort: { name: 1, id: -1 },
666
+ $skip: 0,
667
+ $limit: 50,
668
+ })).toBe("SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE '%some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
669
+ expect(this.dialect.find(test_1.User, {
670
+ $project: ['id'],
671
+ $filter: { name: { $iendsWith: 'Some', $ne: 'Something' } },
672
+ $sort: { name: 1, id: -1 },
673
+ $skip: 0,
674
+ $limit: 50,
675
+ })).toBe("SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE '%some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
676
+ }
677
+ shouldFind$includes() {
678
+ expect(this.dialect.find(test_1.User, {
679
+ $project: ['id'],
680
+ $filter: { name: { $includes: 'Some' } },
681
+ $sort: { name: 1, id: -1 },
682
+ $skip: 0,
683
+ $limit: 50,
684
+ })).toBe("SELECT `id` FROM `User` WHERE `name` LIKE '%Some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
685
+ expect(this.dialect.find(test_1.User, {
686
+ $project: ['id'],
687
+ $filter: { name: { $includes: 'Some', $ne: 'Something' } },
688
+ $sort: { name: 1, id: -1 },
689
+ $skip: 0,
690
+ $limit: 50,
691
+ })).toBe("SELECT `id` FROM `User` WHERE (`name` LIKE '%Some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
692
+ }
693
+ shouldFind$iincludes() {
694
+ expect(this.dialect.find(test_1.User, {
695
+ $project: ['id'],
696
+ $filter: { name: { $iincludes: 'Some' } },
697
+ $sort: { name: 1, id: -1 },
698
+ $skip: 0,
699
+ $limit: 50,
700
+ })).toBe("SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE '%some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
701
+ expect(this.dialect.find(test_1.User, {
702
+ $project: ['id'],
703
+ $filter: { name: { $iincludes: 'Some', $ne: 'Something' } },
704
+ $sort: { name: 1, id: -1 },
705
+ $skip: 0,
706
+ $limit: 50,
707
+ })).toBe("SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE '%some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
708
+ }
709
+ shouldFind$like() {
710
+ expect(this.dialect.find(test_1.User, {
711
+ $project: ['id'],
712
+ $filter: { name: { $like: 'Some' } },
713
+ $sort: { name: 1, id: -1 },
714
+ $skip: 0,
715
+ $limit: 50,
716
+ })).toBe("SELECT `id` FROM `User` WHERE `name` LIKE 'Some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
717
+ expect(this.dialect.find(test_1.User, {
718
+ $project: { id: true },
719
+ $filter: { name: { $like: 'Some', $ne: 'Something' } },
720
+ $sort: { name: 1, id: -1 },
721
+ $skip: 0,
722
+ $limit: 50,
723
+ })).toBe("SELECT `id` FROM `User` WHERE (`name` LIKE 'Some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
724
+ }
725
+ shouldFind$ilike() {
726
+ expect(this.dialect.find(test_1.User, {
727
+ $project: ['id'],
728
+ $filter: { name: { $ilike: 'Some' } },
729
+ $sort: { name: 1, id: -1 },
730
+ $skip: 0,
731
+ $limit: 50,
732
+ })).toBe("SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE 'some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
733
+ expect(this.dialect.find(test_1.User, {
734
+ $project: { id: true },
735
+ $filter: { name: { $ilike: 'Some', $ne: 'Something' } },
736
+ $sort: { name: 1, id: -1 },
737
+ $skip: 0,
738
+ $limit: 50,
739
+ })).toBe("SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE 'some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0");
740
+ }
741
+ shouldFind$regex() {
742
+ expect(this.dialect.find(test_1.User, {
743
+ $project: ['id'],
744
+ $filter: { name: { $regex: '^some' } },
745
+ })).toBe("SELECT `id` FROM `User` WHERE `name` REGEXP '^some'");
746
+ }
747
+ shouldFind$text() {
748
+ expect(this.dialect.find(test_1.Item, {
749
+ $project: { id: true },
750
+ $filter: { $text: { $fields: ['name', 'description'], $value: 'some text' }, companyId: 1 },
751
+ $limit: 30,
752
+ })).toBe("SELECT `id` FROM `Item` WHERE `Item` MATCH {`name` `description`} : 'some text' AND `companyId` = 1 LIMIT 30");
753
+ expect(this.dialect.find(test_1.User, {
754
+ $project: { id: 1 },
755
+ $filter: {
756
+ $text: { $fields: ['name'], $value: 'something' },
757
+ name: { $ne: 'other unwanted' },
758
+ companyId: 1,
759
+ },
760
+ $limit: 10,
761
+ })).toBe("SELECT `id` FROM `User` WHERE `User` MATCH {`name`} : 'something' AND `name` <> 'other unwanted' AND `companyId` = 1 LIMIT 10");
762
+ }
763
+ }
764
+ exports.AbstractSqlDialectSpec = AbstractSqlDialectSpec;
765
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractSqlDialect-spec.js","sourceRoot":"","sources":["../../src/dialect/abstractSqlDialect-spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { Spec, User, Item, ItemAdjustment, TaxCategory, Profile, InventoryAdjustment, MeasureUnit, Company, Tax } from '@uql/core/test';\n\nimport { FieldKey, QueryFilter } from '@uql/core/type';\nimport { raw } from '@uql/core/util';\nimport { AbstractSqlDialect } from './abstractSqlDialect';\n\nexport abstract class AbstractSqlDialectSpec implements Spec {\n  constructor(readonly dialect: AbstractSqlDialect) {}\n\n  shouldBeValidEscapeCharacter() {\n    expect(this.dialect.escapeIdChar).toBe('`');\n  }\n\n  shouldBeginTransaction() {\n    expect(this.dialect.beginTransactionCommand).toBe('BEGIN TRANSACTION');\n  }\n\n  shouldInsertMany() {\n    expect(\n      this.dialect.insert(User, [\n        {\n          name: 'Some name 1',\n          email: 'someemail1@example.com',\n          createdAt: 123,\n        },\n        {\n          name: 'Some name 2',\n          email: 'someemail2@example.com',\n          createdAt: 456,\n        },\n        {\n          name: 'Some name 3',\n          email: 'someemail3@example.com',\n          createdAt: 789,\n        },\n      ])\n    ).toBe(\n      'INSERT INTO `User` (`name`, `email`, `createdAt`) VALUES' +\n        \" ('Some name 1', 'someemail1@example.com', 123)\" +\n        \", ('Some name 2', 'someemail2@example.com', 456)\" +\n        \", ('Some name 3', 'someemail3@example.com', 789)\"\n    );\n  }\n\n  shouldInsertOne() {\n    expect(\n      this.dialect.insert(User, {\n        name: 'Some Name',\n        email: 'someemail@example.com',\n        createdAt: 123,\n      })\n    ).toBe(\"INSERT INTO `User` (`name`, `email`, `createdAt`) VALUES ('Some Name', 'someemail@example.com', 123)\");\n\n    expect(\n      this.dialect.insert(InventoryAdjustment, {\n        date: new Date(2021, 11, 31, 23, 59, 59, 999),\n        createdAt: 123,\n      })\n    ).toBe(\"INSERT INTO `InventoryAdjustment` (`date`, `createdAt`) VALUES ('2021-12-31 23:59:59.999', 123)\");\n  }\n\n  shouldInsertWithOnInsertId() {\n    expect(\n      this.dialect.insert(TaxCategory, {\n        name: 'Some Name',\n        createdAt: 123,\n      })\n    ).toMatch(/^INSERT INTO `TaxCategory` \\(`name`, `createdAt`, `pk`\\) VALUES \\('Some Name', 123, '.+'\\)$/);\n  }\n\n  shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {\n    expect(\n      this.dialect.insert(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    ).toMatch(\n      /^INSERT INTO `TaxCategory` \\(`name`, `createdAt`, `pk`\\) VALUES \\('Some Name A', \\d+, '.+'\\), \\('Some Name B', \\d+, '50'\\), \\('Some Name C', \\d+, '.+'\\), \\('Some Name D', \\d+, '70'\\)$/\n    );\n  }\n\n  shouldUpdate() {\n    expect(\n      this.dialect.update(\n        User,\n        { $filter: { name: 'some', creatorId: 123 } },\n        {\n          name: 'Some Text',\n          updatedAt: 321,\n        }\n      )\n    ).toBe(\"UPDATE `User` SET `name` = 'Some Text', `updatedAt` = 321 WHERE `name` = 'some' AND `creatorId` = 123\");\n  }\n\n  shouldFind() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { id: 123, name: 'abc' },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'\");\n\n    expect(\n      this.dialect.find(Profile, {\n        $project: ['id', 'picture', 'companyId'],\n        $filter: { id: 123, picture: 'abc' },\n      })\n    ).toBe(\"SELECT `pk` `id`, `image` `picture`, `companyId` FROM `user_profile` WHERE `pk` = 123 AND `image` = 'abc'\");\n\n    expect(\n      this.dialect.find(MeasureUnit, {\n        $project: ['id'],\n        $filter: { id: 123, name: 'abc' },\n      })\n    ).toBe(\"SELECT `id` FROM `MeasureUnit` WHERE `id` = 123 AND `name` = 'abc' AND `deletedAt` IS NULL\");\n  }\n\n  shouldBeSecure() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id', 'something' as FieldKey<User>],\n        $filter: {\n          id: 1,\n          something: 1,\n        } as any,\n        $sort: {\n          id: 1,\n          something: 1,\n        } as any,\n        $group: ['id', 'something' as any],\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE `id` = 1 AND `something` = 1 GROUP BY `id`, `something` ORDER BY `id`, `something`');\n\n    expect(\n      this.dialect.insert(User, {\n        name: 'Some Name',\n        something: 'anything',\n        createdAt: 1,\n      } as any)\n    ).toBe(\"INSERT INTO `User` (`name`, `createdAt`) VALUES ('Some Name', 1)\");\n\n    expect(\n      this.dialect.update(\n        User,\n        {\n          $filter: { something: 'anything' },\n        },\n        {\n          name: 'Some Name',\n          something: 'anything',\n          updatedAt: 1,\n        } as any\n      )\n    ).toBe(\"UPDATE `User` SET `name` = 'Some Name', `updatedAt` = 1 WHERE `something` = 'anything'\");\n\n    expect(\n      this.dialect.delete(User, {\n        $filter: { something: 'anything' } as any,\n      })\n    ).toBe(\"DELETE FROM `User` WHERE `something` = 'anything'\");\n  }\n\n  shouldFind$and() {\n    const sql = \"SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'\";\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $and: [{ id: 123, name: 'abc' }] },\n      })\n    ).toBe(sql);\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1 },\n        $filter: { $and: [{ id: 123 }], name: 'abc' },\n      })\n    ).toBe(sql);\n  }\n\n  shouldFind$or() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $or: [{ id: 123 }, { name: 'abc' }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `id` = 123 OR `name` = 'abc'\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $or: [{ id: 123 }] },\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE `id` = 123');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1 },\n        $filter: { $or: [{ id: 123, name: 'abc' }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $or: [{ id: 123 }], name: 'abc' },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `id` = 123 AND `name` = 'abc'\");\n  }\n\n  shouldFind$not() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $not: [{ name: 'Some' }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT `name` = 'Some'\");\n\n    expect(\n      this.dialect.find(Company, {\n        $project: ['id'],\n        $filter: { id: { $not: 123 } },\n      })\n    ).toBe('SELECT `id` FROM `Company` WHERE NOT `id` = 123');\n\n    expect(\n      this.dialect.find(Company, {\n        $project: ['id'],\n        $filter: { id: { $not: [123, 456] } },\n      })\n    ).toBe('SELECT `id` FROM `Company` WHERE NOT `id` IN (123, 456)');\n\n    expect(\n      this.dialect.find(Company, {\n        $project: ['id'],\n        $filter: { id: 123, name: { $not: { $startsWith: 'a' } } },\n      })\n    ).toBe(\"SELECT `id` FROM `Company` WHERE `id` = 123 AND NOT `name` LIKE 'a%'\");\n\n    expect(\n      this.dialect.find(Company, {\n        $project: ['id'],\n        $filter: { name: { $not: { $startsWith: 'a', $endsWith: 'z' } } },\n      })\n    ).toBe(\"SELECT `id` FROM `Company` WHERE NOT (`name` LIKE 'a%' AND `name` LIKE '%z')\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { $not: [{ name: { $like: 'Some', $ne: 'Something' } }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT (`name` LIKE 'Some' AND `name` <> 'Something')\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { $not: [{ name: 'abc' }, { creatorId: 1 }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT (`name` = 'abc' AND `creatorId` = 1)\");\n\n    expect(\n      this.dialect.find(Tax, {\n        $project: ['id'],\n        $filter: { companyId: 1, name: { $not: { $startsWith: 'a' } } },\n      })\n    ).toBe(\"SELECT `id` FROM `Tax` WHERE `companyId` = 1 AND NOT `name` LIKE 'a%'\");\n  }\n\n  shouldFind$nor() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $nor: [{ name: 'Some' }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT `name` = 'Some'\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { $nor: [{ name: { $like: 'Some', $ne: 'Something' } }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT (`name` LIKE 'Some' AND `name` <> 'Something')\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { $nor: [{ name: 'abc' }, { creatorId: 1 }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE NOT (`name` = 'abc' OR `creatorId` = 1)\");\n  }\n\n  shouldFind$orAnd$and() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { creatorId: 1, $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }], id: 1 },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `creatorId` = 1 AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com') AND `id` = 1\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: {\n          creatorId: 1,\n          $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }],\n          id: 1,\n          email: 'e',\n        },\n      })\n    ).toBe(\n      'SELECT `id` FROM `User` WHERE `creatorId` = 1' +\n        \" AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com') AND `id` = 1 AND `email` = 'e'\"\n    );\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: {\n          creatorId: 1,\n          $or: [{ name: ['a', 'b', 'c'] }, { email: 'abc@example.com' }],\n          id: 1,\n          email: 'e',\n        },\n        $sort: { name: 1, createdAt: -1 },\n        $skip: 50,\n        $limit: 10,\n      })\n    ).toBe(\n      'SELECT `id` FROM `User` WHERE `creatorId` = 1' +\n        \" AND (`name` IN ('a', 'b', 'c') OR `email` = 'abc@example.com')\" +\n        \" AND `id` = 1 AND `email` = 'e'\" +\n        ' ORDER BY `name`, `createdAt` DESC LIMIT 10 OFFSET 50'\n    );\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: {\n          $or: [\n            {\n              creatorId: 1,\n              id: 1,\n              email: 'e',\n            },\n            { name: ['a', 'b', 'c'], email: 'abc@example.com' },\n          ],\n        },\n        $sort: [\n          { field: 'name', sort: 'asc' },\n          { field: 'createdAt', sort: 'desc' },\n        ],\n        $skip: 50,\n        $limit: 10,\n      })\n    ).toBe(\n      \"SELECT `id` FROM `User` WHERE (`creatorId` = 1 AND `id` = 1 AND `email` = 'e')\" +\n        \" OR (`name` IN ('a', 'b', 'c') AND `email` = 'abc@example.com')\" +\n        ' ORDER BY `name`, `createdAt` DESC LIMIT 10 OFFSET 50'\n    );\n  }\n\n  shouldFindSingle$filter() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'some' },\n        $limit: 3,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` = 'some' LIMIT 3\");\n  }\n\n  shouldFindMultipleComparisonOperators() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { $or: [{ name: { $eq: 'other', $ne: 'other unwanted' } }, { companyId: 1 }] },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (`name` = 'other' AND `name` <> 'other unwanted') OR `companyId` = 1\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { createdAt: { $gte: 123, $lte: 999 } },\n        $limit: 10,\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE (`createdAt` >= 123 AND `createdAt` <= 999) LIMIT 10');\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { createdAt: { $gt: 123, $lt: 999 } },\n        $limit: 10,\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE (`createdAt` > 123 AND `createdAt` < 999) LIMIT 10');\n  }\n\n  shouldFind$ne() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'some', companyId: { $ne: 5 } },\n        $limit: 20,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` <> 5 LIMIT 20\");\n  }\n\n  shouldFindIsNull() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { creatorId: 123, companyId: null },\n        $limit: 5,\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 123 AND `companyId` IS NULL LIMIT 5');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { creatorId: 123, companyId: { $ne: null } },\n        $limit: 5,\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE `creatorId` = 123 AND `companyId` IS NOT NULL LIMIT 5');\n  }\n\n  shouldFind$in() {\n    const sql = \"SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` IN (1, 2, 3) LIMIT 10\";\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'some', companyId: [1, 2, 3] },\n        $limit: 10,\n      })\n    ).toBe(sql);\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'some', companyId: { $in: [1, 2, 3] } },\n        $limit: 10,\n      })\n    ).toBe(sql);\n  }\n\n  shouldFind$nin() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'some', companyId: { $nin: [1, 2, 3] } },\n        $limit: 10,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` = 'some' AND `companyId` NOT IN (1, 2, 3) LIMIT 10\");\n  }\n\n  shouldFind$projectFields() {\n    expect(this.dialect.find(User, { $project: { id: true, company: true } })).toBe(\n      'SELECT `User`.`id`, `company`.`id` `company.id`, `company`.`companyId` `company.companyId`, `company`.`creatorId` `company.creatorId`' +\n        ', `company`.`createdAt` `company.createdAt`, `company`.`updatedAt` `company.updatedAt`' +\n        ', `company`.`name` `company.name`, `company`.`description` `company.description`' +\n        ' FROM `User` LEFT JOIN `Company` `company` ON `company`.`id` = `User`.`companyId`'\n    );\n  }\n\n  shouldFind$projectOneToOne() {\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true, name: true, profile: ['id', 'picture'] },\n      })\n    ).toBe(\n      'SELECT `User`.`id`, `User`.`name`, `profile`.`pk` `profile.id`, `profile`.`image` `profile.picture` FROM `User`' +\n        ' LEFT JOIN `user_profile` `profile` ON `profile`.`creatorId` = `User`.`id`'\n    );\n\n    expect(this.dialect.find(User, { $project: { profile: true } })).toBe(\n      'SELECT `User`.`id`, `profile`.`companyId` `profile.companyId`' +\n        ', `profile`.`creatorId` `profile.creatorId`, `profile`.`createdAt` `profile.createdAt`' +\n        ', `profile`.`updatedAt` `profile.updatedAt`' +\n        ', `profile`.`pk` `profile.id`, `profile`.`image` `profile.picture`' +\n        ' FROM `User` LEFT JOIN `user_profile` `profile` ON `profile`.`creatorId` = `User`.`id`'\n    );\n  }\n\n  shouldFind$projectManyToOne() {\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: true,\n          name: true,\n          code: true,\n          tax: { $project: ['id', 'name'], $required: true },\n          measureUnit: { $project: ['id', 'name', 'categoryId'] },\n        },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +\n        ', `tax`.`id` `tax.id`, `tax`.`name` `tax.name`' +\n        ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +\n        ' FROM `Item`' +\n        ' INNER JOIN `Tax` `tax` ON `tax`.`id` = `Item`.`taxId`' +\n        ' LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +\n        ' LIMIT 100'\n    );\n  }\n\n  shouldFind$projectWithAllFieldsAndSpecificFieldsAndFilter() {\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: true,\n          name: true,\n          measureUnit: { $project: ['id', 'name'], $filter: { name: { $ne: 'unidad' } }, $required: true },\n          tax: ['id', 'name'],\n        },\n        $filter: { salePrice: { $gte: 1000 }, name: { $istartsWith: 'A' } },\n        $sort: { tax: { name: 1 }, measureUnit: { name: 1 }, createdAt: -1 },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `Item`.`id`, `Item`.`name`' +\n        ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`' +\n        ', `tax`.`id` `tax.id`, `tax`.`name` `tax.name`' +\n        ' FROM `Item`' +\n        \" INNER JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId` AND `measureUnit`.`name` <> 'unidad' AND `measureUnit`.`deletedAt` IS NULL\" +\n        ' LEFT JOIN `Tax` `tax` ON `tax`.`id` = `Item`.`taxId`' +\n        \" WHERE `Item`.`salePrice` >= 1000 AND LOWER(`Item`.`name`) LIKE 'a%'\" +\n        ' ORDER BY `tax`.`name`, `measureUnit`.`name`, `Item`.`createdAt` DESC LIMIT 100'\n    );\n  }\n\n  shouldVirtualField() {\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: 1,\n        },\n        $filter: {\n          tagsCount: { $gte: 10 },\n        },\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE (SELECT COUNT(*) `count` FROM `ItemTag` WHERE `ItemTag`.`itemId` = `id`) >= 10');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: 1,\n          name: 1,\n          code: 1,\n          tagsCount: 1,\n          measureUnit: {\n            $project: { id: 1, name: 1, categoryId: 1, category: ['name'] },\n          },\n        },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +\n        ', (SELECT COUNT(*) `count` FROM `ItemTag` WHERE `ItemTag`.`itemId` = `Item`.`id`) `tagsCount`' +\n        ', `measureUnit`.`id` `measureUnit.id`, `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +\n        ', `measureUnit.category`.`id` `measureUnit.category.id`, `measureUnit.category`.`name` `measureUnit.category.name`' +\n        ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +\n        ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +\n        ' LIMIT 100'\n    );\n  }\n\n  shouldFind$projectDeep() {\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: 1,\n          name: 1,\n          code: 1,\n          measureUnit: {\n            $project: { id: 1, name: 1, categoryId: 1, category: ['name'] },\n          },\n        },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`' +\n        ', `measureUnit`.`id` `measureUnit.id`' +\n        ', `measureUnit`.`name` `measureUnit.name`, `measureUnit`.`categoryId` `measureUnit.categoryId`' +\n        ', `measureUnit.category`.`id` `measureUnit.category.id`, `measureUnit.category`.`name` `measureUnit.category.name`' +\n        ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +\n        ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +\n        ' LIMIT 100'\n    );\n\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          id: true,\n          name: true,\n          code: true,\n          measureUnit: {\n            $project: { id: true, name: true, category: { $project: { id: true, name: true } } },\n          },\n        },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `Item`.`id`, `Item`.`name`, `Item`.`code`, `measureUnit`.`id` `measureUnit.id`' +\n        ', `measureUnit`.`name` `measureUnit.name`, `measureUnit.category`.`id` `measureUnit.category.id`' +\n        ', `measureUnit.category`.`name` `measureUnit.category.name`' +\n        ' FROM `Item` LEFT JOIN `MeasureUnit` `measureUnit` ON `measureUnit`.`id` = `Item`.`measureUnitId`' +\n        ' LEFT JOIN `MeasureUnitCategory` `measureUnit.category` ON `measureUnit.category`.`id` = `measureUnit`.`categoryId`' +\n        ' LIMIT 100'\n    );\n\n    expect(\n      this.dialect.find(ItemAdjustment, {\n        $project: {\n          id: true,\n          buyPrice: true,\n          number: true,\n          item: {\n            $project: {\n              id: true,\n              name: true,\n              measureUnit: {\n                $project: { id: true, name: true, category: ['id', 'name'] },\n              },\n            },\n            $required: true,\n          },\n        },\n        $limit: 100,\n      })\n    ).toBe(\n      'SELECT `ItemAdjustment`.`id`, `ItemAdjustment`.`buyPrice`, `ItemAdjustment`.`number`' +\n        ', `item`.`id` `item.id`, `item`.`name` `item.name`' +\n        ', `item.measureUnit`.`id` `item.measureUnit.id`, `item.measureUnit`.`name` `item.measureUnit.name`' +\n        ', `item.measureUnit.category`.`id` `item.measureUnit.category.id`, `item.measureUnit.category`.`name` `item.measureUnit.category.name`' +\n        ' FROM `ItemAdjustment`' +\n        ' INNER JOIN `Item` `item` ON `item`.`id` = `ItemAdjustment`.`itemId`' +\n        ' LEFT JOIN `MeasureUnit` `item.measureUnit` ON `item.measureUnit`.`id` = `item`.`measureUnitId`' +\n        ' LEFT JOIN `MeasureUnitCategory` `item.measureUnit.category` ON `item.measureUnit.category`.`id` = `item.measureUnit`.`categoryId`' +\n        ' LIMIT 100'\n    );\n  }\n\n  shouldFind$group() {\n    expect(\n      this.dialect.find(User, {\n        $group: ['companyId'],\n      })\n    ).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `name`, `email`, `password` FROM `User` GROUP BY `companyId`');\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['companyId', raw('COUNT(*)', 'count')],\n        $group: ['companyId'],\n        $having: {\n          count: {\n            $gte: 10,\n          },\n        } as QueryFilter<User>,\n      })\n    ).toBe('SELECT `companyId`, COUNT(*) `count` FROM `User` GROUP BY `companyId` HAVING `count` >= 10');\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id', 'name'],\n        $filter: { companyId: 1 },\n        $group: ['companyId'],\n        $skip: 50,\n        $limit: 100,\n        $sort: { name: 'desc' },\n      })\n    ).toBe('SELECT `id`, `name` FROM `User` WHERE `companyId` = 1 GROUP BY `companyId` ORDER BY `name` DESC LIMIT 100 OFFSET 50');\n  }\n\n  shouldFind$limit() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: 9,\n        $limit: 1,\n      })\n    ).toBe('SELECT `id` FROM `User` WHERE `id` = 9 LIMIT 1');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1, name: 1, creatorId: 1 },\n        $filter: 9,\n        $limit: 1,\n      })\n    ).toBe('SELECT `id`, `name`, `creatorId` FROM `User` WHERE `id` = 9 LIMIT 1');\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: 'something', creatorId: 123 },\n        $limit: 1,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` = 'something' AND `creatorId` = 123 LIMIT 1\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id', 'name', 'creatorId'],\n        $limit: 25,\n      })\n    ).toBe('SELECT `id`, `name`, `creatorId` FROM `User` LIMIT 25');\n  }\n\n  shouldFind$skip() {\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1, name: 1, creatorId: 1 },\n        $skip: 30,\n      })\n    ).toBe('SELECT `id`, `name`, `creatorId` FROM `User` OFFSET 30');\n  }\n\n  shouldFind$project() {\n    expect(\n      this.dialect.find(User, {\n        $project: { password: false },\n      })\n    ).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `name`, `email` FROM `User`');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { name: 0, password: 0 },\n      })\n    ).toBe('SELECT `id`, `companyId`, `creatorId`, `createdAt`, `updatedAt`, `email` FROM `User`');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1, name: 1, password: 0 },\n      })\n    ).toBe('SELECT `id`, `name` FROM `User`');\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1, name: 0, password: 0 },\n      })\n    ).toBe('SELECT `id` FROM `User`');\n\n    expect(\n      this.dialect.find(User, {\n        $project: [raw('*'), raw('LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt', 'hotness')],\n        $filter: { name: 'something' },\n      })\n    ).toBe(\"SELECT *, LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt `hotness` FROM `User` WHERE `name` = 'something'\");\n  }\n\n  shouldDelete() {\n    expect(this.dialect.delete(User, { $filter: 123 })).toBe('DELETE FROM `User` WHERE `id` = 123');\n    expect(() => this.dialect.delete(User, { $filter: 123 }, { softDelete: true })).toThrow(\"'User' has not enabled 'softDelete'\");\n    expect(this.dialect.delete(User, { $filter: 123 }, { softDelete: false })).toBe('DELETE FROM `User` WHERE `id` = 123');\n    expect(this.dialect.delete(MeasureUnit, { $filter: 123 })).toMatch(\n      /^UPDATE `MeasureUnit` SET `deletedAt` = \\d+ WHERE `id` = 123 AND `deletedAt` IS NULL$/\n    );\n    expect(this.dialect.delete(MeasureUnit, { $filter: 123 }, { softDelete: true })).toMatch(\n      /^UPDATE `MeasureUnit` SET `deletedAt` = \\d+ WHERE `id` = 123 AND `deletedAt` IS NULL$/\n    );\n    expect(this.dialect.delete(MeasureUnit, { $filter: 123 }, { softDelete: false })).toBe('DELETE FROM `MeasureUnit` WHERE `id` = 123');\n  }\n\n  shouldFind$projectRaw() {\n    expect(\n      this.dialect.find(Item, {\n        $project: {\n          companyId: true,\n          total: raw(({ escapedPrefix, dialect }) => `SUM(${escapedPrefix}${dialect.escapeId('salePrice')})`),\n        },\n        $group: ['companyId'],\n      })\n    ).toBe('SELECT `companyId`, SUM(`salePrice`) `total` FROM `Item` GROUP BY `companyId`');\n\n    expect(\n      this.dialect.find(ItemAdjustment, {\n        $project: {\n          item: {\n            $project: {\n              companyId: true,\n              total: raw(({ escapedPrefix, dialect }) => `SUM(${escapedPrefix}${dialect.escapeId('salePrice')})`),\n            },\n            $required: true,\n          },\n        },\n        $group: ['companyId'],\n      })\n    ).toBe(\n      'SELECT `ItemAdjustment`.`id`, `item`.`id` `item.id`, `item`.`companyId` `item.companyId`, SUM(`item`.`salePrice`) `item.total`' +\n        ' FROM `ItemAdjustment` INNER JOIN `Item` `item` ON `item`.`id` = `ItemAdjustment`.`itemId` GROUP BY `companyId`'\n    );\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['companyId', raw('COUNT(*)', 'count')],\n        $group: ['companyId'],\n        $having: {\n          count: {\n            $gte: 10,\n          },\n        } as QueryFilter<User>,\n      })\n    ).toBe('SELECT `companyId`, COUNT(*) `count` FROM `User` GROUP BY `companyId` HAVING `count` >= 10');\n\n    expect(\n      this.dialect.find(User, {\n        $project: [raw(() => 'createdAt', 'hotness')],\n        $filter: { name: 'something' },\n      })\n    ).toBe(\"SELECT createdAt `hotness` FROM `User` WHERE `name` = 'something'\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: [raw('*'), raw('LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt', 'hotness')],\n        $filter: { name: 'something' },\n      })\n    ).toBe(\"SELECT *, LOG10(numberOfVotes + 1) * 287014.5873982681 + createdAt `hotness` FROM `User` WHERE `name` = 'something'\");\n  }\n\n  shouldFind$filterRaw() {\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $and: [{ companyId: 1 }, raw('SUM(salePrice) > 500')] },\n        $group: ['creatorId'],\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE `companyId` = 1 AND SUM(salePrice) > 500 GROUP BY `creatorId`');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $or: [{ companyId: 1 }, 5, raw('SUM(salePrice) > 500')] },\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE `companyId` = 1 OR `id` = 5 OR SUM(salePrice) > 500');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $and: [raw('SUM(`salePrice`) > 500')] },\n        $group: ['companyId'],\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE SUM(`salePrice`) > 500 GROUP BY `companyId`');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $or: [1, raw('SUM(salePrice) > 500')] },\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE `id` = 1 OR SUM(salePrice) > 500');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $or: [raw('SUM(salePrice) > 500'), 1, { companyId: 1 }] },\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 OR `id` = 1 OR `companyId` = 1');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $and: [raw('SUM(salePrice) > 500')] },\n        $group: ['creatorId'],\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 GROUP BY `creatorId`');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: raw('SUM(salePrice) > 500'),\n        $group: ['creatorId'],\n      })\n    ).toBe('SELECT `id` FROM `Item` WHERE SUM(salePrice) > 500 GROUP BY `creatorId`');\n\n    expect(\n      this.dialect.find(Item, {\n        $project: ['id'],\n        $filter: { $or: [[1, 2], { code: 'abc' }] },\n        $group: ['creatorId'],\n      })\n    ).toBe(\"SELECT `id` FROM `Item` WHERE `id` IN (1, 2) OR `code` = 'abc' GROUP BY `creatorId`\");\n  }\n\n  shouldFind$startsWith() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $startsWith: 'Some' } },\n        $sort: [\n          { field: 'name', sort: 'asc' },\n          { field: 'createdAt', sort: 'desc' },\n        ],\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` LIKE 'Some%' ORDER BY `name`, `createdAt` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { name: { $startsWith: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (`name` LIKE 'Some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$istartsWith() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $istartsWith: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE 'some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { name: { $istartsWith: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE 'some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$endsWith() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $endsWith: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` LIKE '%Some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $endsWith: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (`name` LIKE '%Some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$iendsWith() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $iendsWith: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE '%some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $iendsWith: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE '%some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$includes() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $includes: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` LIKE '%Some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $includes: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (`name` LIKE '%Some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$iincludes() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $iincludes: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE '%some%' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $iincludes: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE '%some%' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$like() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $like: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` LIKE 'Some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { name: { $like: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (`name` LIKE 'Some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$ilike() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $ilike: 'Some' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE LOWER(`name`) LIKE 'some' ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: true },\n        $filter: { name: { $ilike: 'Some', $ne: 'Something' } },\n        $sort: { name: 1, id: -1 },\n        $skip: 0,\n        $limit: 50,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE (LOWER(`name`) LIKE 'some' AND `name` <> 'Something') ORDER BY `name`, `id` DESC LIMIT 50 OFFSET 0\");\n  }\n\n  shouldFind$regex() {\n    expect(\n      this.dialect.find(User, {\n        $project: ['id'],\n        $filter: { name: { $regex: '^some' } },\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `name` REGEXP '^some'\");\n  }\n\n  shouldFind$text() {\n    expect(\n      this.dialect.find(Item, {\n        $project: { id: true },\n        $filter: { $text: { $fields: ['name', 'description'], $value: 'some text' }, companyId: 1 },\n        $limit: 30,\n      })\n    ).toBe(\"SELECT `id` FROM `Item` WHERE `Item` MATCH {`name` `description`} : 'some text' AND `companyId` = 1 LIMIT 30\");\n\n    expect(\n      this.dialect.find(User, {\n        $project: { id: 1 },\n        $filter: {\n          $text: { $fields: ['name'], $value: 'something' },\n          name: { $ne: 'other unwanted' },\n          companyId: 1,\n        },\n        $limit: 10,\n      })\n    ).toBe(\"SELECT `id` FROM `User` WHERE `User` MATCH {`name`} : 'something' AND `name` <> 'other unwanted' AND `companyId` = 1 LIMIT 10\");\n  }\n}\n"]}