@joktec/mysql 0.2.14 → 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 +212 -2
- package/dist/__tests__/mysql.column.decorator.spec.js +474 -1
- package/dist/__tests__/mysql.column.decorator.spec.js.map +1 -1
- package/dist/__tests__/mysql.dialect.spec.js +1 -0
- package/dist/__tests__/mysql.dialect.spec.js.map +1 -1
- package/dist/decorators/column.decorator.d.ts +4 -5
- package/dist/decorators/column.decorator.d.ts.map +1 -1
- package/dist/decorators/column.decorator.js +151 -5
- package/dist/decorators/column.decorator.js.map +1 -1
- package/dist/decorators/columns/array.column.d.ts +2 -1
- package/dist/decorators/columns/array.column.d.ts.map +1 -1
- package/dist/decorators/columns/array.column.js +7 -2
- package/dist/decorators/columns/array.column.js.map +1 -1
- package/dist/decorators/columns/column.factory.d.ts +3 -3
- package/dist/decorators/columns/column.factory.d.ts.map +1 -1
- package/dist/decorators/columns/column.factory.js +4 -2
- package/dist/decorators/columns/column.factory.js.map +1 -1
- package/dist/decorators/columns/column.type.d.ts +107 -4
- package/dist/decorators/columns/column.type.d.ts.map +1 -1
- package/dist/decorators/columns/column.util.d.ts +13 -6
- package/dist/decorators/columns/column.util.d.ts.map +1 -1
- package/dist/decorators/columns/column.util.js +85 -4
- package/dist/decorators/columns/column.util.js.map +1 -1
- package/dist/decorators/columns/enum.column.d.ts +2 -2
- package/dist/decorators/columns/enum.column.d.ts.map +1 -1
- package/dist/decorators/columns/enum.column.js.map +1 -1
- package/dist/decorators/columns/index.d.ts +3 -0
- package/dist/decorators/columns/index.d.ts.map +1 -1
- package/dist/decorators/columns/index.js +3 -0
- package/dist/decorators/columns/index.js.map +1 -1
- package/dist/decorators/columns/nested.column.d.ts +2 -2
- package/dist/decorators/columns/nested.column.d.ts.map +1 -1
- package/dist/decorators/columns/nested.column.js +2 -2
- package/dist/decorators/columns/nested.column.js.map +1 -1
- package/dist/decorators/columns/number.column.d.ts +2 -2
- package/dist/decorators/columns/number.column.d.ts.map +1 -1
- package/dist/decorators/columns/number.column.js +2 -1
- package/dist/decorators/columns/number.column.js.map +1 -1
- 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/string.column.d.ts +2 -2
- package/dist/decorators/columns/string.column.d.ts.map +1 -1
- package/dist/decorators/columns/string.column.js +10 -7
- package/dist/decorators/columns/string.column.js.map +1 -1
- package/dist/decorators/columns/swagger.column.d.ts +2 -2
- package/dist/decorators/columns/swagger.column.d.ts.map +1 -1
- package/dist/decorators/columns/swagger.column.js +10 -1
- package/dist/decorators/columns/swagger.column.js.map +1 -1
- 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 +2 -2
- package/dist/decorators/columns/transform.column.d.ts.map +1 -1
- package/dist/decorators/columns/transform.column.js +5 -2
- package/dist/decorators/columns/transform.column.js.map +1 -1
- 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 +2 -0
- package/dist/decorators/index.d.ts.map +1 -1
- package/dist/decorators/index.js +1 -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 -24
- 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/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- 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/mysql.repo.d.ts +1 -2
- package/dist/mysql.repo.d.ts.map +1 -1
- package/dist/mysql.repo.js +0 -15
- package/dist/mysql.repo.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- 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
|
@@ -11,20 +11,43 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
const globals_1 = require("@jest/globals");
|
|
13
13
|
const utils_1 = require("@joktec/utils");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
14
15
|
const typeorm_1 = require("typeorm");
|
|
15
16
|
const decorators_1 = require("../decorators");
|
|
16
17
|
const UUID_V7_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-7[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/;
|
|
18
|
+
const hasIndexColumn = (item, column) => {
|
|
19
|
+
return Array.isArray(item.columns) && item.columns.includes(column);
|
|
20
|
+
};
|
|
21
|
+
const getSwaggerMetadata = (target, property) => {
|
|
22
|
+
return Reflect.getMetadata(swagger_1.DECORATORS.API_MODEL_PROPERTIES, target, property);
|
|
23
|
+
};
|
|
17
24
|
(0, globals_1.describe)('MySQL column decorators', () => {
|
|
18
25
|
(0, globals_1.it)('applies TypeORM column metadata and validation decorators', () => {
|
|
26
|
+
const transformer = {
|
|
27
|
+
to: (value) => value?.trim(),
|
|
28
|
+
from: (value) => value,
|
|
29
|
+
};
|
|
19
30
|
class ProductColumnFixture {
|
|
20
31
|
}
|
|
21
32
|
__decorate([
|
|
22
|
-
(0, decorators_1.Column)({
|
|
33
|
+
(0, decorators_1.Column)({
|
|
34
|
+
length: 10,
|
|
35
|
+
nullable: false,
|
|
36
|
+
transformer,
|
|
37
|
+
index: { name: 'IDX_product_name', options: { unique: true } },
|
|
38
|
+
check: { name: 'CHK_product_name', expression: 'LENGTH(name) > 0' },
|
|
39
|
+
}),
|
|
23
40
|
__metadata("design:type", String)
|
|
24
41
|
], ProductColumnFixture.prototype, "name", void 0);
|
|
25
42
|
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === ProductColumnFixture && item.propertyName === 'name');
|
|
26
43
|
(0, globals_1.expect)(metadata).toBeDefined();
|
|
27
44
|
(0, globals_1.expect)(metadata.options.length).toEqual(10);
|
|
45
|
+
(0, globals_1.expect)(metadata.options.transformer).toBe(transformer);
|
|
46
|
+
const index = (0, typeorm_1.getMetadataArgsStorage)().indices.find(item => item.target === ProductColumnFixture && hasIndexColumn(item, 'name'));
|
|
47
|
+
const check = (0, typeorm_1.getMetadataArgsStorage)().checks.find(item => item.target === ProductColumnFixture && item.expression === 'LENGTH(name) > 0');
|
|
48
|
+
(0, globals_1.expect)(index?.name).toEqual('IDX_product_name');
|
|
49
|
+
(0, globals_1.expect)(index?.unique ?? index?.options?.unique).toEqual(true);
|
|
50
|
+
(0, globals_1.expect)(check?.name).toEqual('CHK_product_name');
|
|
28
51
|
const invalid = new ProductColumnFixture();
|
|
29
52
|
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('name');
|
|
30
53
|
const valid = new ProductColumnFixture();
|
|
@@ -56,5 +79,455 @@ const UUID_V7_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-7[0-9a-f]{3}-[89ab][0-9a-f]{3}-[
|
|
|
56
79
|
(0, globals_1.expect)(metadata).toBeDefined();
|
|
57
80
|
(0, globals_1.expect)(metadata.options.primary).toEqual(true);
|
|
58
81
|
});
|
|
82
|
+
(0, globals_1.it)('wraps TypeORM timestamp columns with date validation metadata', () => {
|
|
83
|
+
class TimestampFixture {
|
|
84
|
+
}
|
|
85
|
+
__decorate([
|
|
86
|
+
(0, decorators_1.TimestampColumn)('create', { name: 'created_at', type: 'datetime', precision: 6, required: true }),
|
|
87
|
+
__metadata("design:type", Date)
|
|
88
|
+
], TimestampFixture.prototype, "createdAt", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
(0, decorators_1.TimestampColumn)('update', { name: 'updated_at', type: 'datetime', precision: 6 }),
|
|
91
|
+
__metadata("design:type", Date)
|
|
92
|
+
], TimestampFixture.prototype, "updatedAt", void 0);
|
|
93
|
+
__decorate([
|
|
94
|
+
(0, decorators_1.TimestampColumn)('delete', { name: 'deleted_at', type: 'datetime', precision: 6 }),
|
|
95
|
+
__metadata("design:type", Date)
|
|
96
|
+
], TimestampFixture.prototype, "deletedAt", void 0);
|
|
97
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.filter(item => item.target === TimestampFixture);
|
|
98
|
+
const createdAt = metadata.find(item => item.propertyName === 'createdAt');
|
|
99
|
+
const updatedAt = metadata.find(item => item.propertyName === 'updatedAt');
|
|
100
|
+
const deletedAt = metadata.find(item => item.propertyName === 'deletedAt');
|
|
101
|
+
(0, globals_1.expect)(createdAt).toBeDefined();
|
|
102
|
+
(0, globals_1.expect)(createdAt.mode).toEqual('createDate');
|
|
103
|
+
(0, globals_1.expect)(createdAt.options.name).toEqual('created_at');
|
|
104
|
+
(0, globals_1.expect)(createdAt.options.precision).toEqual(6);
|
|
105
|
+
(0, globals_1.expect)(updatedAt.mode).toEqual('updateDate');
|
|
106
|
+
(0, globals_1.expect)(deletedAt.mode).toEqual('deleteDate');
|
|
107
|
+
(0, globals_1.expect)(deletedAt.options.nullable).toEqual(true);
|
|
108
|
+
(0, globals_1.expect)(getSwaggerMetadata(TimestampFixture.prototype, 'createdAt').readOnly).toEqual(true);
|
|
109
|
+
(0, globals_1.expect)(getSwaggerMetadata(TimestampFixture.prototype, 'updatedAt').readOnly).toEqual(true);
|
|
110
|
+
(0, globals_1.expect)(getSwaggerMetadata(TimestampFixture.prototype, 'deletedAt').readOnly).toEqual(true);
|
|
111
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(new TimestampFixture()).map(error => error.property)).toContain('createdAt');
|
|
112
|
+
const valid = new TimestampFixture();
|
|
113
|
+
valid.createdAt = new Date();
|
|
114
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(valid)).toHaveLength(0);
|
|
115
|
+
});
|
|
116
|
+
(0, globals_1.it)('keeps column option modes strict at compile time', () => {
|
|
117
|
+
const normal = { type: 'varchar', isEmail: true };
|
|
118
|
+
const virtual = { kind: 'virtual', comment: 'Display name' };
|
|
119
|
+
const sqlVirtual = { kind: 'virtual', mode: 'sql', query: (alias) => alias };
|
|
120
|
+
const relation = { kind: 'relation', relation: 'many-to-one', type: () => String };
|
|
121
|
+
const relationId = {
|
|
122
|
+
kind: 'relation-id',
|
|
123
|
+
relationId: (entity) => entity.author,
|
|
124
|
+
};
|
|
125
|
+
(0, globals_1.expect)(normal.type).toEqual('varchar');
|
|
126
|
+
(0, globals_1.expect)(virtual.kind).toEqual('virtual');
|
|
127
|
+
(0, globals_1.expect)(sqlVirtual.mode).toEqual('sql');
|
|
128
|
+
(0, globals_1.expect)(relation.relation).toEqual('many-to-one');
|
|
129
|
+
(0, globals_1.expect)(relationId.kind).toEqual('relation-id');
|
|
130
|
+
const invalidVirtual = { kind: 'virtual', isEmail: true };
|
|
131
|
+
const invalidRelation = {
|
|
132
|
+
kind: 'relation',
|
|
133
|
+
relation: 'many-to-one',
|
|
134
|
+
type: () => String,
|
|
135
|
+
isEmail: true,
|
|
136
|
+
};
|
|
137
|
+
const checkedInvalidRelation = invalidRelation;
|
|
138
|
+
const invalidRelationId = {
|
|
139
|
+
kind: 'relation-id',
|
|
140
|
+
relationId: (entity) => entity.author,
|
|
141
|
+
joinColumn: true,
|
|
142
|
+
};
|
|
143
|
+
const checkedInvalidRelationId = invalidRelationId;
|
|
144
|
+
(0, globals_1.expect)(invalidVirtual).toBeDefined();
|
|
145
|
+
(0, globals_1.expect)(checkedInvalidRelation).toBeDefined();
|
|
146
|
+
(0, globals_1.expect)(checkedInvalidRelationId).toBeDefined();
|
|
147
|
+
});
|
|
148
|
+
(0, globals_1.it)('infers integer validation from int-like column types', () => {
|
|
149
|
+
class IntegerFixture {
|
|
150
|
+
}
|
|
151
|
+
__decorate([
|
|
152
|
+
(0, decorators_1.Column)({ type: 'int' }),
|
|
153
|
+
__metadata("design:type", Number)
|
|
154
|
+
], IntegerFixture.prototype, "count", void 0);
|
|
155
|
+
const invalid = new IntegerFixture();
|
|
156
|
+
invalid.count = 1.5;
|
|
157
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('count');
|
|
158
|
+
const valid = new IntegerFixture();
|
|
159
|
+
valid.count = 1;
|
|
160
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(valid)).toHaveLength(0);
|
|
161
|
+
});
|
|
162
|
+
(0, globals_1.it)('validates simple-array elements with each semantics', () => {
|
|
163
|
+
class ArrayFixture {
|
|
164
|
+
}
|
|
165
|
+
__decorate([
|
|
166
|
+
(0, decorators_1.Column)('simple-array'),
|
|
167
|
+
__metadata("design:type", Array)
|
|
168
|
+
], ArrayFixture.prototype, "codes", void 0);
|
|
169
|
+
const invalid = new ArrayFixture();
|
|
170
|
+
invalid.codes = ['A', 1];
|
|
171
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('codes');
|
|
172
|
+
const valid = new ArrayFixture();
|
|
173
|
+
valid.codes = ['A', 'B'];
|
|
174
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(valid)).toHaveLength(0);
|
|
175
|
+
});
|
|
176
|
+
(0, globals_1.it)('supports uuid and object validation flags', () => {
|
|
177
|
+
class TypedFixture {
|
|
178
|
+
}
|
|
179
|
+
__decorate([
|
|
180
|
+
(0, decorators_1.Column)('varchar', { isUUID: true, nullable: true }),
|
|
181
|
+
__metadata("design:type", String)
|
|
182
|
+
], TypedFixture.prototype, "targetId", void 0);
|
|
183
|
+
__decorate([
|
|
184
|
+
(0, decorators_1.Column)('simple-json', { isObject: true }),
|
|
185
|
+
__metadata("design:type", Object)
|
|
186
|
+
], TypedFixture.prototype, "payload", void 0);
|
|
187
|
+
const invalid = new TypedFixture();
|
|
188
|
+
invalid.targetId = 'not-uuid';
|
|
189
|
+
invalid.payload = 'not-object';
|
|
190
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toEqual(['targetId', 'payload']);
|
|
191
|
+
const valid = new TypedFixture();
|
|
192
|
+
valid.targetId = '6f12b53a-5c43-4b2a-8cf4-bd32b6cbbf35';
|
|
193
|
+
valid.payload = { source: 'test' };
|
|
194
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(valid)).toHaveLength(0);
|
|
195
|
+
});
|
|
196
|
+
(0, globals_1.it)('rejects Mongo ObjectId column metadata in the MySQL adapter', () => {
|
|
197
|
+
(0, globals_1.expect)(() => {
|
|
198
|
+
class ObjectIdColumnFixture {
|
|
199
|
+
}
|
|
200
|
+
__decorate([
|
|
201
|
+
(0, decorators_1.Column)('varchar', { isObjectId: true }),
|
|
202
|
+
__metadata("design:type", String)
|
|
203
|
+
], ObjectIdColumnFixture.prototype, "mongoId", void 0);
|
|
204
|
+
return ObjectIdColumnFixture;
|
|
205
|
+
}).toThrow('MYSQL_MONGO_COLUMN_UNSUPPORTED');
|
|
206
|
+
(0, globals_1.expect)(() => {
|
|
207
|
+
class ObjectIdPrimaryFixture {
|
|
208
|
+
}
|
|
209
|
+
__decorate([
|
|
210
|
+
(0, decorators_1.PrimaryColumn)('objectId'),
|
|
211
|
+
__metadata("design:type", String)
|
|
212
|
+
], ObjectIdPrimaryFixture.prototype, "id", void 0);
|
|
213
|
+
return ObjectIdPrimaryFixture;
|
|
214
|
+
}).toThrow('MYSQL_MONGO_PRIMARY_UNSUPPORTED');
|
|
215
|
+
});
|
|
216
|
+
(0, globals_1.it)('adds class-transformer type metadata for primitive column design types', () => {
|
|
217
|
+
class TransformFixture {
|
|
218
|
+
}
|
|
219
|
+
__decorate([
|
|
220
|
+
(0, decorators_1.Column)('bigint', { default: 0 }),
|
|
221
|
+
__metadata("design:type", Number)
|
|
222
|
+
], TransformFixture.prototype, "plan", void 0);
|
|
223
|
+
const fixture = (0, utils_1.plainToInstance)(TransformFixture, { plan: '42' });
|
|
224
|
+
(0, globals_1.expect)(fixture.plan).toBe(42);
|
|
225
|
+
});
|
|
226
|
+
(0, globals_1.it)('adds class-transformer type metadata for json class columns', () => {
|
|
227
|
+
class JsonPreference {
|
|
228
|
+
}
|
|
229
|
+
__decorate([
|
|
230
|
+
(0, utils_1.IsString)(),
|
|
231
|
+
__metadata("design:type", String)
|
|
232
|
+
], JsonPreference.prototype, "theme", void 0);
|
|
233
|
+
class JsonFixture {
|
|
234
|
+
}
|
|
235
|
+
__decorate([
|
|
236
|
+
(0, decorators_1.Column)('jsonb', { nullable: true }),
|
|
237
|
+
__metadata("design:type", JsonPreference)
|
|
238
|
+
], JsonFixture.prototype, "preference", void 0);
|
|
239
|
+
const fixture = (0, utils_1.plainToInstance)(JsonFixture, { preference: { theme: 'dark' } });
|
|
240
|
+
(0, globals_1.expect)(fixture.preference).toBeInstanceOf(JsonPreference);
|
|
241
|
+
(0, globals_1.expect)(fixture.preference.theme).toEqual('dark');
|
|
242
|
+
const invalid = new JsonFixture();
|
|
243
|
+
invalid.preference = 'not-object';
|
|
244
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('preference');
|
|
245
|
+
const invalidNested = (0, utils_1.plainToInstance)(JsonFixture, { preference: { theme: 1 } });
|
|
246
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalidNested).map(error => error.property)).toContain('preference');
|
|
247
|
+
});
|
|
248
|
+
(0, globals_1.it)('uses explicit nested type metadata for json class arrays', () => {
|
|
249
|
+
class JsonPreference {
|
|
250
|
+
}
|
|
251
|
+
__decorate([
|
|
252
|
+
(0, utils_1.IsString)(),
|
|
253
|
+
__metadata("design:type", String)
|
|
254
|
+
], JsonPreference.prototype, "theme", void 0);
|
|
255
|
+
class JsonArrayFixture {
|
|
256
|
+
}
|
|
257
|
+
__decorate([
|
|
258
|
+
(0, decorators_1.Column)('jsonb', { nested: JsonPreference, nullable: true }),
|
|
259
|
+
__metadata("design:type", Array)
|
|
260
|
+
], JsonArrayFixture.prototype, "preferences", void 0);
|
|
261
|
+
const fixture = (0, utils_1.plainToInstance)(JsonArrayFixture, { preferences: [{ theme: 'dark' }, { theme: 'light' }] });
|
|
262
|
+
(0, globals_1.expect)(fixture.preferences[0]).toBeInstanceOf(JsonPreference);
|
|
263
|
+
(0, globals_1.expect)(fixture.preferences[1]).toBeInstanceOf(JsonPreference);
|
|
264
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(fixture)).toHaveLength(0);
|
|
265
|
+
const invalid = (0, utils_1.plainToInstance)(JsonArrayFixture, { preferences: [{ theme: 'dark' }, { theme: 1 }] });
|
|
266
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('preferences');
|
|
267
|
+
const swagger = Reflect.getMetadata(swagger_1.DECORATORS.API_MODEL_PROPERTIES, JsonArrayFixture.prototype, 'preferences');
|
|
268
|
+
(0, globals_1.expect)(swagger.type).toBe(JsonPreference);
|
|
269
|
+
(0, globals_1.expect)(swagger.isArray).toEqual(true);
|
|
270
|
+
(0, globals_1.expect)(swagger.nullable).toEqual(true);
|
|
271
|
+
});
|
|
272
|
+
(0, globals_1.it)('allows swagger options to override inferred nested metadata', () => {
|
|
273
|
+
class JsonPreference {
|
|
274
|
+
}
|
|
275
|
+
__decorate([
|
|
276
|
+
(0, utils_1.IsString)(),
|
|
277
|
+
__metadata("design:type", String)
|
|
278
|
+
], JsonPreference.prototype, "theme", void 0);
|
|
279
|
+
class SwaggerOverrideFixture {
|
|
280
|
+
}
|
|
281
|
+
__decorate([
|
|
282
|
+
(0, decorators_1.Column)('jsonb', {
|
|
283
|
+
nested: JsonPreference,
|
|
284
|
+
nullable: true,
|
|
285
|
+
swagger: { description: 'Custom docs type', type: String, isArray: false },
|
|
286
|
+
}),
|
|
287
|
+
__metadata("design:type", Array)
|
|
288
|
+
], SwaggerOverrideFixture.prototype, "preferences", void 0);
|
|
289
|
+
const swagger = Reflect.getMetadata(swagger_1.DECORATORS.API_MODEL_PROPERTIES, SwaggerOverrideFixture.prototype, 'preferences');
|
|
290
|
+
(0, globals_1.expect)(swagger.type).toBe(String);
|
|
291
|
+
(0, globals_1.expect)(swagger.isArray).toEqual(false);
|
|
292
|
+
(0, globals_1.expect)(swagger.description).toEqual('Custom docs type');
|
|
293
|
+
});
|
|
294
|
+
(0, globals_1.it)('maps immutable metadata to Swagger readOnly and still allows explicit override', () => {
|
|
295
|
+
class ImmutableColumnFixture {
|
|
296
|
+
}
|
|
297
|
+
__decorate([
|
|
298
|
+
(0, decorators_1.Column)({ type: 'varchar', immutable: true }),
|
|
299
|
+
__metadata("design:type", String)
|
|
300
|
+
], ImmutableColumnFixture.prototype, "serverManaged", void 0);
|
|
301
|
+
__decorate([
|
|
302
|
+
(0, decorators_1.Column)({ type: 'varchar', update: false }),
|
|
303
|
+
__metadata("design:type", String)
|
|
304
|
+
], ImmutableColumnFixture.prototype, "insertOnly", void 0);
|
|
305
|
+
__decorate([
|
|
306
|
+
(0, decorators_1.Column)({ type: 'varchar', update: false, immutable: false }),
|
|
307
|
+
__metadata("design:type", String)
|
|
308
|
+
], ImmutableColumnFixture.prototype, "insertOnlyButClientWritable", void 0);
|
|
309
|
+
__decorate([
|
|
310
|
+
(0, decorators_1.Column)({ type: 'varchar', immutable: true, swagger: { readOnly: false } }),
|
|
311
|
+
__metadata("design:type", String)
|
|
312
|
+
], ImmutableColumnFixture.prototype, "documentedOverride", void 0);
|
|
313
|
+
const immutableSwagger = getSwaggerMetadata(ImmutableColumnFixture.prototype, 'serverManaged');
|
|
314
|
+
const insertOnlySwagger = getSwaggerMetadata(ImmutableColumnFixture.prototype, 'insertOnly');
|
|
315
|
+
const clientWritableSwagger = getSwaggerMetadata(ImmutableColumnFixture.prototype, 'insertOnlyButClientWritable');
|
|
316
|
+
const overriddenSwagger = getSwaggerMetadata(ImmutableColumnFixture.prototype, 'documentedOverride');
|
|
317
|
+
(0, globals_1.expect)(immutableSwagger.readOnly).toEqual(true);
|
|
318
|
+
(0, globals_1.expect)(insertOnlySwagger.readOnly).toEqual(true);
|
|
319
|
+
(0, globals_1.expect)(clientWritableSwagger.readOnly).toEqual(false);
|
|
320
|
+
(0, globals_1.expect)(overriddenSwagger.readOnly).toEqual(false);
|
|
321
|
+
});
|
|
322
|
+
(0, globals_1.it)('keeps record-like json columns as plain objects', () => {
|
|
323
|
+
class JsonRecordFixture {
|
|
324
|
+
}
|
|
325
|
+
__decorate([
|
|
326
|
+
(0, decorators_1.Column)('jsonb', { nullable: true }),
|
|
327
|
+
__metadata("design:type", Object)
|
|
328
|
+
], JsonRecordFixture.prototype, "preference", void 0);
|
|
329
|
+
const fixture = (0, utils_1.plainToInstance)(JsonRecordFixture, { preference: { theme: 'dark' } });
|
|
330
|
+
(0, globals_1.expect)(fixture.preference).toEqual({ theme: 'dark' });
|
|
331
|
+
(0, globals_1.expect)(fixture.preference).not.toBeInstanceOf(JsonRecordFixture);
|
|
332
|
+
});
|
|
333
|
+
(0, globals_1.it)('applies virtual metadata without registering a persisted TypeORM column', () => {
|
|
334
|
+
class VirtualColumnFixture {
|
|
335
|
+
constructor() {
|
|
336
|
+
this.requests = [{ pc: 2 }, { pc: 3 }];
|
|
337
|
+
}
|
|
338
|
+
get totalRequest() {
|
|
339
|
+
return this.requests.reduce((total, request) => total + request.pc, 0);
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
__decorate([
|
|
343
|
+
(0, decorators_1.Column)({ kind: 'virtual', comment: 'Total request', example: 5 }),
|
|
344
|
+
__metadata("design:type", Number),
|
|
345
|
+
__metadata("design:paramtypes", [])
|
|
346
|
+
], VirtualColumnFixture.prototype, "totalRequest", null);
|
|
347
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === VirtualColumnFixture && item.propertyName === 'totalRequest');
|
|
348
|
+
(0, globals_1.expect)(metadata).toBeUndefined();
|
|
349
|
+
(0, globals_1.expect)(getSwaggerMetadata(VirtualColumnFixture.prototype, 'totalRequest').readOnly).toEqual(true);
|
|
350
|
+
(0, globals_1.expect)(new VirtualColumnFixture().totalRequest).toEqual(5);
|
|
351
|
+
});
|
|
352
|
+
(0, globals_1.it)('keeps legacy virtual metadata mode compatible', () => {
|
|
353
|
+
class LegacyVirtualColumnFixture {
|
|
354
|
+
get label() {
|
|
355
|
+
return 'legacy';
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
__decorate([
|
|
359
|
+
(0, decorators_1.Column)({ virtual: true, comment: 'Legacy virtual' }),
|
|
360
|
+
__metadata("design:type", String),
|
|
361
|
+
__metadata("design:paramtypes", [])
|
|
362
|
+
], LegacyVirtualColumnFixture.prototype, "label", null);
|
|
363
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === LegacyVirtualColumnFixture && item.propertyName === 'label');
|
|
364
|
+
(0, globals_1.expect)(metadata).toBeUndefined();
|
|
365
|
+
(0, globals_1.expect)(new LegacyVirtualColumnFixture().label).toEqual('legacy');
|
|
366
|
+
});
|
|
367
|
+
(0, globals_1.it)('wraps TypeORM version columns with integer validation metadata', () => {
|
|
368
|
+
class VersionColumnFixture {
|
|
369
|
+
}
|
|
370
|
+
__decorate([
|
|
371
|
+
(0, decorators_1.Column)({ kind: 'version' }),
|
|
372
|
+
__metadata("design:type", Number)
|
|
373
|
+
], VersionColumnFixture.prototype, "version", void 0);
|
|
374
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === VersionColumnFixture && item.propertyName === 'version');
|
|
375
|
+
(0, globals_1.expect)(metadata).toBeDefined();
|
|
376
|
+
(0, globals_1.expect)(metadata.mode).toEqual('version');
|
|
377
|
+
const invalid = new VersionColumnFixture();
|
|
378
|
+
invalid.version = 1.5;
|
|
379
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(invalid).map(error => error.property)).toContain('version');
|
|
380
|
+
const valid = new VersionColumnFixture();
|
|
381
|
+
valid.version = 1;
|
|
382
|
+
(0, globals_1.expect)((0, utils_1.validateSync)(valid)).toHaveLength(0);
|
|
383
|
+
});
|
|
384
|
+
(0, globals_1.it)('wraps TypeORM virtual SQL columns separately from metadata-only computed getters', () => {
|
|
385
|
+
class TypeormVirtualColumnFixture {
|
|
386
|
+
}
|
|
387
|
+
__decorate([
|
|
388
|
+
(0, decorators_1.Column)('int', {
|
|
389
|
+
kind: 'virtual',
|
|
390
|
+
mode: 'sql',
|
|
391
|
+
query: alias => `SELECT COUNT(*) FROM item WHERE item.owner_id = ${alias}.id`,
|
|
392
|
+
}),
|
|
393
|
+
__metadata("design:type", Number)
|
|
394
|
+
], TypeormVirtualColumnFixture.prototype, "itemCount", void 0);
|
|
395
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === TypeormVirtualColumnFixture && item.propertyName === 'itemCount');
|
|
396
|
+
(0, globals_1.expect)(metadata).toBeDefined();
|
|
397
|
+
(0, globals_1.expect)(metadata.mode).toEqual('virtual-property');
|
|
398
|
+
(0, globals_1.expect)(metadata.options.type).toEqual('int');
|
|
399
|
+
(0, globals_1.expect)(metadata.options.query('user')).toEqual('SELECT COUNT(*) FROM item WHERE item.owner_id = user.id');
|
|
400
|
+
(0, globals_1.expect)(getSwaggerMetadata(TypeormVirtualColumnFixture.prototype, 'itemCount').readOnly).toEqual(true);
|
|
401
|
+
});
|
|
402
|
+
(0, globals_1.it)('wraps TypeORM view columns with JokTec metadata', () => {
|
|
403
|
+
class ViewColumnFixture {
|
|
404
|
+
}
|
|
405
|
+
__decorate([
|
|
406
|
+
(0, decorators_1.Column)({ kind: 'view', name: 'display_name' }),
|
|
407
|
+
__metadata("design:type", String)
|
|
408
|
+
], ViewColumnFixture.prototype, "displayName", void 0);
|
|
409
|
+
const metadata = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === ViewColumnFixture && item.propertyName === 'displayName');
|
|
410
|
+
(0, globals_1.expect)(metadata).toBeDefined();
|
|
411
|
+
(0, globals_1.expect)(metadata.mode).toEqual('regular');
|
|
412
|
+
(0, globals_1.expect)(metadata.options.name).toEqual('display_name');
|
|
413
|
+
(0, globals_1.expect)(getSwaggerMetadata(ViewColumnFixture.prototype, 'displayName').readOnly).toEqual(true);
|
|
414
|
+
});
|
|
415
|
+
(0, globals_1.it)('wraps TypeORM relations with join metadata and field metadata', () => {
|
|
416
|
+
class UserRelationFixture {
|
|
417
|
+
}
|
|
418
|
+
class ArticleRelationFixture {
|
|
419
|
+
}
|
|
420
|
+
__decorate([
|
|
421
|
+
(0, decorators_1.Column)({
|
|
422
|
+
kind: 'relation',
|
|
423
|
+
relation: 'many-to-one',
|
|
424
|
+
type: () => UserRelationFixture,
|
|
425
|
+
inverseSide: user => user.articles,
|
|
426
|
+
joinColumn: { name: 'author_id' },
|
|
427
|
+
nullable: true,
|
|
428
|
+
index: 'IDX_article_author',
|
|
429
|
+
}),
|
|
430
|
+
__metadata("design:type", UserRelationFixture)
|
|
431
|
+
], ArticleRelationFixture.prototype, "author", void 0);
|
|
432
|
+
__decorate([
|
|
433
|
+
(0, decorators_1.Column)({
|
|
434
|
+
kind: 'relation-id',
|
|
435
|
+
relationId: (article) => article.author,
|
|
436
|
+
nullable: true,
|
|
437
|
+
}),
|
|
438
|
+
__metadata("design:type", String)
|
|
439
|
+
], ArticleRelationFixture.prototype, "authorId", void 0);
|
|
440
|
+
const relation = (0, typeorm_1.getMetadataArgsStorage)().relations.find(item => item.target === ArticleRelationFixture && item.propertyName === 'author');
|
|
441
|
+
const joinColumn = (0, typeorm_1.getMetadataArgsStorage)().joinColumns.find(item => item.target === ArticleRelationFixture && item.propertyName === 'author');
|
|
442
|
+
(0, globals_1.expect)(relation).toBeDefined();
|
|
443
|
+
(0, globals_1.expect)(relation.relationType).toEqual('many-to-one');
|
|
444
|
+
(0, globals_1.expect)(relation.options.nullable).toEqual(true);
|
|
445
|
+
(0, globals_1.expect)(joinColumn).toBeDefined();
|
|
446
|
+
(0, globals_1.expect)(joinColumn.name).toEqual('author_id');
|
|
447
|
+
const index = (0, typeorm_1.getMetadataArgsStorage)().indices.find(item => item.target === ArticleRelationFixture && hasIndexColumn(item, 'author'));
|
|
448
|
+
const relationId = (0, typeorm_1.getMetadataArgsStorage)().relationIds.find(item => item.target === ArticleRelationFixture && item.propertyName === 'authorId');
|
|
449
|
+
(0, globals_1.expect)(index?.name).toEqual('IDX_article_author');
|
|
450
|
+
(0, globals_1.expect)(relationId).toBeDefined();
|
|
451
|
+
(0, globals_1.expect)(getSwaggerMetadata(ArticleRelationFixture.prototype, 'authorId').readOnly).toEqual(true);
|
|
452
|
+
});
|
|
453
|
+
(0, globals_1.it)('wraps TypeORM table metadata for entity modes, inheritance, and checks', () => {
|
|
454
|
+
let TableEntityFixture = class TableEntityFixture {
|
|
455
|
+
};
|
|
456
|
+
TableEntityFixture = __decorate([
|
|
457
|
+
(0, decorators_1.Tables)({
|
|
458
|
+
name: 'table_entity_fixture',
|
|
459
|
+
index: ['code'],
|
|
460
|
+
unique: ['slug'],
|
|
461
|
+
textSearch: ['title'],
|
|
462
|
+
customIndexes: [{ name: 'IDX_table_custom', fields: ['active'], where: 'active = true' }],
|
|
463
|
+
checks: [{ name: 'CHK_table_score', expression: 'score >= 0' }],
|
|
464
|
+
inheritance: { column: { name: 'kind', type: 'varchar' } },
|
|
465
|
+
})
|
|
466
|
+
], TableEntityFixture);
|
|
467
|
+
const table = (0, typeorm_1.getMetadataArgsStorage)().tables.find(item => item.target === TableEntityFixture);
|
|
468
|
+
const inheritance = (0, typeorm_1.getMetadataArgsStorage)().inheritances.find(item => item.target === TableEntityFixture);
|
|
469
|
+
const check = (0, typeorm_1.getMetadataArgsStorage)().checks.find(item => item.target === TableEntityFixture && item.expression === 'score >= 0');
|
|
470
|
+
const index = (0, typeorm_1.getMetadataArgsStorage)().indices.find(item => item.name === 'IDX_table_custom');
|
|
471
|
+
(0, globals_1.expect)(table?.name).toEqual('table_entity_fixture');
|
|
472
|
+
(0, globals_1.expect)(inheritance?.column).toEqual({ name: 'kind', type: 'varchar' });
|
|
473
|
+
(0, globals_1.expect)(check?.name).toEqual('CHK_table_score');
|
|
474
|
+
(0, globals_1.expect)(index?.columns).toEqual(['active']);
|
|
475
|
+
});
|
|
476
|
+
(0, globals_1.it)('wraps TypeORM view and child table metadata', () => {
|
|
477
|
+
let ActiveUsersViewFixture = class ActiveUsersViewFixture {
|
|
478
|
+
};
|
|
479
|
+
ActiveUsersViewFixture = __decorate([
|
|
480
|
+
(0, decorators_1.Tables)({ kind: 'view', name: 'active_users_view', expression: 'SELECT 1 AS id' })
|
|
481
|
+
], ActiveUsersViewFixture);
|
|
482
|
+
let AdminUserFixture = class AdminUserFixture {
|
|
483
|
+
};
|
|
484
|
+
AdminUserFixture = __decorate([
|
|
485
|
+
(0, decorators_1.Tables)({ kind: 'child', discriminatorValue: 'admin' })
|
|
486
|
+
], AdminUserFixture);
|
|
487
|
+
const view = (0, typeorm_1.getMetadataArgsStorage)().tables.find(item => item.target === ActiveUsersViewFixture);
|
|
488
|
+
const child = (0, typeorm_1.getMetadataArgsStorage)().tables.find(item => item.target === AdminUserFixture);
|
|
489
|
+
const discriminator = (0, typeorm_1.getMetadataArgsStorage)().discriminatorValues.find(item => item.target === AdminUserFixture);
|
|
490
|
+
(0, globals_1.expect)(view?.type).toEqual('view');
|
|
491
|
+
(0, globals_1.expect)(view?.expression).toEqual('SELECT 1 AS id');
|
|
492
|
+
(0, globals_1.expect)(child?.type).toEqual('entity-child');
|
|
493
|
+
(0, globals_1.expect)(discriminator?.value).toEqual('admin');
|
|
494
|
+
});
|
|
495
|
+
(0, globals_1.it)('wraps TypeORM tree property decorators', () => {
|
|
496
|
+
let TreeFixture = class TreeFixture {
|
|
497
|
+
};
|
|
498
|
+
__decorate([
|
|
499
|
+
(0, decorators_1.Column)({ kind: 'tree', tree: 'parent', onDelete: 'CASCADE' }),
|
|
500
|
+
__metadata("design:type", TreeFixture)
|
|
501
|
+
], TreeFixture.prototype, "parent", void 0);
|
|
502
|
+
__decorate([
|
|
503
|
+
(0, decorators_1.Column)({ kind: 'tree', tree: 'children', cascade: true }),
|
|
504
|
+
__metadata("design:type", Array)
|
|
505
|
+
], TreeFixture.prototype, "children", void 0);
|
|
506
|
+
__decorate([
|
|
507
|
+
(0, decorators_1.Column)({ kind: 'tree', tree: 'level' }),
|
|
508
|
+
__metadata("design:type", Number)
|
|
509
|
+
], TreeFixture.prototype, "level", void 0);
|
|
510
|
+
TreeFixture = __decorate([
|
|
511
|
+
(0, decorators_1.Tables)({ tree: 'closure-table' })
|
|
512
|
+
], TreeFixture);
|
|
513
|
+
const relations = (0, typeorm_1.getMetadataArgsStorage)().relations.filter(item => item.target === TreeFixture);
|
|
514
|
+
const tree = (0, typeorm_1.getMetadataArgsStorage)().trees.find(item => item.target === TreeFixture);
|
|
515
|
+
const level = (0, typeorm_1.getMetadataArgsStorage)().columns.find(item => item.target === TreeFixture && item.propertyName === 'level');
|
|
516
|
+
(0, globals_1.expect)(tree?.type).toEqual('closure-table');
|
|
517
|
+
(0, globals_1.expect)(relations.find(item => item.propertyName === 'parent')?.isTreeParent).toEqual(true);
|
|
518
|
+
(0, globals_1.expect)(relations.find(item => item.propertyName === 'children')?.isTreeChildren).toEqual(true);
|
|
519
|
+
(0, globals_1.expect)(level?.mode).toEqual('treeLevel');
|
|
520
|
+
(0, globals_1.expect)(getSwaggerMetadata(TreeFixture.prototype, 'level').readOnly).toEqual(true);
|
|
521
|
+
});
|
|
522
|
+
(0, globals_1.it)('wraps TypeORM tree table options with closure-table options', () => {
|
|
523
|
+
let ClosureTreeFixture = class ClosureTreeFixture {
|
|
524
|
+
};
|
|
525
|
+
ClosureTreeFixture = __decorate([
|
|
526
|
+
(0, decorators_1.Tables)({ tree: { type: 'closure-table', options: { closureTableName: 'category_closure' } } })
|
|
527
|
+
], ClosureTreeFixture);
|
|
528
|
+
const tree = (0, typeorm_1.getMetadataArgsStorage)().trees.find(item => item.target === ClosureTreeFixture);
|
|
529
|
+
(0, globals_1.expect)(tree?.type).toEqual('closure-table');
|
|
530
|
+
(0, globals_1.expect)(tree?.options?.closureTableName).toEqual('category_closure');
|
|
531
|
+
});
|
|
59
532
|
});
|
|
60
533
|
//# sourceMappingURL=mysql.column.decorator.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.column.decorator.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.column.decorator.spec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,2CAAqD;AACrD,yCAA6C;AAC7C,qCAAiD;AACjD,8CAAsD;AAEtD,MAAM,aAAa,GAAG,uEAAuE,CAAC;AAE9F,IAAA,kBAAQ,EAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAA,YAAE,EAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,oBAAoB;SAGzB;QADC;YADC,IAAA,mBAAM,EAAC,EAAE,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;;0DAC1B;QAGhB,MAAM,QAAQ,GAAG,IAAA,gCAAsB,GAAE,CAAC,OAAO,CAAC,IAAI,CACpD,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,oBAAoB,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,CAC7E,CAAC;QAEF,IAAA,gBAAM,EAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/B,IAAA,gBAAM,EAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAE5C,MAAM,OAAO,GAAG,IAAI,oBAAoB,EAAE,CAAC;QAC3C,IAAA,gBAAM,EAAC,IAAA,oBAAY,EAAC,OAAO,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAE7E,MAAM,KAAK,GAAG,IAAI,oBAAoB,EAAE,CAAC;QACzC,KAAK,CAAC,IAAI,GAAG,SAAS,CAAC;QACvB,IAAA,gBAAM,EAAC,IAAA,oBAAY,EAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAA,YAAE,EAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,qBAAqB;SAG1B;QADC;YADC,IAAA,mBAAM,EAAC,EAAE,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2DACzB;QAGhB,IAAA,gBAAM,EAAC,IAAA,oBAAY,EAAC,IAAI,qBAAqB,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,IAAA,YAAE,EAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,kBAAkB;SAGvB;QADC;YADC,IAAA,0BAAa,EAAC,QAAQ,CAAC;;sDACZ;QAGd,MAAM,OAAO,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,MAAM,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACpF,IAAI,CAAC,QAAQ,CAAC,+BAA+B,CAAC,CAC/C,CAAC;QAEF,IAAA,gBAAM,EAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/B,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QAEpB,IAAA,gBAAM,EAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAE1C,MAAM,QAAQ,GAAG,IAAA,gCAAsB,GAAE,CAAC,OAAO,CAAC,IAAI,CACpD,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,kBAAkB,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,CACzE,CAAC;QACF,IAAA,gBAAM,EAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/B,IAAA,gBAAM,EAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
1
|
+
{"version":3,"file":"mysql.column.decorator.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.column.decorator.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,6 +23,7 @@ describe('Mysql dialect support', () => {
|
|
|
23
23
|
expect(() => (0, services_1.assertFirstClassDialect)(mysql_config_1.Dialect.MYSQL)).not.toThrow();
|
|
24
24
|
expect(() => (0, services_1.assertFirstClassDialect)(mysql_config_1.Dialect.MARIADB)).not.toThrow();
|
|
25
25
|
expect(() => (0, services_1.assertFirstClassDialect)(mysql_config_1.Dialect.POSTGRES)).not.toThrow();
|
|
26
|
+
expect(() => (0, services_1.assertFirstClassDialect)('mongodb')).toThrow('MYSQL_UNSUPPORTED_DIALECT');
|
|
26
27
|
});
|
|
27
28
|
});
|
|
28
29
|
//# sourceMappingURL=mysql.dialect.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.dialect.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.dialect.spec.ts"],"names":[],"mappings":";;AAAA,kDAAuD;AACvD,0CAAmF;AAEnF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,MAAM,GAAG,IAAI,0BAAW,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAiB,CAAC,CAAC;QAE1G,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,CAAC,IAAA,sCAA2B,EAAC,sBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC;YAC/D,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,MAAM;YAC3B,aAAa,EAAE,IAAI;SACpB,CAAC,CAAC;QACH,MAAM,CAAC,IAAA,sCAA2B,EAAC,sBAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC;YAClE,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,OAAO;YAC5B,cAAc,EAAE,IAAI;SACrB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACnE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACrE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"mysql.dialect.spec.js","sourceRoot":"","sources":["../../src/__tests__/mysql.dialect.spec.ts"],"names":[],"mappings":";;AAAA,kDAAuD;AACvD,0CAAmF;AAEnF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,MAAM,GAAG,IAAI,0BAAW,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAiB,CAAC,CAAC;QAE1G,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,CAAC,IAAA,sCAA2B,EAAC,sBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC;YAC/D,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,MAAM;YAC3B,aAAa,EAAE,IAAI;SACpB,CAAC,CAAC;QACH,MAAM,CAAC,IAAA,sCAA2B,EAAC,sBAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC;YAClE,UAAU,EAAE,IAAI;YAChB,mBAAmB,EAAE,OAAO;YAC5B,cAAc,EAAE,IAAI;SACrB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACnE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACrE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,sBAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACtE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kCAAuB,EAAC,SAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC;IACnG,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { ColumnType } from 'typeorm';
|
|
2
|
-
import { IMysqlColumnOptions, IMysqlPrimaryColumnOptions, PrimaryColumnStrategy } from './columns';
|
|
3
|
-
export
|
|
4
|
-
export declare function Column():
|
|
5
|
-
export declare function Column(
|
|
6
|
-
export declare function Column(type: ColumnType, options?: IMysqlColumnOptions): PropertyDecorator;
|
|
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;
|
|
7
6
|
export declare function PrimaryColumn(): PropertyDecorator;
|
|
8
7
|
export declare function PrimaryColumn(strategy: PrimaryColumnStrategy, options?: IMysqlPrimaryColumnOptions): PropertyDecorator;
|
|
9
8
|
export declare function PrimaryColumn(options: IMysqlPrimaryColumnOptions): PropertyDecorator;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"column.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/column.decorator.ts"],"names":[],"mappings":"
|
|
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"}
|