@loopback/repository-tests 0.18.2 → 0.19.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/crud/create-retrieve.suite.js +24 -24
- package/dist/crud/create-retrieve.suite.js.map +1 -1
- package/dist/crud/freeform-properties.suite.js +16 -16
- package/dist/crud/freeform-properties.suite.js.map +1 -1
- package/dist/crud/nested-model-properties.suite.js +26 -26
- package/dist/crud/nested-model-properties.suite.js.map +1 -1
- package/dist/crud/relations/acceptance/belongs-to.inclusion-resolver.relation.acceptance.js +10 -10
- package/dist/crud/relations/acceptance/belongs-to.inclusion-resolver.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/belongs-to.relation.acceptance.js +7 -7
- package/dist/crud/relations/acceptance/belongs-to.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-many-inclusion-resolver.relation.acceptance.js +19 -19
- package/dist/crud/relations/acceptance/has-many-inclusion-resolver.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-many-through-inclusion-resolver.acceptance.js +18 -18
- package/dist/crud/relations/acceptance/has-many-through-inclusion-resolver.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-many-through.relation.acceptance.js +43 -43
- package/dist/crud/relations/acceptance/has-many-through.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-many.relation.acceptance.js +27 -27
- package/dist/crud/relations/acceptance/has-many.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-one.inclusion-resolver.acceptance.js +9 -9
- package/dist/crud/relations/acceptance/has-one.inclusion-resolver.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/has-one.relation.acceptance.js +21 -21
- package/dist/crud/relations/acceptance/has-one.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/acceptance/multi-relations-inclusion-resolver.relation.acceptance.js +10 -10
- package/dist/crud/relations/acceptance/multi-relations-inclusion-resolver.relation.acceptance.js.map +1 -1
- package/dist/crud/relations/fixtures/models/address.model.js +20 -20
- package/dist/crud/relations/fixtures/models/address.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/cart-item.model.js +11 -11
- package/dist/crud/relations/fixtures/models/cart-item.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/customer-cart-item-link.model.js +14 -14
- package/dist/crud/relations/fixtures/models/customer-cart-item-link.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/customer.model.js +23 -23
- package/dist/crud/relations/fixtures/models/customer.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/index.js +8 -8
- package/dist/crud/relations/fixtures/models/index.js.map +1 -1
- package/dist/crud/relations/fixtures/models/order.model.js +17 -17
- package/dist/crud/relations/fixtures/models/order.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/shipment.model.js +15 -15
- package/dist/crud/relations/fixtures/models/shipment.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/user-link.model.js +14 -14
- package/dist/crud/relations/fixtures/models/user-link.model.js.map +1 -1
- package/dist/crud/relations/fixtures/models/user.model.js +11 -11
- package/dist/crud/relations/fixtures/models/user.model.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/address.repository.js +1 -1
- package/dist/crud/relations/fixtures/repositories/address.repository.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/cart-item.repository.js +1 -1
- package/dist/crud/relations/fixtures/repositories/cart-item.repository.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/customer.repository.js +5 -5
- package/dist/crud/relations/fixtures/repositories/customer.repository.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/index.js +8 -8
- package/dist/crud/relations/fixtures/repositories/index.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/order.repository.js +2 -2
- package/dist/crud/relations/fixtures/repositories/order.repository.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/shipment.repository.js +1 -1
- package/dist/crud/relations/fixtures/repositories/shipment.repository.js.map +1 -1
- package/dist/crud/relations/fixtures/repositories/user.repository.js +1 -1
- package/dist/crud/relations/fixtures/repositories/user.repository.js.map +1 -1
- package/dist/crud/relations/helpers.js +8 -8
- package/dist/crud/relations/helpers.js.map +1 -1
- package/dist/crud/replace-by-id.suite.js +21 -21
- package/dist/crud/replace-by-id.suite.js.map +1 -1
- package/dist/crud/transactions.suite.js +25 -25
- package/dist/crud/transactions.suite.js.map +1 -1
- package/dist/crud-test-suite.js +7 -7
- package/dist/crud-test-suite.js.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/package.json +14 -14
|
@@ -17,31 +17,31 @@ function createRetrieveSuite(dataSourceOptions, repositoryClass, features) {
|
|
|
17
17
|
super(data);
|
|
18
18
|
}
|
|
19
19
|
};
|
|
20
|
-
tslib_1.__decorate([
|
|
21
|
-
repository_1.property({
|
|
20
|
+
(0, tslib_1.__decorate)([
|
|
21
|
+
(0, repository_1.property)({
|
|
22
22
|
type: features.idType,
|
|
23
23
|
id: true,
|
|
24
24
|
generated: true,
|
|
25
25
|
description: 'The unique identifier for a product',
|
|
26
26
|
}),
|
|
27
|
-
tslib_1.__metadata("design:type", Object)
|
|
27
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
28
28
|
], Product.prototype, "id", void 0);
|
|
29
|
-
tslib_1.__decorate([
|
|
30
|
-
repository_1.property({ type: 'string', required: true }),
|
|
31
|
-
tslib_1.__metadata("design:type", String)
|
|
29
|
+
(0, tslib_1.__decorate)([
|
|
30
|
+
(0, repository_1.property)({ type: 'string', required: true }),
|
|
31
|
+
(0, tslib_1.__metadata)("design:type", String)
|
|
32
32
|
], Product.prototype, "name", void 0);
|
|
33
|
-
tslib_1.__decorate([
|
|
34
|
-
repository_1.property(),
|
|
35
|
-
tslib_1.__metadata("design:type", Number)
|
|
33
|
+
(0, tslib_1.__decorate)([
|
|
34
|
+
(0, repository_1.property)(),
|
|
35
|
+
(0, tslib_1.__metadata)("design:type", Number)
|
|
36
36
|
], Product.prototype, "categoryId", void 0);
|
|
37
|
-
Product = tslib_1.__decorate([
|
|
38
|
-
repository_1.model(),
|
|
39
|
-
tslib_1.__metadata("design:paramtypes", [Object])
|
|
37
|
+
Product = (0, tslib_1.__decorate)([
|
|
38
|
+
(0, repository_1.model)(),
|
|
39
|
+
(0, tslib_1.__metadata)("design:paramtypes", [Object])
|
|
40
40
|
], Product);
|
|
41
41
|
describe('create-retrieve', () => {
|
|
42
42
|
before(helpers_repository_tests_1.deleteAllModelsInDefaultDataSource);
|
|
43
43
|
let repo;
|
|
44
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
44
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
45
45
|
repo = new repositoryClass(Product, ctx.dataSource);
|
|
46
46
|
await ctx.dataSource.automigrate(Product.name);
|
|
47
47
|
}));
|
|
@@ -50,30 +50,30 @@ function createRetrieveSuite(dataSourceOptions, repositoryClass, features) {
|
|
|
50
50
|
});
|
|
51
51
|
it('retrieves a newly created model with id set by the database', async () => {
|
|
52
52
|
const created = await repo.create({ name: 'Pencil', categoryId: 1 });
|
|
53
|
-
testlab_1.expect(created.toObject()).to.have.properties('id', 'name', 'categoryId');
|
|
54
|
-
testlab_1.expect(created.id).to.be.ok();
|
|
53
|
+
(0, testlab_1.expect)(created.toObject()).to.have.properties('id', 'name', 'categoryId');
|
|
54
|
+
(0, testlab_1.expect)(created.id).to.be.ok();
|
|
55
55
|
const found = await repo.findById(created.id);
|
|
56
|
-
testlab_1.expect(testlab_1.toJSON(created)).to.deepEqual(testlab_1.toJSON(found));
|
|
56
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(created)).to.deepEqual((0, testlab_1.toJSON)(found));
|
|
57
57
|
});
|
|
58
58
|
it('retrieves a newly created model when id was transformed via JSON', async () => {
|
|
59
59
|
const created = await repo.create({ name: 'Pen', categoryId: 1 });
|
|
60
|
-
testlab_1.expect(created.id).to.be.ok();
|
|
61
|
-
const id = testlab_1.toJSON(created).id;
|
|
60
|
+
(0, testlab_1.expect)(created.id).to.be.ok();
|
|
61
|
+
const id = (0, testlab_1.toJSON)(created).id;
|
|
62
62
|
const found = await repo.findById(id);
|
|
63
|
-
testlab_1.expect(testlab_1.toJSON(created)).to.deepEqual(testlab_1.toJSON(found));
|
|
63
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(created)).to.deepEqual((0, testlab_1.toJSON)(found));
|
|
64
64
|
});
|
|
65
65
|
it('retrieves an instance of a model from its foreign key value', async () => {
|
|
66
66
|
const pens = await repo.create({ name: 'Pens', categoryId: 1 });
|
|
67
67
|
const pencils = await repo.create({ name: 'Pencils', categoryId: 2 });
|
|
68
|
-
const products = await repository_1.findByForeignKeys(repo, 'categoryId', [1]);
|
|
69
|
-
testlab_1.expect(testlab_1.toJSON(products)).deepEqual(testlab_1.toJSON([pens]));
|
|
70
|
-
testlab_1.expect(products).to.not.containDeep(pencils);
|
|
68
|
+
const products = await (0, repository_1.findByForeignKeys)(repo, 'categoryId', [1]);
|
|
69
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(products)).deepEqual((0, testlab_1.toJSON)([pens]));
|
|
70
|
+
(0, testlab_1.expect)(products).to.not.containDeep(pencils);
|
|
71
71
|
});
|
|
72
72
|
it('retrieves instances of a model from their foreign key value', async () => {
|
|
73
73
|
const pens = await repo.create({ name: 'Pens', categoryId: 1 });
|
|
74
74
|
const pencils = await repo.create({ name: 'Pencils', categoryId: 2 });
|
|
75
|
-
const products = await repository_1.findByForeignKeys(repo, 'categoryId', [1, 2]);
|
|
76
|
-
testlab_1.expect(testlab_1.toJSON(products)).deepEqual(testlab_1.toJSON([pens, pencils]));
|
|
75
|
+
const products = await (0, repository_1.findByForeignKeys)(repo, 'categoryId', [1, 2]);
|
|
76
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(products)).deepEqual((0, testlab_1.toJSON)([pens, pencils]));
|
|
77
77
|
});
|
|
78
78
|
});
|
|
79
79
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-retrieve.suite.js","sourceRoot":"","sources":["../../src/crud/create-retrieve.suite.ts"],"names":[],"mappings":";AAAA,iDAAiD;AACjD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;;AAEhE,qDAO8B;AAC9B,+CAAiD;AACjD,0EAIqC;AAQrC,8EAA8E;AAC9E,yEAAyE;AACzE,SAAgB,mBAAmB,CACjC,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAGtB,IAAM,OAAO,GAAb,MAAM,OAAQ,SAAQ,mBAAM;QAe1B,YAAY,IAAuB;YACjC,KAAK,CAAC,IAAI,CAAC,CAAC;QACd,CAAC;KACF,CAAA;IAXC;QANC,qBAAQ,
|
|
1
|
+
{"version":3,"file":"create-retrieve.suite.js","sourceRoot":"","sources":["../../src/crud/create-retrieve.suite.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,38 +16,38 @@ function freeformPropertiesSuite(dataSourceOptions, repositoryClass, features) {
|
|
|
16
16
|
super(data);
|
|
17
17
|
}
|
|
18
18
|
};
|
|
19
|
-
tslib_1.__decorate([
|
|
20
|
-
repository_1.property({
|
|
19
|
+
(0, tslib_1.__decorate)([
|
|
20
|
+
(0, repository_1.property)({
|
|
21
21
|
type: features.idType,
|
|
22
22
|
id: true,
|
|
23
23
|
description: 'The unique identifier for a product',
|
|
24
24
|
}),
|
|
25
|
-
tslib_1.__metadata("design:type", Object)
|
|
25
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
26
26
|
], Freeform.prototype, "id", void 0);
|
|
27
|
-
tslib_1.__decorate([
|
|
28
|
-
repository_1.property({ type: 'string', required: true }),
|
|
29
|
-
tslib_1.__metadata("design:type", String)
|
|
27
|
+
(0, tslib_1.__decorate)([
|
|
28
|
+
(0, repository_1.property)({ type: 'string', required: true }),
|
|
29
|
+
(0, tslib_1.__metadata)("design:type", String)
|
|
30
30
|
], Freeform.prototype, "name", void 0);
|
|
31
|
-
Freeform = tslib_1.__decorate([
|
|
32
|
-
repository_1.model({ settings: { strict: false } }),
|
|
33
|
-
tslib_1.__metadata("design:paramtypes", [Object])
|
|
31
|
+
Freeform = (0, tslib_1.__decorate)([
|
|
32
|
+
(0, repository_1.model)({ settings: { strict: false } }),
|
|
33
|
+
(0, tslib_1.__metadata)("design:paramtypes", [Object])
|
|
34
34
|
], Freeform);
|
|
35
35
|
/* istanbul ignore next */
|
|
36
36
|
it('should warn that {strict: false} mode is not supported for SQL DBs ', async () => {
|
|
37
|
-
helpers_repository_tests_1.withCrudCtx(async (ctx) => {
|
|
37
|
+
(0, helpers_repository_tests_1.withCrudCtx)(async (ctx) => {
|
|
38
38
|
new repositoryClass(Freeform, ctx.dataSource);
|
|
39
39
|
});
|
|
40
40
|
if (!features.freeFormProperties) {
|
|
41
|
-
console_1.assert("WARNING: relational database doesn't support {strict: false} mode. {strict: true} " +
|
|
41
|
+
(0, console_1.assert)("WARNING: relational database doesn't support {strict: false} mode. {strict: true} " +
|
|
42
42
|
'mode will be set for model Freeform instead.');
|
|
43
43
|
}
|
|
44
44
|
});
|
|
45
45
|
// test DBs that support freeform props
|
|
46
46
|
/* istanbul ignore next */
|
|
47
|
-
testlab_1.skipIf(!features.freeFormProperties, it, 'free-form properties {strict: false}', async () => {
|
|
47
|
+
(0, testlab_1.skipIf)(!features.freeFormProperties, it, 'free-form properties {strict: false}', async () => {
|
|
48
48
|
before(helpers_repository_tests_1.deleteAllModelsInDefaultDataSource);
|
|
49
49
|
let repo;
|
|
50
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
50
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
51
51
|
repo = new repositoryClass(Freeform, ctx.dataSource);
|
|
52
52
|
await ctx.dataSource.automigrate(Freeform.name);
|
|
53
53
|
}));
|
|
@@ -59,10 +59,10 @@ function freeformPropertiesSuite(dataSourceOptions, repositoryClass, features) {
|
|
|
59
59
|
name: 'Pencil',
|
|
60
60
|
color: 'red',
|
|
61
61
|
});
|
|
62
|
-
testlab_1.expect(created.toObject()).to.have.properties('id', 'name');
|
|
63
|
-
testlab_1.expect(created.id).to.be.ok();
|
|
62
|
+
(0, testlab_1.expect)(created.toObject()).to.have.properties('id', 'name');
|
|
63
|
+
(0, testlab_1.expect)(created.id).to.be.ok();
|
|
64
64
|
const found = await repo.findById(created.id);
|
|
65
|
-
testlab_1.expect(testlab_1.toJSON(created)).to.deepEqual(testlab_1.toJSON(found));
|
|
65
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(created)).to.deepEqual((0, testlab_1.toJSON)(found));
|
|
66
66
|
});
|
|
67
67
|
});
|
|
68
68
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"freeform-properties.suite.js","sourceRoot":"","sources":["../../src/crud/freeform-properties.suite.ts"],"names":[],"mappings":";AAAA,sDAAsD;AACtD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;;AAEhE,qDAA6D;AAE7D,+CAAyD;AAEzD,0EAGqC;AAOrC,qCAA+B;AAE/B,SAAgB,uBAAuB,CACrC,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAGtB,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,mBAAM;QAc3B,YAAY,IAAwB;YAClC,KAAK,CAAC,IAAI,CAAC,CAAC;QACd,CAAC;KACF,CAAA;IAXC;QALC,qBAAQ,
|
|
1
|
+
{"version":3,"file":"freeform-properties.suite.js","sourceRoot":"","sources":["../../src/crud/freeform-properties.suite.ts"],"names":[],"mappings":";AAAA,sDAAsD;AACtD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;;AAEhE,qDAA6D;AAE7D,+CAAyD;AAEzD,0EAGqC;AAOrC,qCAA+B;AAE/B,SAAgB,uBAAuB,CACrC,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAGtB,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,mBAAM;QAc3B,YAAY,IAAwB;YAClC,KAAK,CAAC,IAAI,CAAC,CAAC;QACd,CAAC;KACF,CAAA;IAXC;QALC,IAAA,qBAAQ,EAAC;YACR,IAAI,EAAE,QAAQ,CAAC,MAAM;YACrB,EAAE,EAAE,IAAI;YACR,WAAW,EAAE,qCAAqC;SACnD,CAAC;;wCACc;IAGhB;QADC,IAAA,qBAAQ,EAAC,EAAC,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC;;0CAC9B;IATT,QAAQ;QADb,IAAA,kBAAK,EAAC,EAAC,QAAQ,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC,EAAC,CAAC;;OAC7B,QAAQ,CAiBb;IACD,0BAA0B;IAC1B,EAAE,CAAC,qEAAqE,EAAE,KAAK,IAAI,EAAE;QACnF,IAAA,sCAAW,EAAC,KAAK,EAAE,GAAoB,EAAE,EAAE;YACzC,IAAI,eAAe,CAAC,QAAQ,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE;YAChC,IAAA,gBAAM,EACJ,oFAAoF;gBAClF,8CAA8C,CACjD,CAAC;SACH;IACH,CAAC,CAAC,CAAC;IAEH,uCAAuC;IACvC,0BAA0B;IAC1B,IAAA,gBAAM,EACJ,CAAC,QAAQ,CAAC,kBAAkB,EAC5B,EAAE,EACF,sCAAsC,EACtC,KAAK,IAAI,EAAE;QACT,MAAM,CAAC,6DAAkC,CAAC,CAAC;QAE3C,IAAI,IAAkE,CAAC;QAEvE,MAAM,CACJ,IAAA,sCAAW,EAAC,KAAK,UAAU,eAAe,CAAC,GAAoB;YAC7D,IAAI,GAAG,IAAI,eAAe,CAAC,QAAQ,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;YACrD,MAAM,GAAG,CAAC,UAAU,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClD,CAAC,CAAC,CACH,CAAC;QAEF,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;YACjD,0EAA0E;YAC1E,wEAAwE;YACxE,mCAAmC;YACnC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAoB;gBACnD,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,KAAK;aACb,CAAC,CAAC;YACH,IAAA,gBAAM,EAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAC5D,IAAA,gBAAM,EAAC,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAE9B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC9C,IAAA,gBAAM,EAAC,IAAA,gBAAM,EAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,IAAA,gBAAM,EAAC,KAAK,CAAC,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;IACL,CAAC,CACF,CAAC;AACJ,CAAC;AAvED,0DAuEC"}
|
|
@@ -14,7 +14,7 @@ function nestedModelsPropertiesSuite(dataSourceOptions, repositoryClass, feature
|
|
|
14
14
|
let db;
|
|
15
15
|
let userRepo;
|
|
16
16
|
before(helpers_repository_tests_1.deleteAllModelsInDefaultDataSource);
|
|
17
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
17
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
18
18
|
db = ctx.dataSource;
|
|
19
19
|
userRepo = new repository_1.DefaultCrudRepository(User, db);
|
|
20
20
|
const models = [User];
|
|
@@ -31,7 +31,7 @@ function nestedModelsPropertiesSuite(dataSourceOptions, repositoryClass, feature
|
|
|
31
31
|
};
|
|
32
32
|
const created = await userRepo.create(user);
|
|
33
33
|
const stored = await userRepo.findById(created.id);
|
|
34
|
-
testlab_1.expect(testlab_1.toJSON(stored)).to.containDeep(testlab_1.toJSON(user));
|
|
34
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(stored)).to.containDeep((0, testlab_1.toJSON)(user));
|
|
35
35
|
});
|
|
36
36
|
it('allows models to allow multiple nested model properties in an array', async () => {
|
|
37
37
|
const user = {
|
|
@@ -41,50 +41,50 @@ function nestedModelsPropertiesSuite(dataSourceOptions, repositoryClass, feature
|
|
|
41
41
|
};
|
|
42
42
|
const created = await userRepo.create(user);
|
|
43
43
|
const stored = await userRepo.findById(created.id);
|
|
44
|
-
testlab_1.expect(testlab_1.toJSON(stored)).to.containDeep(testlab_1.toJSON(user));
|
|
44
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(stored)).to.containDeep((0, testlab_1.toJSON)(user));
|
|
45
45
|
});
|
|
46
46
|
let Role = class Role extends repository_1.Entity {
|
|
47
47
|
};
|
|
48
|
-
tslib_1.__decorate([
|
|
49
|
-
repository_1.property(),
|
|
50
|
-
tslib_1.__metadata("design:type", String)
|
|
48
|
+
(0, tslib_1.__decorate)([
|
|
49
|
+
(0, repository_1.property)(),
|
|
50
|
+
(0, tslib_1.__metadata)("design:type", String)
|
|
51
51
|
], Role.prototype, "name", void 0);
|
|
52
|
-
Role = tslib_1.__decorate([
|
|
53
|
-
repository_1.model()
|
|
52
|
+
Role = (0, tslib_1.__decorate)([
|
|
53
|
+
(0, repository_1.model)()
|
|
54
54
|
], Role);
|
|
55
55
|
let Address = class Address extends repository_1.Entity {
|
|
56
56
|
};
|
|
57
|
-
tslib_1.__decorate([
|
|
58
|
-
repository_1.property(),
|
|
59
|
-
tslib_1.__metadata("design:type", String)
|
|
57
|
+
(0, tslib_1.__decorate)([
|
|
58
|
+
(0, repository_1.property)(),
|
|
59
|
+
(0, tslib_1.__metadata)("design:type", String)
|
|
60
60
|
], Address.prototype, "street", void 0);
|
|
61
|
-
Address = tslib_1.__decorate([
|
|
62
|
-
repository_1.model()
|
|
61
|
+
Address = (0, tslib_1.__decorate)([
|
|
62
|
+
(0, repository_1.model)()
|
|
63
63
|
], Address);
|
|
64
64
|
let User = class User extends repository_1.Entity {
|
|
65
65
|
};
|
|
66
|
-
tslib_1.__decorate([
|
|
67
|
-
repository_1.property({
|
|
66
|
+
(0, tslib_1.__decorate)([
|
|
67
|
+
(0, repository_1.property)({
|
|
68
68
|
id: true,
|
|
69
69
|
generated: true,
|
|
70
70
|
useDefaultIdType: true,
|
|
71
71
|
}),
|
|
72
|
-
tslib_1.__metadata("design:type", Object)
|
|
72
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
73
73
|
], User.prototype, "id", void 0);
|
|
74
|
-
tslib_1.__decorate([
|
|
75
|
-
repository_1.property({ type: 'string' }),
|
|
76
|
-
tslib_1.__metadata("design:type", String)
|
|
74
|
+
(0, tslib_1.__decorate)([
|
|
75
|
+
(0, repository_1.property)({ type: 'string' }),
|
|
76
|
+
(0, tslib_1.__metadata)("design:type", String)
|
|
77
77
|
], User.prototype, "name", void 0);
|
|
78
|
-
tslib_1.__decorate([
|
|
78
|
+
(0, tslib_1.__decorate)([
|
|
79
79
|
repository_1.property.array(Role),
|
|
80
|
-
tslib_1.__metadata("design:type", Array)
|
|
80
|
+
(0, tslib_1.__metadata)("design:type", Array)
|
|
81
81
|
], User.prototype, "roles", void 0);
|
|
82
|
-
tslib_1.__decorate([
|
|
83
|
-
repository_1.property(),
|
|
84
|
-
tslib_1.__metadata("design:type", Address)
|
|
82
|
+
(0, tslib_1.__decorate)([
|
|
83
|
+
(0, repository_1.property)(),
|
|
84
|
+
(0, tslib_1.__metadata)("design:type", Address)
|
|
85
85
|
], User.prototype, "address", void 0);
|
|
86
|
-
User = tslib_1.__decorate([
|
|
87
|
-
repository_1.model()
|
|
86
|
+
User = (0, tslib_1.__decorate)([
|
|
87
|
+
(0, repository_1.model)()
|
|
88
88
|
], User);
|
|
89
89
|
});
|
|
90
90
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nested-model-properties.suite.js","sourceRoot":"","sources":["../../src/crud/nested-model-properties.suite.ts"],"names":[],"mappings":";AAAA,iDAAiD;AACjD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;;AAEhE,qDAO8B;AAC9B,+CAAiD;AACjD,0EAIqC;AAQrC,SAAgB,2BAA2B,CACzC,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAEtB,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACxC,IAAI,EAAsB,CAAC;QAC3B,IAAI,QAA8D,CAAC;QAEnE,MAAM,CAAC,6DAAkC,CAAC,CAAC;QAE3C,MAAM,CACJ,sCAAW,
|
|
1
|
+
{"version":3,"file":"nested-model-properties.suite.js","sourceRoot":"","sources":["../../src/crud/nested-model-properties.suite.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,16 +10,16 @@ const helpers_repository_tests_1 = require("../../../helpers.repository-tests");
|
|
|
10
10
|
const models_1 = require("../fixtures/models");
|
|
11
11
|
const helpers_1 = require("../helpers");
|
|
12
12
|
function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass, features) {
|
|
13
|
-
testlab_1.skipIf(!features.supportsInclusionResolvers, describe, 'BelongsTo inclusion resolvers - acceptance', suite);
|
|
13
|
+
(0, testlab_1.skipIf)(!features.supportsInclusionResolvers, describe, 'BelongsTo inclusion resolvers - acceptance', suite);
|
|
14
14
|
function suite() {
|
|
15
15
|
before(helpers_repository_tests_1.deleteAllModelsInDefaultDataSource);
|
|
16
16
|
let customerRepo;
|
|
17
17
|
let orderRepo;
|
|
18
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
18
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
19
19
|
// this helper should create the inclusion resolvers and also
|
|
20
20
|
// register inclusion resolvers for us
|
|
21
|
-
({ customerRepo, orderRepo } = helpers_1.givenBoundCrudRepositories(ctx.dataSource, repositoryClass, features));
|
|
22
|
-
testlab_1.expect(orderRepo.customer.inclusionResolver).to.be.Function();
|
|
21
|
+
({ customerRepo, orderRepo } = (0, helpers_1.givenBoundCrudRepositories)(ctx.dataSource, repositoryClass, features));
|
|
22
|
+
(0, testlab_1.expect)(orderRepo.customer.inclusionResolver).to.be.Function();
|
|
23
23
|
await ctx.dataSource.automigrate([models_1.Customer.name, models_1.Order.name]);
|
|
24
24
|
}));
|
|
25
25
|
beforeEach(async () => {
|
|
@@ -32,7 +32,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
32
32
|
description: 'an order',
|
|
33
33
|
customerId: customer.id,
|
|
34
34
|
});
|
|
35
|
-
await testlab_1.expect(orderRepo.find({ include: ['shipment'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "shipment"`);
|
|
35
|
+
await (0, testlab_1.expect)(orderRepo.find({ include: ['shipment'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "shipment"`);
|
|
36
36
|
});
|
|
37
37
|
it('returns single model instance including single related instance', async () => {
|
|
38
38
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -52,7 +52,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
52
52
|
parentId: features.emptyValue,
|
|
53
53
|
},
|
|
54
54
|
};
|
|
55
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual([testlab_1.toJSON(expected)]);
|
|
55
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual([(0, testlab_1.toJSON)(expected)]);
|
|
56
56
|
});
|
|
57
57
|
it('returns multiple model instances including related instances', async () => {
|
|
58
58
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -88,7 +88,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
88
88
|
},
|
|
89
89
|
},
|
|
90
90
|
];
|
|
91
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
91
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
92
92
|
});
|
|
93
93
|
it('returns a specified instance including its related model instances', async () => {
|
|
94
94
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -113,7 +113,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
113
113
|
parentId: features.emptyValue,
|
|
114
114
|
},
|
|
115
115
|
};
|
|
116
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
116
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
117
117
|
});
|
|
118
118
|
it('queries entities with null foreign key', async () => {
|
|
119
119
|
const customer = await customerRepo.create({
|
|
@@ -146,7 +146,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
146
146
|
},
|
|
147
147
|
];
|
|
148
148
|
const result = await orderRepo.find({ include: ['customer'] });
|
|
149
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
149
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
150
150
|
});
|
|
151
151
|
it('throws error if the target repository does not have the registered resolver', async () => {
|
|
152
152
|
const customer = await customerRepo.create({ name: 'customer' });
|
|
@@ -156,7 +156,7 @@ function belongsToInclusionResolverAcceptance(dataSourceOptions, repositoryClass
|
|
|
156
156
|
});
|
|
157
157
|
// unregister the resolver
|
|
158
158
|
orderRepo.inclusionResolvers.delete('customer');
|
|
159
|
-
await testlab_1.expect(orderRepo.find({ include: ['customer'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "customer"`);
|
|
159
|
+
await (0, testlab_1.expect)(orderRepo.find({ include: ['customer'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "customer"`);
|
|
160
160
|
});
|
|
161
161
|
}
|
|
162
162
|
}
|
package/dist/crud/relations/acceptance/belongs-to.inclusion-resolver.relation.acceptance.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"belongs-to.inclusion-resolver.relation.acceptance.js","sourceRoot":"","sources":["../../../../src/crud/relations/acceptance/belongs-to.inclusion-resolver.relation.acceptance.ts"],"names":[],"mappings":";AAAA,sDAAsD;AACtD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;AAEhE,+CAAyD;AAQzD,gFAG2C;AAC3C,+CAK4B;AAC5B,wCAAsD;AAEtD,SAAgB,oCAAoC,CAClD,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAEtB,gBAAM,
|
|
1
|
+
{"version":3,"file":"belongs-to.inclusion-resolver.relation.acceptance.js","sourceRoot":"","sources":["../../../../src/crud/relations/acceptance/belongs-to.inclusion-resolver.relation.acceptance.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,8 +17,8 @@ function belongsToRelationAcceptance(dataSourceOptions, repositoryClass, feature
|
|
|
17
17
|
let customerRepo;
|
|
18
18
|
let orderRepo;
|
|
19
19
|
let shipmentRepo;
|
|
20
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
21
|
-
({ customerRepo, orderRepo, shipmentRepo } = helpers_1.givenBoundCrudRepositories(ctx.dataSource, repositoryClass, features));
|
|
20
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
21
|
+
({ customerRepo, orderRepo, shipmentRepo } = (0, helpers_1.givenBoundCrudRepositories)(ctx.dataSource, repositoryClass, features));
|
|
22
22
|
const models = [models_1.Customer, models_1.Order, models_1.Shipment];
|
|
23
23
|
await ctx.dataSource.automigrate(models.map(m => m.name));
|
|
24
24
|
}));
|
|
@@ -37,7 +37,7 @@ function belongsToRelationAcceptance(dataSourceOptions, repositoryClass, feature
|
|
|
37
37
|
const result = await orderRepo.customer(order.id);
|
|
38
38
|
// adding parentId to customer so MySQL doesn't complain about null vs
|
|
39
39
|
// undefined
|
|
40
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON({ ...customer, parentId: features.emptyValue }));
|
|
40
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)({ ...customer, parentId: features.emptyValue }));
|
|
41
41
|
});
|
|
42
42
|
it('can find shipment of order with a custom foreign key name', async () => {
|
|
43
43
|
const shipment = await shipmentRepo.create({
|
|
@@ -50,7 +50,7 @@ function belongsToRelationAcceptance(dataSourceOptions, repositoryClass, feature
|
|
|
50
50
|
description: 'Order that is shipped Tuesday morning',
|
|
51
51
|
});
|
|
52
52
|
const result = await orderRepo.shipment(order.id);
|
|
53
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(shipment));
|
|
53
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(shipment));
|
|
54
54
|
});
|
|
55
55
|
it('returns undefined if the source instance does not have the foreign key', async () => {
|
|
56
56
|
await shipmentRepo.create({
|
|
@@ -61,7 +61,7 @@ function belongsToRelationAcceptance(dataSourceOptions, repositoryClass, feature
|
|
|
61
61
|
description: 'Order that is shipped Tuesday morning',
|
|
62
62
|
});
|
|
63
63
|
const result = await orderRepo.shipment(order.id);
|
|
64
|
-
testlab_1.expect(result).to.be.undefined();
|
|
64
|
+
(0, testlab_1.expect)(result).to.be.undefined();
|
|
65
65
|
});
|
|
66
66
|
it('throws EntityNotFound error when the related model does not exist', async () => {
|
|
67
67
|
const deletedCustomer = await customerRepo.create({
|
|
@@ -72,11 +72,11 @@ function belongsToRelationAcceptance(dataSourceOptions, repositoryClass, feature
|
|
|
72
72
|
description: 'custotmer will be deleted',
|
|
73
73
|
});
|
|
74
74
|
await customerRepo.deleteAll();
|
|
75
|
-
await testlab_1.expect(findCustomerOfOrder(order.id)).to.be.rejectedWith(repository_1.EntityNotFoundError);
|
|
75
|
+
await (0, testlab_1.expect)(findCustomerOfOrder(order.id)).to.be.rejectedWith(repository_1.EntityNotFoundError);
|
|
76
76
|
});
|
|
77
77
|
// helpers
|
|
78
78
|
function givenAccessor() {
|
|
79
|
-
findCustomerOfOrder = repository_1.createBelongsToAccessor(models_1.Order.definition.relations.customer, repository_1.Getter.fromValue(customerRepo), orderRepo);
|
|
79
|
+
findCustomerOfOrder = (0, repository_1.createBelongsToAccessor)(models_1.Order.definition.relations.customer, repository_1.Getter.fromValue(customerRepo), orderRepo);
|
|
80
80
|
}
|
|
81
81
|
});
|
|
82
82
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"belongs-to.relation.acceptance.js","sourceRoot":"","sources":["../../../../src/crud/relations/acceptance/belongs-to.relation.acceptance.ts"],"names":[],"mappings":";AAAA,sDAAsD;AACtD,0CAA0C;AAC1C,+CAA+C;AAC/C,gEAAgE;;;AAEhE,qDAM8B;AAC9B,+CAAiD;AACjD,gFAG2C;AAO3C,+CAO4B;AAC5B,wCAAsD;AAEtD,SAAgB,2BAA2B,CACzC,iBAAoC,EACpC,eAAmC,EACnC,QAAsB;IAEtB,QAAQ,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,6DAAkC,CAAC,CAAC;QAE3C,IAAI,mBAGH,CAAC;QACF,IAAI,YAAgC,CAAC;QACrC,IAAI,SAA0B,CAAC;QAC/B,IAAI,YAAgC,CAAC;QAErC,MAAM,CACJ,sCAAW,
|
|
1
|
+
{"version":3,"file":"belongs-to.relation.acceptance.js","sourceRoot":"","sources":["../../../../src/crud/relations/acceptance/belongs-to.relation.acceptance.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,17 +10,17 @@ const helpers_repository_tests_1 = require("../../../helpers.repository-tests");
|
|
|
10
10
|
const models_1 = require("../fixtures/models");
|
|
11
11
|
const helpers_1 = require("../helpers");
|
|
12
12
|
function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass, features) {
|
|
13
|
-
testlab_1.skipIf(!features.supportsInclusionResolvers, describe, 'HasMany inclusion resolvers - acceptance', suite);
|
|
13
|
+
(0, testlab_1.skipIf)(!features.supportsInclusionResolvers, describe, 'HasMany inclusion resolvers - acceptance', suite);
|
|
14
14
|
function suite() {
|
|
15
15
|
before(helpers_repository_tests_1.deleteAllModelsInDefaultDataSource);
|
|
16
16
|
let customerRepo;
|
|
17
17
|
let orderRepo;
|
|
18
18
|
let shipmentRepo;
|
|
19
|
-
before(helpers_repository_tests_1.withCrudCtx(async function setupRepository(ctx) {
|
|
19
|
+
before((0, helpers_repository_tests_1.withCrudCtx)(async function setupRepository(ctx) {
|
|
20
20
|
// this helper should create the inclusion resolvers and also
|
|
21
21
|
// register inclusion resolvers for us
|
|
22
|
-
({ customerRepo, orderRepo, shipmentRepo } = helpers_1.givenBoundCrudRepositories(ctx.dataSource, repositoryClass, features));
|
|
23
|
-
testlab_1.expect(customerRepo.orders.inclusionResolver).to.be.Function();
|
|
22
|
+
({ customerRepo, orderRepo, shipmentRepo } = (0, helpers_1.givenBoundCrudRepositories)(ctx.dataSource, repositoryClass, features));
|
|
23
|
+
(0, testlab_1.expect)(customerRepo.orders.inclusionResolver).to.be.Function();
|
|
24
24
|
await ctx.dataSource.automigrate([models_1.Customer.name, models_1.Order.name]);
|
|
25
25
|
}));
|
|
26
26
|
beforeEach(async () => {
|
|
@@ -34,7 +34,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
34
34
|
description: 'an order',
|
|
35
35
|
customerId: customer.id,
|
|
36
36
|
});
|
|
37
|
-
await testlab_1.expect(customerRepo.find({ include: ['managers'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "managers"`);
|
|
37
|
+
await (0, testlab_1.expect)(customerRepo.find({ include: ['managers'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "managers"`);
|
|
38
38
|
});
|
|
39
39
|
it('returns single model instance including single related instance', async () => {
|
|
40
40
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -45,8 +45,8 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
45
45
|
const result = await customerRepo.find({
|
|
46
46
|
include: ['orders'],
|
|
47
47
|
});
|
|
48
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual([
|
|
49
|
-
testlab_1.toJSON({
|
|
48
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual([
|
|
49
|
+
(0, testlab_1.toJSON)({
|
|
50
50
|
...thor,
|
|
51
51
|
parentId: features.emptyValue,
|
|
52
52
|
orders: [
|
|
@@ -106,7 +106,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
106
106
|
],
|
|
107
107
|
},
|
|
108
108
|
];
|
|
109
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
109
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
110
110
|
});
|
|
111
111
|
it('returns a specified instance including its related model instances', async () => {
|
|
112
112
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -137,7 +137,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
137
137
|
},
|
|
138
138
|
],
|
|
139
139
|
};
|
|
140
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
140
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
141
141
|
});
|
|
142
142
|
it('returns related models with non-id property as a source key(keyFrom)', async () => {
|
|
143
143
|
const shipment = await shipmentRepo.create({
|
|
@@ -153,7 +153,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
153
153
|
const found = await shipmentRepo.find({
|
|
154
154
|
include: ['shipmentOrders'],
|
|
155
155
|
});
|
|
156
|
-
testlab_1.expect(testlab_1.toJSON(found)).containDeep(testlab_1.toJSON([
|
|
156
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(found)).containDeep((0, testlab_1.toJSON)([
|
|
157
157
|
{
|
|
158
158
|
...shipment,
|
|
159
159
|
shipmentOrders: [
|
|
@@ -166,7 +166,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
166
166
|
},
|
|
167
167
|
]));
|
|
168
168
|
});
|
|
169
|
-
testlab_1.skipIf(features.hasRevisionToken, it, 'returns inclusions after running save() operation', async () => {
|
|
169
|
+
(0, testlab_1.skipIf)(features.hasRevisionToken, it, 'returns inclusions after running save() operation', async () => {
|
|
170
170
|
// this shows save() works well with func ensurePersistable and ObjectId
|
|
171
171
|
// the test skips for Cloudant as it needs the _rev property for replacement.
|
|
172
172
|
// see replace-by-id.suite.ts
|
|
@@ -194,9 +194,9 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
194
194
|
},
|
|
195
195
|
],
|
|
196
196
|
};
|
|
197
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.containEql(testlab_1.toJSON(expected));
|
|
197
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.containEql((0, testlab_1.toJSON)(expected));
|
|
198
198
|
});
|
|
199
|
-
testlab_1.skipIf(features.hasRevisionToken, it, 'returns inclusions after running replaceById() operation', async () => {
|
|
199
|
+
(0, testlab_1.skipIf)(features.hasRevisionToken, it, 'returns inclusions after running replaceById() operation', async () => {
|
|
200
200
|
// this shows replaceById() works well with func ensurePersistable and ObjectId
|
|
201
201
|
// the test skips for Cloudant as it needs the _rev property for replacement.
|
|
202
202
|
// see replace-by-id.suite.ts
|
|
@@ -233,7 +233,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
233
233
|
],
|
|
234
234
|
},
|
|
235
235
|
];
|
|
236
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
236
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
237
237
|
});
|
|
238
238
|
it('returns inclusions after running updateById() operation', async () => {
|
|
239
239
|
const thor = await customerRepo.create({ name: 'Thor' });
|
|
@@ -244,7 +244,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
244
244
|
});
|
|
245
245
|
const pizza = await orderRepo.findById(thorOrder.id.toString());
|
|
246
246
|
pizza.customerId = odin.id;
|
|
247
|
-
const reheatedPizza = testlab_1.toJSON(pizza);
|
|
247
|
+
const reheatedPizza = (0, testlab_1.toJSON)(pizza);
|
|
248
248
|
await orderRepo.updateById(pizza.id, reheatedPizza);
|
|
249
249
|
const odinPizza = await orderRepo.findById(thorOrder.id);
|
|
250
250
|
const result = await customerRepo.find({
|
|
@@ -267,7 +267,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
267
267
|
],
|
|
268
268
|
},
|
|
269
269
|
];
|
|
270
|
-
testlab_1.expect(testlab_1.toJSON(result)).to.deepEqual(testlab_1.toJSON(expected));
|
|
270
|
+
(0, testlab_1.expect)((0, testlab_1.toJSON)(result)).to.deepEqual((0, testlab_1.toJSON)(expected));
|
|
271
271
|
});
|
|
272
272
|
it('throws when navigational properties are present when updating model instance with save()', async () => {
|
|
273
273
|
// save() calls replaceById so the result will be the same for replaceById
|
|
@@ -281,14 +281,14 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
281
281
|
const found = await customerRepo.findById(customerId, {
|
|
282
282
|
include: ['orders'],
|
|
283
283
|
});
|
|
284
|
-
testlab_1.expect(found.orders).to.have.lengthOf(1);
|
|
284
|
+
(0, testlab_1.expect)(found.orders).to.have.lengthOf(1);
|
|
285
285
|
const wrongOrder = await orderRepo.create({
|
|
286
286
|
description: 'wrong order',
|
|
287
287
|
customerId: anotherCus.id,
|
|
288
288
|
});
|
|
289
289
|
found.name = 'updated name';
|
|
290
290
|
found.orders.push(wrongOrder);
|
|
291
|
-
await testlab_1.expect(customerRepo.save(found)).to.be.rejectedWith(/Navigational properties are not allowed.*"orders"/);
|
|
291
|
+
await (0, testlab_1.expect)(customerRepo.save(found)).to.be.rejectedWith(/Navigational properties are not allowed.*"orders"/);
|
|
292
292
|
});
|
|
293
293
|
it('throws error if the target repository does not have the registered resolver', async () => {
|
|
294
294
|
const customer = await customerRepo.create({ name: 'customer' });
|
|
@@ -298,7 +298,7 @@ function hasManyInclusionResolverAcceptance(dataSourceOptions, repositoryClass,
|
|
|
298
298
|
});
|
|
299
299
|
// unregister the resolver
|
|
300
300
|
customerRepo.inclusionResolvers.delete('orders');
|
|
301
|
-
await testlab_1.expect(customerRepo.find({ include: ['orders'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "orders"`);
|
|
301
|
+
await (0, testlab_1.expect)(customerRepo.find({ include: ['orders'] })).to.be.rejectedWith(`Invalid "filter.include" entries: "orders"`);
|
|
302
302
|
});
|
|
303
303
|
}
|
|
304
304
|
}
|