@joktec/mysql 0.2.13 → 0.2.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +419 -79
- package/dist/__tests__/mysql.column.decorator.spec.d.ts +2 -0
- package/dist/__tests__/mysql.column.decorator.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.column.decorator.spec.js +533 -0
- package/dist/__tests__/mysql.column.decorator.spec.js.map +1 -0
- package/dist/__tests__/mysql.dialect.spec.d.ts +2 -0
- package/dist/__tests__/mysql.dialect.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.dialect.spec.js +29 -0
- package/dist/__tests__/mysql.dialect.spec.js.map +1 -0
- package/dist/__tests__/mysql.exception.spec.d.ts +2 -0
- package/dist/__tests__/mysql.exception.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.exception.spec.js +42 -0
- package/dist/__tests__/mysql.exception.spec.js.map +1 -0
- package/dist/__tests__/mysql.helper.spec.d.ts +2 -0
- package/dist/__tests__/mysql.helper.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.helper.spec.js +80 -0
- package/dist/__tests__/mysql.helper.spec.js.map +1 -0
- package/dist/__tests__/mysql.module.integration.spec.d.ts +2 -0
- package/dist/__tests__/mysql.module.integration.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.module.integration.spec.js +67 -0
- package/dist/__tests__/mysql.module.integration.spec.js.map +1 -0
- package/dist/__tests__/mysql.repo.cursor.spec.d.ts +2 -0
- package/dist/__tests__/mysql.repo.cursor.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.repo.cursor.spec.js +146 -0
- package/dist/__tests__/mysql.repo.cursor.spec.js.map +1 -0
- package/dist/__tests__/mysql.service.spec.d.ts +2 -0
- package/dist/__tests__/mysql.service.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.service.spec.js +70 -0
- package/dist/__tests__/mysql.service.spec.js.map +1 -0
- package/dist/__tests__/mysql.utils.spec.d.ts +2 -0
- package/dist/__tests__/mysql.utils.spec.d.ts.map +1 -0
- package/dist/__tests__/mysql.utils.spec.js +21 -0
- package/dist/__tests__/mysql.utils.spec.js.map +1 -0
- package/dist/decorators/column.decorator.d.ts +10 -0
- package/dist/decorators/column.decorator.d.ts.map +1 -0
- package/dist/decorators/column.decorator.js +181 -0
- package/dist/decorators/column.decorator.js.map +1 -0
- package/dist/decorators/columns/array.column.d.ts +3 -0
- package/dist/decorators/columns/array.column.d.ts.map +1 -0
- package/dist/decorators/columns/array.column.js +13 -0
- package/dist/decorators/columns/array.column.js.map +1 -0
- package/dist/decorators/columns/bool.column.d.ts +2 -0
- package/dist/decorators/columns/bool.column.d.ts.map +1 -0
- package/dist/decorators/columns/bool.column.js +8 -0
- package/dist/decorators/columns/bool.column.js.map +1 -0
- package/dist/decorators/columns/column.factory.d.ts +5 -0
- package/dist/decorators/columns/column.factory.d.ts.map +1 -0
- package/dist/decorators/columns/column.factory.js +42 -0
- package/dist/decorators/columns/column.factory.js.map +1 -0
- package/dist/decorators/columns/column.type.d.ts +136 -0
- package/dist/decorators/columns/column.type.d.ts.map +1 -0
- package/dist/decorators/columns/column.type.js +3 -0
- package/dist/decorators/columns/column.type.js.map +1 -0
- package/dist/decorators/columns/column.util.d.ts +22 -0
- package/dist/decorators/columns/column.util.d.ts.map +1 -0
- package/dist/decorators/columns/column.util.js +163 -0
- package/dist/decorators/columns/column.util.js.map +1 -0
- package/dist/decorators/columns/date.column.d.ts +2 -0
- package/dist/decorators/columns/date.column.d.ts.map +1 -0
- package/dist/decorators/columns/date.column.js +8 -0
- package/dist/decorators/columns/date.column.js.map +1 -0
- package/dist/decorators/columns/enum.column.d.ts +3 -0
- package/dist/decorators/columns/enum.column.d.ts.map +1 -0
- package/dist/decorators/columns/enum.column.js +8 -0
- package/dist/decorators/columns/enum.column.js.map +1 -0
- package/dist/decorators/columns/index.d.ts +17 -0
- package/dist/decorators/columns/index.d.ts.map +1 -0
- package/dist/decorators/columns/index.js +33 -0
- package/dist/decorators/columns/index.js.map +1 -0
- package/dist/decorators/columns/nested.column.d.ts +4 -0
- package/dist/decorators/columns/nested.column.d.ts.map +1 -0
- package/dist/decorators/columns/nested.column.js +12 -0
- package/dist/decorators/columns/nested.column.js.map +1 -0
- package/dist/decorators/columns/number.column.d.ts +3 -0
- package/dist/decorators/columns/number.column.d.ts.map +1 -0
- package/dist/decorators/columns/number.column.js +16 -0
- package/dist/decorators/columns/number.column.js.map +1 -0
- package/dist/decorators/columns/object.column.d.ts +4 -0
- package/dist/decorators/columns/object.column.d.ts.map +1 -0
- package/dist/decorators/columns/object.column.js +13 -0
- package/dist/decorators/columns/object.column.js.map +1 -0
- package/dist/decorators/columns/primary.column.d.ts +3 -0
- package/dist/decorators/columns/primary.column.d.ts.map +1 -0
- package/dist/decorators/columns/primary.column.js +48 -0
- package/dist/decorators/columns/primary.column.js.map +1 -0
- package/dist/decorators/columns/string.column.d.ts +3 -0
- package/dist/decorators/columns/string.column.d.ts.map +1 -0
- package/dist/decorators/columns/string.column.js +28 -0
- package/dist/decorators/columns/string.column.js.map +1 -0
- package/dist/decorators/columns/swagger.column.d.ts +4 -0
- package/dist/decorators/columns/swagger.column.d.ts.map +1 -0
- package/dist/decorators/columns/swagger.column.js +49 -0
- package/dist/decorators/columns/swagger.column.js.map +1 -0
- package/dist/decorators/columns/timestamp.column.d.ts +6 -0
- package/dist/decorators/columns/timestamp.column.d.ts.map +1 -0
- package/dist/decorators/columns/timestamp.column.js +55 -0
- package/dist/decorators/columns/timestamp.column.js.map +1 -0
- package/dist/decorators/columns/transform.column.d.ts +4 -0
- package/dist/decorators/columns/transform.column.d.ts.map +1 -0
- package/dist/decorators/columns/transform.column.js +18 -0
- package/dist/decorators/columns/transform.column.js.map +1 -0
- package/dist/decorators/columns/virtual.column.d.ts +4 -0
- package/dist/decorators/columns/virtual.column.d.ts.map +1 -0
- package/dist/decorators/columns/virtual.column.js +23 -0
- package/dist/decorators/columns/virtual.column.js.map +1 -0
- package/dist/decorators/index.d.ts +3 -0
- package/dist/decorators/index.d.ts.map +1 -1
- package/dist/decorators/index.js +2 -0
- package/dist/decorators/index.js.map +1 -1
- package/dist/decorators/table.decorator.d.ts +31 -2
- package/dist/decorators/table.decorator.d.ts.map +1 -1
- package/dist/decorators/table.decorator.js +55 -18
- package/dist/decorators/table.decorator.js.map +1 -1
- package/dist/decorators/timestamp.decorator.d.ts +4 -0
- package/dist/decorators/timestamp.decorator.d.ts.map +1 -0
- package/dist/decorators/timestamp.decorator.js +19 -0
- package/dist/decorators/timestamp.decorator.js.map +1 -0
- package/dist/helpers/index.d.ts +0 -1
- package/dist/helpers/index.d.ts.map +1 -1
- package/dist/helpers/index.js +0 -1
- package/dist/helpers/index.js.map +1 -1
- package/dist/helpers/mysql.helper.d.ts +21 -6
- package/dist/helpers/mysql.helper.d.ts.map +1 -1
- package/dist/helpers/mysql.helper.js +152 -82
- package/dist/helpers/mysql.helper.js.map +1 -1
- package/dist/helpers/mysql.utils.d.ts.map +1 -1
- package/dist/helpers/mysql.utils.js +28 -11
- package/dist/helpers/mysql.utils.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -1
- package/dist/models/mysql.model.d.ts.map +1 -1
- package/dist/models/mysql.model.js +4 -11
- package/dist/models/mysql.model.js.map +1 -1
- package/dist/models/mysql.option.d.ts +11 -2
- package/dist/models/mysql.option.d.ts.map +1 -1
- package/dist/mysql.config.d.ts +1 -17
- package/dist/mysql.config.d.ts.map +1 -1
- package/dist/mysql.config.js +1 -17
- package/dist/mysql.config.js.map +1 -1
- package/dist/mysql.exception.d.ts.map +1 -1
- package/dist/mysql.exception.js +48 -4
- package/dist/mysql.exception.js.map +1 -1
- package/dist/mysql.module.d.ts.map +1 -1
- package/dist/mysql.module.js.map +1 -1
- package/dist/mysql.repo.d.ts +9 -2
- package/dist/mysql.repo.d.ts.map +1 -1
- package/dist/mysql.repo.js +164 -48
- package/dist/mysql.repo.js.map +1 -1
- package/dist/mysql.service.d.ts.map +1 -1
- package/dist/mysql.service.js +8 -2
- package/dist/mysql.service.js.map +1 -1
- package/dist/services/index.d.ts +1 -0
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +1 -0
- package/dist/services/index.js.map +1 -1
- package/dist/services/mysql.dialect.d.ts +14 -0
- package/dist/services/mysql.dialect.d.ts.map +1 -0
- package/dist/services/mysql.dialect.js +50 -0
- package/dist/services/mysql.dialect.js.map +1 -0
- package/dist/services/mysql.strategy.d.ts +1 -1
- package/dist/services/mysql.strategy.d.ts.map +1 -1
- package/dist/services/mysql.strategy.js +1 -1
- package/dist/services/mysql.strategy.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +14 -10
- package/dist/helpers/mysql.finder.d.ts +0 -15
- package/dist/helpers/mysql.finder.d.ts.map +0 -1
- package/dist/helpers/mysql.finder.js +0 -128
- package/dist/helpers/mysql.finder.js.map +0 -1
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const typeorm_1 = require("typeorm");
|
|
13
|
+
const mysql_exception_1 = require("../mysql.exception");
|
|
14
|
+
class QueryFailureHarness {
|
|
15
|
+
constructor() {
|
|
16
|
+
this.PinoLogger = {
|
|
17
|
+
setContext: jest.fn(),
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
async run(error) {
|
|
21
|
+
throw error;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
__decorate([
|
|
25
|
+
mysql_exception_1.MysqlCatch,
|
|
26
|
+
__metadata("design:type", Function),
|
|
27
|
+
__metadata("design:paramtypes", [Error]),
|
|
28
|
+
__metadata("design:returntype", Promise)
|
|
29
|
+
], QueryFailureHarness.prototype, "run", null);
|
|
30
|
+
describe('Mysql exception mapping', () => {
|
|
31
|
+
it('should normalize duplicate key driver errors', async () => {
|
|
32
|
+
const harness = new QueryFailureHarness();
|
|
33
|
+
const error = new typeorm_1.QueryFailedError('insert', [], { code: 'ER_DUP_ENTRY' });
|
|
34
|
+
await expect(harness.run(error)).rejects.toThrow('MYSQL_DUPLICATE_KEY');
|
|
35
|
+
});
|
|
36
|
+
it('should normalize postgres deadlock driver errors', async () => {
|
|
37
|
+
const harness = new QueryFailureHarness();
|
|
38
|
+
const error = new typeorm_1.QueryFailedError('update', [], { code: '40P01' });
|
|
39
|
+
await expect(harness.run(error)).rejects.toThrow('MYSQL_DEADLOCK');
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=mysql.exception.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.exception.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.exception.spec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,qCAA2C;AAC3C,wDAAgD;AAEhD,MAAM,mBAAmB;IAAzB;QACE,eAAU,GAAG;YACX,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE;SACtB,CAAC;IAMJ,CAAC;IAHO,AAAN,KAAK,CAAC,GAAG,CAAC,KAAY;QACpB,MAAM,KAAK,CAAC;IACd,CAAC;CACF;AAHO;IADL,4BAAU;;qCACM,KAAK;;8CAErB;AAGH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,OAAO,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,IAAI,0BAAgB,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,cAAc,EAA8B,CAAC,CAAC;QAEvG,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,OAAO,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,IAAI,0BAAgB,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAA8B,CAAC,CAAC;QAEhG,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.helper.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.helper.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const helpers_1 = require("../helpers");
|
|
4
|
+
const mysql_config_1 = require("../mysql.config");
|
|
5
|
+
const metadata = {
|
|
6
|
+
name: 'TestMysqlEntity',
|
|
7
|
+
columns: [
|
|
8
|
+
{ propertyName: 'id', propertyPath: 'id' },
|
|
9
|
+
{ propertyName: 'title', propertyPath: 'title' },
|
|
10
|
+
{ propertyName: 'createdAt', propertyPath: 'createdAt' },
|
|
11
|
+
],
|
|
12
|
+
relations: [{ propertyName: 'author', propertyPath: 'author' }],
|
|
13
|
+
};
|
|
14
|
+
const createQueryBuilder = () => ({
|
|
15
|
+
alias: 'TestMysqlEntity',
|
|
16
|
+
andWhere: jest.fn().mockReturnThis(),
|
|
17
|
+
addOrderBy: jest.fn().mockReturnThis(),
|
|
18
|
+
select: jest.fn().mockReturnThis(),
|
|
19
|
+
leftJoinAndSelect: jest.fn().mockReturnThis(),
|
|
20
|
+
});
|
|
21
|
+
describe('MysqlHelper query safety', () => {
|
|
22
|
+
it('should reject unsafe field paths before interpolating identifiers', () => {
|
|
23
|
+
const qb = createQueryBuilder();
|
|
24
|
+
expect(() => helpers_1.MysqlHelper.applyOrder(qb, { 'title;drop': 'asc' }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_UNSAFE_FIELD_PATH');
|
|
25
|
+
});
|
|
26
|
+
it('should reject unknown columns from request query', () => {
|
|
27
|
+
const qb = createQueryBuilder();
|
|
28
|
+
expect(() => helpers_1.MysqlHelper.applyProjection(qb, ['missingColumn'], { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_UNKNOWN_COLUMN');
|
|
29
|
+
});
|
|
30
|
+
it('should reject unsupported array operators for mysql dialect', () => {
|
|
31
|
+
const qb = createQueryBuilder();
|
|
32
|
+
expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $size: 2 } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_OPERATOR_UNSUPPORTED_BY_DIALECT');
|
|
33
|
+
});
|
|
34
|
+
it('should choose postgres case-insensitive like operator and escape wildcard input', () => {
|
|
35
|
+
const qb = createQueryBuilder();
|
|
36
|
+
helpers_1.MysqlHelper.applyCondition(qb, { title: { $like: 'hello_%\\' } }, {
|
|
37
|
+
metadata,
|
|
38
|
+
dialect: mysql_config_1.Dialect.POSTGRES,
|
|
39
|
+
});
|
|
40
|
+
expect(qb.andWhere).toHaveBeenCalledWith("TestMysqlEntity.title ILIKE :title_0 ESCAPE '\\\\'", {
|
|
41
|
+
title_0: '%hello\\_\\%\\\\%',
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
it('should reject empty or non-array values for list operators', () => {
|
|
45
|
+
const qb = createQueryBuilder();
|
|
46
|
+
expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $in: [] } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_INVALID_OPERATOR_VALUE');
|
|
47
|
+
expect(() => helpers_1.MysqlHelper.applyCondition(qb, { title: { $nin: 'draft' } }, { metadata, dialect: mysql_config_1.Dialect.MYSQL })).toThrow('MYSQL_INVALID_OPERATOR_VALUE');
|
|
48
|
+
});
|
|
49
|
+
it('should respect boolean semantics for nil and exists operators', () => {
|
|
50
|
+
const qb = createQueryBuilder();
|
|
51
|
+
helpers_1.MysqlHelper.applyCondition(qb, {
|
|
52
|
+
title: { $nil: false },
|
|
53
|
+
createdAt: { $exists: false },
|
|
54
|
+
}, { metadata, dialect: mysql_config_1.Dialect.MYSQL });
|
|
55
|
+
expect(qb.andWhere).toHaveBeenCalledWith('TestMysqlEntity.title IS NOT NULL');
|
|
56
|
+
expect(qb.andWhere).toHaveBeenCalledWith('TestMysqlEntity.createdAt IS NULL');
|
|
57
|
+
});
|
|
58
|
+
it('should keep the root alias when building nested logical clauses', () => {
|
|
59
|
+
const qb = createQueryBuilder();
|
|
60
|
+
helpers_1.MysqlHelper.applyCondition(qb, { $or: [{ title: 'first' }, { title: 'second' }] }, {
|
|
61
|
+
metadata,
|
|
62
|
+
dialect: mysql_config_1.Dialect.MYSQL,
|
|
63
|
+
});
|
|
64
|
+
const rootBracket = qb.andWhere.mock.calls[0][0];
|
|
65
|
+
const childBuilder = {
|
|
66
|
+
andWhere: jest.fn().mockReturnThis(),
|
|
67
|
+
orWhere: jest.fn().mockReturnThis(),
|
|
68
|
+
};
|
|
69
|
+
rootBracket.whereFactory(childBuilder);
|
|
70
|
+
const firstNestedBracket = childBuilder.andWhere.mock.calls[0][0];
|
|
71
|
+
const grandChildBuilder = {
|
|
72
|
+
andWhere: jest.fn().mockReturnThis(),
|
|
73
|
+
};
|
|
74
|
+
firstNestedBracket.whereFactory(grandChildBuilder);
|
|
75
|
+
expect(grandChildBuilder.andWhere).toHaveBeenCalledWith('TestMysqlEntity.title = :title_0', {
|
|
76
|
+
title_0: 'first',
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
//# sourceMappingURL=mysql.helper.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.helper.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.helper.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.module.integration.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.module.integration.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const common_1 = require("@nestjs/common");
|
|
13
|
+
const testing_1 = require("@nestjs/testing");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const core_1 = require("@joktec/core");
|
|
16
|
+
const models_1 = require("../models");
|
|
17
|
+
const mysql_client_1 = require("../mysql.client");
|
|
18
|
+
const mysql_module_1 = require("../mysql.module");
|
|
19
|
+
const mysql_service_1 = require("../mysql.service");
|
|
20
|
+
let TestMysqlEntity = class TestMysqlEntity extends models_1.MysqlModel {
|
|
21
|
+
};
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
24
|
+
__metadata("design:type", Number)
|
|
25
|
+
], TestMysqlEntity.prototype, "id", void 0);
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.Column)(),
|
|
28
|
+
__metadata("design:type", String)
|
|
29
|
+
], TestMysqlEntity.prototype, "title", void 0);
|
|
30
|
+
TestMysqlEntity = __decorate([
|
|
31
|
+
(0, typeorm_1.Entity)()
|
|
32
|
+
], TestMysqlEntity);
|
|
33
|
+
class TestMysqlSubscriber {
|
|
34
|
+
}
|
|
35
|
+
let TestSupportModule = class TestSupportModule {
|
|
36
|
+
};
|
|
37
|
+
TestSupportModule = __decorate([
|
|
38
|
+
(0, common_1.Global)(),
|
|
39
|
+
(0, common_1.Module)({
|
|
40
|
+
providers: [
|
|
41
|
+
{ provide: core_1.ConfigService, useValue: { get: jest.fn() } },
|
|
42
|
+
{ provide: core_1.LogService, useValue: { setContext: jest.fn(), info: jest.fn(), warn: jest.fn(), error: jest.fn() } },
|
|
43
|
+
],
|
|
44
|
+
exports: [core_1.ConfigService, core_1.LogService],
|
|
45
|
+
})
|
|
46
|
+
], TestSupportModule);
|
|
47
|
+
describe('MysqlModule integration', () => {
|
|
48
|
+
it('should compile MysqlModule.forRoot and expose model/subscriber registries', async () => {
|
|
49
|
+
const moduleRef = await testing_1.Test.createTestingModule({
|
|
50
|
+
imports: [
|
|
51
|
+
TestSupportModule,
|
|
52
|
+
mysql_module_1.MysqlModule.forRoot({
|
|
53
|
+
conId: 'reporting',
|
|
54
|
+
models: [TestMysqlEntity],
|
|
55
|
+
subscribers: [TestMysqlSubscriber],
|
|
56
|
+
}),
|
|
57
|
+
],
|
|
58
|
+
}).compile();
|
|
59
|
+
expect(moduleRef.get(mysql_service_1.MysqlService)).toBeDefined();
|
|
60
|
+
expect(moduleRef.get(mysql_client_1.MODEL_REGISTRY_KEY, { strict: false })).toEqual({ reporting: [TestMysqlEntity] });
|
|
61
|
+
expect(moduleRef.get(mysql_client_1.SUBSCRIBER_REGISTRY_KEY, { strict: false })).toEqual({
|
|
62
|
+
reporting: [TestMysqlSubscriber],
|
|
63
|
+
});
|
|
64
|
+
await moduleRef.close();
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
//# sourceMappingURL=mysql.module.integration.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.module.integration.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.module.integration.spec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,2CAAgD;AAChD,6CAAuC;AACvC,qCAA2G;AAC3G,uCAAyD;AACzD,sCAAuC;AACvC,kDAA8E;AAC9E,kDAA8C;AAC9C,oDAAgD;AAGhD,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,mBAAU;CAMvC,CAAA;AAJC;IADC,IAAA,gCAAsB,GAAE;;2CACb;AAGZ;IADC,IAAA,gBAAM,GAAE;;8CACM;AALX,eAAe;IADpB,IAAA,gBAAW,GAAE;GACR,eAAe,CAMpB;AAED,MAAM,mBAAmB;CAAyD;AAUlF,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,iBAAiB;IARtB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,SAAS,EAAE;YACT,EAAE,OAAO,EAAE,oBAAa,EAAE,QAAQ,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE;YACxD,EAAE,OAAO,EAAE,iBAAU,EAAE,QAAQ,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE;SACjH;QACD,OAAO,EAAE,CAAC,oBAAa,EAAE,iBAAU,CAAC;KACrC,CAAC;GACI,iBAAiB,CAAG;AAE1B,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,2EAA2E,EAAE,KAAK,IAAI,EAAE;QACzF,MAAM,SAAS,GAAG,MAAM,cAAI,CAAC,mBAAmB,CAAC;YAC/C,OAAO,EAAE;gBACP,iBAAiB;gBACjB,0BAAW,CAAC,OAAO,CAAC;oBAClB,KAAK,EAAE,WAAW;oBAClB,MAAM,EAAE,CAAC,eAAe,CAAC;oBACzB,WAAW,EAAE,CAAC,mBAAmB,CAAC;iBACnC,CAAC;aACH;SACF,CAAC,CAAC,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,4BAAY,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,iCAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QACvG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,sCAAuB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACxE,SAAS,EAAE,CAAC,mBAAmB,CAAC;SACjC,CAAC,CAAC;QAEH,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.repo.cursor.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.repo.cursor.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const core_1 = require("@joktec/core");
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const mysql_config_1 = require("../mysql.config");
|
|
15
|
+
const models_1 = require("../models");
|
|
16
|
+
const mysql_repo_1 = require("../mysql.repo");
|
|
17
|
+
let TestMysqlEntity = class TestMysqlEntity extends models_1.MysqlModel {
|
|
18
|
+
};
|
|
19
|
+
__decorate([
|
|
20
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
21
|
+
__metadata("design:type", Number)
|
|
22
|
+
], TestMysqlEntity.prototype, "id", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
(0, typeorm_1.Column)(),
|
|
25
|
+
__metadata("design:type", String)
|
|
26
|
+
], TestMysqlEntity.prototype, "title", void 0);
|
|
27
|
+
TestMysqlEntity = __decorate([
|
|
28
|
+
(0, typeorm_1.Entity)()
|
|
29
|
+
], TestMysqlEntity);
|
|
30
|
+
class TestMysqlRepo extends mysql_repo_1.MysqlRepo {
|
|
31
|
+
constructor(mysqlService) {
|
|
32
|
+
super(mysqlService, TestMysqlEntity);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const createQueryBuilder = (items) => {
|
|
36
|
+
const qb = {
|
|
37
|
+
alias: TestMysqlEntity.name,
|
|
38
|
+
addOrderBy: jest.fn().mockReturnThis(),
|
|
39
|
+
andWhere: jest.fn().mockReturnThis(),
|
|
40
|
+
setParameter: jest.fn().mockReturnThis(),
|
|
41
|
+
take: jest.fn().mockReturnThis(),
|
|
42
|
+
withDeleted: jest.fn().mockReturnThis(),
|
|
43
|
+
comment: jest.fn().mockReturnThis(),
|
|
44
|
+
cache: jest.fn().mockReturnThis(),
|
|
45
|
+
getMany: jest.fn().mockResolvedValue(items),
|
|
46
|
+
getCount: jest.fn().mockResolvedValue(3),
|
|
47
|
+
getOne: jest.fn().mockResolvedValue(items[0] || null),
|
|
48
|
+
};
|
|
49
|
+
return qb;
|
|
50
|
+
};
|
|
51
|
+
const createTypeormRepository = (qb) => ({
|
|
52
|
+
metadata: {
|
|
53
|
+
primaryColumns: [{ propertyName: 'id' }],
|
|
54
|
+
deleteDateColumn: { propertyName: 'deletedAt' },
|
|
55
|
+
columns: [
|
|
56
|
+
{ propertyName: 'id', propertyPath: 'id' },
|
|
57
|
+
{ propertyName: 'title', propertyPath: 'title' },
|
|
58
|
+
{ propertyName: 'createdAt', propertyPath: 'createdAt' },
|
|
59
|
+
],
|
|
60
|
+
relations: [],
|
|
61
|
+
},
|
|
62
|
+
createQueryBuilder: jest.fn().mockReturnValue(qb),
|
|
63
|
+
softRemove: jest.fn(async (entity) => entity),
|
|
64
|
+
remove: jest.fn(async (entity) => entity),
|
|
65
|
+
});
|
|
66
|
+
const createCompositeTypeormRepository = (qb) => ({
|
|
67
|
+
...createTypeormRepository(qb),
|
|
68
|
+
metadata: {
|
|
69
|
+
...createTypeormRepository(qb).metadata,
|
|
70
|
+
primaryColumns: [{ propertyName: 'tenantId' }, { propertyName: 'id' }],
|
|
71
|
+
columns: [
|
|
72
|
+
{ propertyName: 'tenantId', propertyPath: 'tenantId' },
|
|
73
|
+
{ propertyName: 'id', propertyPath: 'id' },
|
|
74
|
+
{ propertyName: 'title', propertyPath: 'title' },
|
|
75
|
+
{ propertyName: 'createdAt', propertyPath: 'createdAt' },
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
const createMysqlService = (repository) => ({
|
|
80
|
+
getRepository: jest.fn().mockReturnValue(repository),
|
|
81
|
+
getConfig: jest.fn().mockReturnValue({ dialect: mysql_config_1.Dialect.MYSQL }),
|
|
82
|
+
});
|
|
83
|
+
const attachDecoratorServices = (repo) => {
|
|
84
|
+
Object.assign(repo, {
|
|
85
|
+
PinoLogger: { setContext: jest.fn() },
|
|
86
|
+
ConfigService: {},
|
|
87
|
+
});
|
|
88
|
+
return repo;
|
|
89
|
+
};
|
|
90
|
+
describe('MysqlRepo cursor pagination', () => {
|
|
91
|
+
it('should build a cursor query using requested cursor key and stable tie breaker', async () => {
|
|
92
|
+
const rawItems = [
|
|
93
|
+
{ id: 1, title: 'first', createdAt: new Date('2026-01-01T00:00:00.000Z') },
|
|
94
|
+
{ id: 2, title: 'second', createdAt: new Date('2026-01-02T00:00:00.000Z') },
|
|
95
|
+
{ id: 3, title: 'third', createdAt: new Date('2026-01-03T00:00:00.000Z') },
|
|
96
|
+
];
|
|
97
|
+
const qb = createQueryBuilder(rawItems);
|
|
98
|
+
const repository = createTypeormRepository(qb);
|
|
99
|
+
const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
|
|
100
|
+
const result = await repo.paginate({
|
|
101
|
+
cursorKey: 'createdAt',
|
|
102
|
+
limit: 2,
|
|
103
|
+
sort: { createdAt: 'desc' },
|
|
104
|
+
});
|
|
105
|
+
expect(repository.createQueryBuilder).toHaveBeenCalledWith(TestMysqlEntity.name);
|
|
106
|
+
expect(qb.addOrderBy).toHaveBeenCalledWith(`${TestMysqlEntity.name}.createdAt`, 'DESC');
|
|
107
|
+
expect(qb.addOrderBy).toHaveBeenCalledWith(`${TestMysqlEntity.name}.id`, 'DESC');
|
|
108
|
+
expect(qb.take).toHaveBeenCalledWith(3);
|
|
109
|
+
expect(result.items).toHaveLength(2);
|
|
110
|
+
expect(result.total).toBe(3);
|
|
111
|
+
expect(result.hasNextPage).toBe(true);
|
|
112
|
+
expect(result.nextCursor).toEqual(expect.any(String));
|
|
113
|
+
const cursor = core_1.CursorPagination.resolve({ cursor: result.nextCursor, defaultKeys: ['id'] });
|
|
114
|
+
expect(cursor.keys).toEqual(['createdAt', 'id']);
|
|
115
|
+
expect(cursor.values).toEqual([rawItems[1].createdAt, rawItems[1].id]);
|
|
116
|
+
});
|
|
117
|
+
it('should reject unsafe cursor field names before building SQL', async () => {
|
|
118
|
+
const qb = createQueryBuilder([]);
|
|
119
|
+
const repository = createTypeormRepository(qb);
|
|
120
|
+
const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
|
|
121
|
+
await expect(repo.paginate({ cursorKey: 'createdAt;drop' })).rejects.toThrow('MYSQL_INVALID_CURSOR');
|
|
122
|
+
});
|
|
123
|
+
it('should reject cursor keys that are not mapped columns', async () => {
|
|
124
|
+
const qb = createQueryBuilder([]);
|
|
125
|
+
const repository = createTypeormRepository(qb);
|
|
126
|
+
const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
|
|
127
|
+
await expect(repo.paginate({ cursorKey: 'missingColumn' })).rejects.toThrow('MYSQL_UNKNOWN_COLUMN');
|
|
128
|
+
});
|
|
129
|
+
it('should reject scalar id lookup for entities with composite primary keys', async () => {
|
|
130
|
+
const qb = createQueryBuilder([]);
|
|
131
|
+
const repository = createCompositeTypeormRepository(qb);
|
|
132
|
+
const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
|
|
133
|
+
await expect(repo.findOne(1)).rejects.toThrow('MYSQL_COMPOSITE_PRIMARY_KEY_REQUIRES_CONDITION');
|
|
134
|
+
});
|
|
135
|
+
it('should call repository softRemove without losing repository context', async () => {
|
|
136
|
+
const entity = { id: 1, title: 'delete me' };
|
|
137
|
+
const qb = createQueryBuilder([]);
|
|
138
|
+
const repository = createTypeormRepository(qb);
|
|
139
|
+
const repo = attachDecoratorServices(new TestMysqlRepo(createMysqlService(repository)));
|
|
140
|
+
jest.spyOn(repo, 'findOne').mockResolvedValue(entity);
|
|
141
|
+
const result = await repo.delete(entity.id);
|
|
142
|
+
expect(repository.softRemove).toHaveBeenCalledWith(entity, {});
|
|
143
|
+
expect(result).toEqual(entity);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
//# sourceMappingURL=mysql.repo.cursor.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.repo.cursor.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.repo.cursor.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.service.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.service.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@joktec/core");
|
|
4
|
+
const mysql_config_1 = require("../mysql.config");
|
|
5
|
+
const mysql_service_1 = require("../mysql.service");
|
|
6
|
+
class TestMysqlService extends mysql_service_1.MysqlService {
|
|
7
|
+
constructor() {
|
|
8
|
+
super({ [core_1.DEFAULT_CON_ID]: [] }, { [core_1.DEFAULT_CON_ID]: [] });
|
|
9
|
+
const logService = {
|
|
10
|
+
debug: jest.fn(),
|
|
11
|
+
error: jest.fn(),
|
|
12
|
+
info: jest.fn(),
|
|
13
|
+
warn: jest.fn(),
|
|
14
|
+
setContext: jest.fn(),
|
|
15
|
+
};
|
|
16
|
+
Object.assign(this, {
|
|
17
|
+
PinoLogger: logService,
|
|
18
|
+
logService,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
setConfig(config) {
|
|
22
|
+
this.configs = {
|
|
23
|
+
[config.conId || core_1.DEFAULT_CON_ID]: new mysql_config_1.MysqlConfig({
|
|
24
|
+
conId: core_1.DEFAULT_CON_ID,
|
|
25
|
+
dialect: mysql_config_1.Dialect.MYSQL,
|
|
26
|
+
username: 'root',
|
|
27
|
+
password: 'root',
|
|
28
|
+
database: 'joktec',
|
|
29
|
+
...config,
|
|
30
|
+
}),
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
startForTest(client, conId = core_1.DEFAULT_CON_ID) {
|
|
34
|
+
return this.start(client, conId);
|
|
35
|
+
}
|
|
36
|
+
stopForTest(client, conId = core_1.DEFAULT_CON_ID) {
|
|
37
|
+
return this.stop(client, conId);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
const createDataSource = (props = {}) => ({
|
|
41
|
+
isInitialized: false,
|
|
42
|
+
initialize: jest.fn().mockResolvedValue(undefined),
|
|
43
|
+
synchronize: jest.fn().mockResolvedValue(undefined),
|
|
44
|
+
destroy: jest.fn().mockResolvedValue(undefined),
|
|
45
|
+
...props,
|
|
46
|
+
});
|
|
47
|
+
describe('MysqlService lifecycle', () => {
|
|
48
|
+
it('should throw when datasource initialization fails', async () => {
|
|
49
|
+
const service = new TestMysqlService();
|
|
50
|
+
service.setConfig({});
|
|
51
|
+
const error = new Error('connect failed');
|
|
52
|
+
const client = createDataSource({ initialize: jest.fn().mockRejectedValue(error) });
|
|
53
|
+
await expect(service.startForTest(client)).rejects.toThrow('connect failed');
|
|
54
|
+
});
|
|
55
|
+
it('should synchronize only when sync is explicitly enabled', async () => {
|
|
56
|
+
const service = new TestMysqlService();
|
|
57
|
+
service.setConfig({ sync: true });
|
|
58
|
+
const client = createDataSource();
|
|
59
|
+
await service.startForTest(client);
|
|
60
|
+
expect(client.initialize).toHaveBeenCalled();
|
|
61
|
+
expect(client.synchronize).toHaveBeenCalledWith(false);
|
|
62
|
+
});
|
|
63
|
+
it('should not destroy an uninitialized datasource', async () => {
|
|
64
|
+
const service = new TestMysqlService();
|
|
65
|
+
const client = createDataSource({ isInitialized: false });
|
|
66
|
+
await service.stopForTest(client);
|
|
67
|
+
expect(client.destroy).not.toHaveBeenCalled();
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
//# sourceMappingURL=mysql.service.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.service.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.service.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.utils.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/mysql.utils.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const helpers_1 = require("../helpers");
|
|
4
|
+
describe('Mysql SQL utils', () => {
|
|
5
|
+
it('should quote and escape positional SQL parameters', () => {
|
|
6
|
+
const sql = (0, helpers_1.printSql)('select * from users where name = ? and active = ? and meta = ?', [
|
|
7
|
+
"O'Reilly",
|
|
8
|
+
true,
|
|
9
|
+
{ role: 'admin' },
|
|
10
|
+
]);
|
|
11
|
+
expect(sql).toBe("select * from users where name = 'O''Reilly' and active = TRUE and meta = '{\"role\":\"admin\"}'");
|
|
12
|
+
});
|
|
13
|
+
it('should replace postgres-style numbered parameters', () => {
|
|
14
|
+
const sql = (0, helpers_1.printSql)('select * from users where id = $1 and created_at > $2', [
|
|
15
|
+
10,
|
|
16
|
+
new Date('2026-01-01T00:00:00.000Z'),
|
|
17
|
+
]);
|
|
18
|
+
expect(sql).toBe("select * from users where id = 10 and created_at > '2026-01-01T00:00:00.000Z'");
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
//# sourceMappingURL=mysql.utils.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql.utils.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.utils.spec.ts"],"names":[],"mappings":";;AAAA,wCAAsC;AAEtC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,GAAG,GAAG,IAAA,kBAAQ,EAAC,gEAAgE,EAAE;YACrF,UAAU;YACV,IAAI;YACJ,EAAE,IAAI,EAAE,OAAO,EAAE;SAClB,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CACd,kGAAkG,CACnG,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,GAAG,GAAG,IAAA,kBAAQ,EAAC,uDAAuD,EAAE;YAC5E,EAAE;YACF,IAAI,IAAI,CAAC,0BAA0B,CAAC;SACrC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,+EAA+E,CAAC,CAAC;IACpG,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ColumnType } from 'typeorm';
|
|
2
|
+
import { IMysqlColumnOptions, IMysqlPrimaryColumnOptions, MysqlFieldDecorator, PrimaryColumnStrategy } from './columns';
|
|
3
|
+
export declare function Column(): MysqlFieldDecorator;
|
|
4
|
+
export declare function Column(options: IMysqlColumnOptions): MysqlFieldDecorator;
|
|
5
|
+
export declare function Column(type: ColumnType, options?: IMysqlColumnOptions): MysqlFieldDecorator;
|
|
6
|
+
export declare function PrimaryColumn(): PropertyDecorator;
|
|
7
|
+
export declare function PrimaryColumn(strategy: PrimaryColumnStrategy, options?: IMysqlPrimaryColumnOptions): PropertyDecorator;
|
|
8
|
+
export declare function PrimaryColumn(options: IMysqlPrimaryColumnOptions): PropertyDecorator;
|
|
9
|
+
export declare const PrimaryGeneratedColumn: typeof PrimaryColumn;
|
|
10
|
+
//# sourceMappingURL=column.decorator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"column.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/column.decorator.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,UAAU,EAcX,MAAM,SAAS,CAAC;AAEjB,OAAO,EAIL,mBAAmB,EACnB,0BAA0B,EAQ1B,mBAAmB,EACnB,qBAAqB,EAWtB,MAAM,WAAW,CAAC;AAcnB,wBAAgB,MAAM,IAAI,mBAAmB,CAAC;AAC9C,wBAAgB,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,mBAAmB,CAAC;AAC1E,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,mBAAmB,CAAC;AAmM7F,wBAAgB,aAAa,IAAI,iBAAiB,CAAC;AACnD,wBAAgB,aAAa,CAAC,QAAQ,EAAE,qBAAqB,EAAE,OAAO,CAAC,EAAE,0BAA0B,GAAG,iBAAiB,CAAC;AACxH,wBAAgB,aAAa,CAAC,OAAO,EAAE,0BAA0B,GAAG,iBAAiB,CAAC;AAsCtF,eAAO,MAAM,sBAAsB,sBAAgB,CAAC"}
|