pure-orm 4.0.0 → 4.0.2
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 +97 -43
- package/coverage/clover.xml +969 -626
- package/coverage/coverage-final.json +34 -22
- package/coverage/lcov-report/dist/src/core.js.html +220 -190
- package/coverage/lcov-report/dist/src/driver-integrations/index.html +97 -0
- package/coverage/lcov-report/dist/src/driver-integrations/pgp.js.html +240 -0
- package/coverage/lcov-report/dist/src/index.html +44 -18
- package/coverage/lcov-report/dist/src/index.js.html +2 -2
- package/coverage/lcov-report/dist/src/orm.js.html +125 -119
- package/coverage/lcov-report/dist/test-utils/blog/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/blog/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/blog/models/article.js.html +15 -15
- package/coverage/lcov-report/dist/test-utils/blog/models/article_tag.js.html +7 -7
- package/coverage/lcov-report/dist/test-utils/blog/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/blog/models/person.js.html +13 -13
- package/coverage/lcov-report/dist/test-utils/blog/models/tag.js.html +4 -4
- package/coverage/lcov-report/dist/test-utils/five/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/order.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/parcel-event.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/parcel-line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/five/models/parcel.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/fourteen/entities.js.html +87 -0
- package/coverage/lcov-report/dist/test-utils/fourteen/index.html +97 -0
- package/coverage/lcov-report/dist/test-utils/fourteen/models/customer.js.html +159 -0
- package/coverage/lcov-report/dist/test-utils/fourteen/models/index.html +110 -0
- package/coverage/lcov-report/dist/test-utils/fourteen/models/person.js.html +138 -0
- package/coverage/lcov-report/dist/test-utils/nine/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/nine/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/nine/models/feature-switch.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/nine/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order/entities.js.html +11 -11
- package/coverage/lcov-report/dist/test-utils/order/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order/models/line-item.js.html +24 -24
- package/coverage/lcov-report/dist/test-utils/order/models/order.js.html +42 -42
- package/coverage/lcov-report/dist/test-utils/order/models/product-variant.js.html +23 -23
- package/coverage/lcov-report/dist/test-utils/order/models/product.js.html +17 -17
- package/coverage/lcov-report/dist/test-utils/order/models/utm-source.js.html +12 -12
- package/coverage/lcov-report/dist/test-utils/order-more/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/actual-product-variant.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/color.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/customer.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/gender.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/inventory-level.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/order.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/parcel-event.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/parcel-line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/parcel.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/physical-address.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/product-variant-image.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/product-variant.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/product.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/refund.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/shipment-actual-product-variant.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/shipment.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/size.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/utm-medium.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/order-more/models/utm-source.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/customer.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/order.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/parcel-line-item.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/six/models/parcel.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/audience.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/brand.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/category.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/member.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/passion.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/product.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/recommendation-audience.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/thirteen/models/recommendation.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/three/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/three/results.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/twelve/entities.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/twelve/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/twelve/models/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/twelve/models/member.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/twelve/models/prompt.js.html +1 -1
- package/coverage/lcov-report/dist/test-utils/two/index.html +1 -1
- package/coverage/lcov-report/dist/test-utils/two/results.js.html +1 -1
- package/coverage/lcov-report/index.html +105 -27
- package/coverage/lcov-report/src/core.ts.html +235 -196
- package/coverage/lcov-report/src/driver-integrations/index.html +97 -0
- package/coverage/lcov-report/src/driver-integrations/pgp.ts.html +345 -0
- package/coverage/lcov-report/src/index.html +44 -18
- package/coverage/lcov-report/src/index.ts.html +3 -15
- package/coverage/lcov-report/src/orm.ts.html +256 -130
- package/coverage/lcov-report/test-utils/blog/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/blog/index.html +1 -1
- package/coverage/lcov-report/test-utils/blog/models/article.ts.html +15 -15
- package/coverage/lcov-report/test-utils/blog/models/article_tag.ts.html +7 -7
- package/coverage/lcov-report/test-utils/blog/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/blog/models/person.ts.html +13 -13
- package/coverage/lcov-report/test-utils/blog/models/tag.ts.html +4 -4
- package/coverage/lcov-report/test-utils/five/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/five/index.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/order.ts.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/parcel-event.ts.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/parcel-line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/five/models/parcel.ts.html +1 -1
- package/coverage/lcov-report/test-utils/fourteen/entities.ts.html +78 -0
- package/coverage/lcov-report/test-utils/fourteen/index.html +97 -0
- package/coverage/lcov-report/test-utils/fourteen/models/customer.ts.html +177 -0
- package/coverage/lcov-report/test-utils/fourteen/models/index.html +110 -0
- package/coverage/lcov-report/test-utils/fourteen/models/person.ts.html +150 -0
- package/coverage/lcov-report/test-utils/nine/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/nine/index.html +1 -1
- package/coverage/lcov-report/test-utils/nine/models/feature-switch.ts.html +1 -1
- package/coverage/lcov-report/test-utils/nine/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/order/entities.ts.html +5 -5
- package/coverage/lcov-report/test-utils/order/index.html +1 -1
- package/coverage/lcov-report/test-utils/order/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/order/models/line-item.ts.html +18 -18
- package/coverage/lcov-report/test-utils/order/models/order.ts.html +37 -37
- package/coverage/lcov-report/test-utils/order/models/product-variant.ts.html +18 -18
- package/coverage/lcov-report/test-utils/order/models/product.ts.html +13 -13
- package/coverage/lcov-report/test-utils/order/models/utm-source.ts.html +8 -8
- package/coverage/lcov-report/test-utils/order-more/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/index.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/actual-product-variant.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/color.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/customer.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/gender.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/inventory-level.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/order.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/parcel-event.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/parcel-line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/parcel.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/physical-address.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/product-variant-image.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/product-variant.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/product.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/refund.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/shipment-actual-product-variant.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/shipment.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/size.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/utm-medium.ts.html +1 -1
- package/coverage/lcov-report/test-utils/order-more/models/utm-source.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/index.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/customer.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/order.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/parcel-line-item.ts.html +1 -1
- package/coverage/lcov-report/test-utils/six/models/parcel.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/index.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/audience.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/brand.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/category.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/member.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/passion.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/product.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/recommendation-audience.ts.html +1 -1
- package/coverage/lcov-report/test-utils/thirteen/models/recommendation.ts.html +1 -1
- package/coverage/lcov-report/test-utils/three/index.html +1 -1
- package/coverage/lcov-report/test-utils/three/results.js.html +1 -1
- package/coverage/lcov-report/test-utils/twelve/entities.ts.html +1 -1
- package/coverage/lcov-report/test-utils/twelve/index.html +1 -1
- package/coverage/lcov-report/test-utils/twelve/models/index.html +1 -1
- package/coverage/lcov-report/test-utils/twelve/models/member.ts.html +1 -1
- package/coverage/lcov-report/test-utils/twelve/models/prompt.ts.html +1 -1
- package/coverage/lcov-report/test-utils/two/index.html +1 -1
- package/coverage/lcov-report/test-utils/two/results.js.html +1 -1
- package/coverage/lcov.info +1686 -1005
- package/dist/src/core.d.ts +1 -1
- package/dist/src/core.js +18 -8
- package/dist/src/core.spec.js +643 -540
- package/dist/src/driver-integrations/index.d.ts +1 -0
- package/dist/src/orm.d.ts +21 -0
- package/dist/src/orm.js +6 -2
- package/dist/src/orm.spec.d.ts +1 -0
- package/dist/src/orm.spec.js +102 -0
- package/dist/test-utils/fourteen/entities.d.ts +6 -0
- package/dist/test-utils/fourteen/entities.js +6 -0
- package/dist/test-utils/fourteen/entities.ts +3 -0
- package/dist/test-utils/fourteen/models/customer.d.ts +19 -0
- package/dist/test-utils/fourteen/models/customer.js +30 -0
- package/dist/test-utils/fourteen/models/customer.ts +36 -0
- package/dist/test-utils/fourteen/models/person.d.ts +17 -0
- package/dist/test-utils/fourteen/models/person.js +23 -0
- package/dist/test-utils/fourteen/models/person.ts +27 -0
- package/dist/test-utils/fourteen/results.json +8 -0
- package/dist/test-utils/order/entities.js +2 -2
- package/dist/test-utils/order/entities.ts +2 -2
- package/dist/test-utils/order/models/order.js +1 -1
- package/dist/test-utils/order/models/order.ts +1 -1
- package/package.json +1 -1
- package/src/core.spec.ts +1112 -986
- package/src/core.ts +27 -14
- package/src/driver-integrations/index.ts +2 -0
- package/src/orm.spec.ts +113 -0
- package/src/orm.ts +54 -8
- package/test-utils/fourteen/entities.ts +3 -0
- package/test-utils/fourteen/models/customer.ts +36 -0
- package/test-utils/fourteen/models/person.ts +27 -0
- package/test-utils/fourteen/results.json +8 -0
- package/test-utils/order/entities.ts +2 -2
- package/test-utils/order/models/order.ts +1 -1
|
@@ -5,6 +5,7 @@ export interface ICreateForDriverOptions {
|
|
|
5
5
|
logError?: (err: Error) => never;
|
|
6
6
|
}
|
|
7
7
|
export interface ICoreIntegratedDriver extends ICore {
|
|
8
|
+
db: any;
|
|
8
9
|
one: <T extends IModel>(query: string, values?: object, errorHandler?: (err: Error) => never) => T;
|
|
9
10
|
oneOrNone: <T extends IModel>(query: string, values?: object, errorHandler?: (err: Error) => never) => T | void;
|
|
10
11
|
many: <T extends ICollection<IModel>>(query: string, values?: object, errorHandler?: (err: Error) => never) => T;
|
package/dist/src/orm.d.ts
CHANGED
|
@@ -16,5 +16,26 @@ export interface IPureORM extends ICoreIntegratedDriver {
|
|
|
16
16
|
}) => T;
|
|
17
17
|
delete: <T extends IModel>(model: T) => void;
|
|
18
18
|
deleteMatching: <T extends IModel>(model: T) => void;
|
|
19
|
+
getSqlInsertParts: (model: IModel) => {
|
|
20
|
+
columns: string;
|
|
21
|
+
values: Array<string>;
|
|
22
|
+
valuesVar: Array<string>;
|
|
23
|
+
};
|
|
24
|
+
getSqlUpdateParts: (model: IModel, on?: string) => {
|
|
25
|
+
clause: string;
|
|
26
|
+
idVar: string;
|
|
27
|
+
values: Array<string>;
|
|
28
|
+
};
|
|
29
|
+
getMatchingParts: (model: IModel) => {
|
|
30
|
+
whereClause: string;
|
|
31
|
+
values: Array<string>;
|
|
32
|
+
};
|
|
33
|
+
getMatchingPartsObject: (model: IModel) => {
|
|
34
|
+
whereClause: string;
|
|
35
|
+
values: Array<string>;
|
|
36
|
+
};
|
|
37
|
+
getNewWith: (model: IModel, sqlColumns: any, values: any) => IModel;
|
|
38
|
+
getValueBySqlColumn: (model: IModel, sqlColumn: string) => string;
|
|
39
|
+
getSqlColumnForPropertyName: (model: IModel, propertyName: string) => string;
|
|
19
40
|
}
|
|
20
41
|
export declare const create: ({ entities: externalEntities, db, logError }: ICreateOptions) => IPureORM;
|
package/dist/src/orm.js
CHANGED
|
@@ -91,6 +91,9 @@ const create = ({ entities: externalEntities, db, logError }) => {
|
|
|
91
91
|
const getValueBySqlColumn = (model, sqlColumn) => {
|
|
92
92
|
return model[orm.getEntityByModel(model).propertyNames[orm.getEntityByModel(model).columnNames.indexOf(sqlColumn)]];
|
|
93
93
|
};
|
|
94
|
+
const getSqlColumnForPropertyName = (model, propertyName) => {
|
|
95
|
+
return orm.getEntityByModel(model).columnNames[orm.getEntityByModel(model).propertyNames.indexOf(propertyName)];
|
|
96
|
+
};
|
|
94
97
|
/* ------------------------------------------------------------------------*/
|
|
95
98
|
/* Built-in basic CRUD functions ------------------------------------------*/
|
|
96
99
|
/* ------------------------------------------------------------------------*/
|
|
@@ -110,7 +113,7 @@ const create = ({ entities: externalEntities, db, logError }) => {
|
|
|
110
113
|
const query = `
|
|
111
114
|
UPDATE "${orm.getEntityByModel(model).tableName}"
|
|
112
115
|
SET ${clause}
|
|
113
|
-
WHERE "${orm.getEntityByModel(model).tableName}".${on} = ${idVar}
|
|
116
|
+
WHERE "${orm.getEntityByModel(model).tableName}".${getSqlColumnForPropertyName(model, on)} = ${idVar}
|
|
114
117
|
RETURNING ${orm.getEntityByModel(model).selectColumnsClause};
|
|
115
118
|
`;
|
|
116
119
|
return orm.one(query, values);
|
|
@@ -184,7 +187,8 @@ const create = ({ entities: externalEntities, db, logError }) => {
|
|
|
184
187
|
getMatchingParts,
|
|
185
188
|
getMatchingPartsObject,
|
|
186
189
|
getNewWith,
|
|
187
|
-
getValueBySqlColumn
|
|
190
|
+
getValueBySqlColumn,
|
|
191
|
+
getSqlColumnForPropertyName
|
|
188
192
|
});
|
|
189
193
|
};
|
|
190
194
|
exports.create = create;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
/* eslint-disable max-len */
|
|
4
|
+
const index_1 = require("./index");
|
|
5
|
+
const entities_1 = require("../test-utils/order/entities");
|
|
6
|
+
test('getSqlInsertParts', () => {
|
|
7
|
+
const orm = (0, index_1.create)({
|
|
8
|
+
entities: entities_1.entities,
|
|
9
|
+
db: { $config: { pgp: true } }
|
|
10
|
+
});
|
|
11
|
+
const order = new entities_1.entities[0].Model({
|
|
12
|
+
id: 1,
|
|
13
|
+
email: 'test@test.com',
|
|
14
|
+
subtotalPrice: 100,
|
|
15
|
+
utmSourceId: 10
|
|
16
|
+
});
|
|
17
|
+
expect(orm.getSqlInsertParts(order)).toEqual({
|
|
18
|
+
columns: '"id", "email", "subtotal_price", "utm_source_id"',
|
|
19
|
+
values: [1, 'test@test.com', 100, 10],
|
|
20
|
+
valuesVar: ['$1', '$2', '$3', '$4']
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
test('getSqlUpdateParts', () => {
|
|
24
|
+
const orm = (0, index_1.create)({
|
|
25
|
+
entities: entities_1.entities,
|
|
26
|
+
db: { $config: { pgp: true } }
|
|
27
|
+
});
|
|
28
|
+
const order = new entities_1.entities[0].Model({
|
|
29
|
+
id: 1,
|
|
30
|
+
email: 'test@test.com',
|
|
31
|
+
subtotalPrice: 100,
|
|
32
|
+
utmSourceId: 10
|
|
33
|
+
});
|
|
34
|
+
expect(orm.getSqlUpdateParts(order)).toEqual({
|
|
35
|
+
clause: '"id" = $1, "email" = $2, "subtotal_price" = $3, "utm_source_id" = $4',
|
|
36
|
+
idVar: '$5',
|
|
37
|
+
values: [1, 'test@test.com', 100, 10, 1]
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
test('getMatchingParts', () => {
|
|
41
|
+
const orm = (0, index_1.create)({
|
|
42
|
+
entities: entities_1.entities,
|
|
43
|
+
db: { $config: { pgp: true } }
|
|
44
|
+
});
|
|
45
|
+
const order = new entities_1.entities[0].Model({
|
|
46
|
+
id: 1,
|
|
47
|
+
email: 'test@test.com',
|
|
48
|
+
subtotalPrice: 100,
|
|
49
|
+
utmSourceId: 10
|
|
50
|
+
});
|
|
51
|
+
expect(orm.getMatchingParts(order)).toEqual({
|
|
52
|
+
values: [1, 'test@test.com', 100, 10],
|
|
53
|
+
whereClause: '"order"."id" = $1 AND "order"."email" = $2 AND "order"."subtotal_price" = $3 AND "order"."utm_source_id" = $4'
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
test('getMatchingPartsObject', () => {
|
|
57
|
+
const orm = (0, index_1.create)({
|
|
58
|
+
entities: entities_1.entities,
|
|
59
|
+
db: { $config: { pgp: true } }
|
|
60
|
+
});
|
|
61
|
+
const order = new entities_1.entities[0].Model({
|
|
62
|
+
id: 1,
|
|
63
|
+
email: 'test@test.com',
|
|
64
|
+
subtotalPrice: 100,
|
|
65
|
+
utmSourceId: 10
|
|
66
|
+
});
|
|
67
|
+
expect(orm.getMatchingPartsObject(order)).toEqual({
|
|
68
|
+
values: {
|
|
69
|
+
1: 1,
|
|
70
|
+
2: 'test@test.com',
|
|
71
|
+
3: 100,
|
|
72
|
+
4: 10
|
|
73
|
+
},
|
|
74
|
+
whereClause: '"order"."id" = $(1) AND "order"."email" = $(2) AND "order"."subtotal_price" = $(3) AND "order"."utm_source_id" = $(4)'
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
test('getValueBySqlColumn', () => {
|
|
78
|
+
const orm = (0, index_1.create)({
|
|
79
|
+
entities: entities_1.entities,
|
|
80
|
+
db: { $config: { pgp: true } }
|
|
81
|
+
});
|
|
82
|
+
const order = new entities_1.entities[0].Model({
|
|
83
|
+
id: 1,
|
|
84
|
+
email: 'test@test.com',
|
|
85
|
+
subtotalPrice: 100,
|
|
86
|
+
utmSourceId: 10
|
|
87
|
+
});
|
|
88
|
+
expect(orm.getValueBySqlColumn(order, 'id')).toEqual(1);
|
|
89
|
+
expect(orm.getValueBySqlColumn(order, 'email')).toEqual('test@test.com');
|
|
90
|
+
expect(orm.getValueBySqlColumn(order, 'subtotal_price')).toEqual(100);
|
|
91
|
+
expect(orm.getValueBySqlColumn(order, 'utm_source_id')).toEqual(10);
|
|
92
|
+
});
|
|
93
|
+
test('getSqlColumnForPropertyName', () => {
|
|
94
|
+
const orm = (0, index_1.create)({
|
|
95
|
+
entities: entities_1.entities,
|
|
96
|
+
db: { $config: { pgp: true } }
|
|
97
|
+
});
|
|
98
|
+
const order = new entities_1.entities[0].Model({ id: 1 });
|
|
99
|
+
expect(orm.getSqlColumnForPropertyName(order, 'id')).toEqual('id');
|
|
100
|
+
expect(orm.getSqlColumnForPropertyName(order, 'utmSourceId')).toEqual('utm_source_id');
|
|
101
|
+
expect(orm.getSqlColumnForPropertyName(order, 'browserIP')).toEqual('browser_ip');
|
|
102
|
+
});
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.entities = void 0;
|
|
4
|
+
const person_1 = require("./models/person");
|
|
5
|
+
const customer_1 = require("./models/customer");
|
|
6
|
+
exports.entities = [person_1.personEntity, customer_1.customerEntity];
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { IModel, ICollection, IColumns } from '../../../src/index';
|
|
2
|
+
export declare const tableName: string;
|
|
3
|
+
export declare const columns: IColumns;
|
|
4
|
+
export declare class Customer implements IModel {
|
|
5
|
+
id: number;
|
|
6
|
+
lockedToAffiliateId: number;
|
|
7
|
+
lockedToSalespersonId: number;
|
|
8
|
+
constructor(props: any);
|
|
9
|
+
}
|
|
10
|
+
export declare class Customers implements ICollection<Customer> {
|
|
11
|
+
models: Array<Customer>;
|
|
12
|
+
constructor({ models }: any);
|
|
13
|
+
}
|
|
14
|
+
export declare const customerEntity: {
|
|
15
|
+
tableName: string;
|
|
16
|
+
columns: import("../../../src/core").IColumn[];
|
|
17
|
+
Model: typeof Customer;
|
|
18
|
+
Collection: typeof Customers;
|
|
19
|
+
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.customerEntity = exports.Customers = exports.Customer = exports.columns = exports.tableName = void 0;
|
|
4
|
+
const person_1 = require("./person");
|
|
5
|
+
exports.tableName = 'customer';
|
|
6
|
+
exports.columns = [
|
|
7
|
+
'id',
|
|
8
|
+
{ column: 'locked_to_affiliate_id', references: person_1.Person },
|
|
9
|
+
{ column: 'locked_to_salesperson_id', references: person_1.Person }
|
|
10
|
+
];
|
|
11
|
+
class Customer {
|
|
12
|
+
constructor(props) {
|
|
13
|
+
this.id = props.id;
|
|
14
|
+
this.lockedToAffiliateId = props.lockedToAffiliateId;
|
|
15
|
+
this.lockedToSalespersonId = props.lockedToSalespersonId;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.Customer = Customer;
|
|
19
|
+
class Customers {
|
|
20
|
+
constructor({ models }) {
|
|
21
|
+
this.models = models;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.Customers = Customers;
|
|
25
|
+
exports.customerEntity = {
|
|
26
|
+
tableName: exports.tableName,
|
|
27
|
+
columns: exports.columns,
|
|
28
|
+
Model: Customer,
|
|
29
|
+
Collection: Customers
|
|
30
|
+
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { IModel, ICollection, IColumns } from '../../../src/index';
|
|
2
|
+
import { Person } from './person';
|
|
3
|
+
|
|
4
|
+
export const tableName: string = 'customer';
|
|
5
|
+
|
|
6
|
+
export const columns: IColumns = [
|
|
7
|
+
'id',
|
|
8
|
+
{ column: 'locked_to_affiliate_id', references: Person },
|
|
9
|
+
{ column: 'locked_to_salesperson_id', references: Person }
|
|
10
|
+
];
|
|
11
|
+
|
|
12
|
+
export class Customer implements IModel {
|
|
13
|
+
id: number;
|
|
14
|
+
lockedToAffiliateId: number;
|
|
15
|
+
lockedToSalespersonId: number;
|
|
16
|
+
|
|
17
|
+
constructor(props: any) {
|
|
18
|
+
this.id = props.id;
|
|
19
|
+
this.lockedToAffiliateId = props.lockedToAffiliateId;
|
|
20
|
+
this.lockedToSalespersonId = props.lockedToSalespersonId;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export class Customers implements ICollection<Customer> {
|
|
25
|
+
models: Array<Customer>;
|
|
26
|
+
constructor({ models }: any) {
|
|
27
|
+
this.models = models;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export const customerEntity = {
|
|
32
|
+
tableName,
|
|
33
|
+
columns,
|
|
34
|
+
Model: Customer,
|
|
35
|
+
Collection: Customers
|
|
36
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { IModel, ICollection, IColumns } from '../../../src/index';
|
|
2
|
+
export declare const tableName: string;
|
|
3
|
+
export declare const columns: IColumns;
|
|
4
|
+
export declare class Person implements IModel {
|
|
5
|
+
id: number;
|
|
6
|
+
constructor(props: any);
|
|
7
|
+
}
|
|
8
|
+
export declare class Persons implements ICollection<Person> {
|
|
9
|
+
models: Array<Person>;
|
|
10
|
+
constructor({ models }: any);
|
|
11
|
+
}
|
|
12
|
+
export declare const personEntity: {
|
|
13
|
+
tableName: string;
|
|
14
|
+
columns: import("../../../src/core").IColumn[];
|
|
15
|
+
Model: typeof Person;
|
|
16
|
+
Collection: typeof Persons;
|
|
17
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.personEntity = exports.Persons = exports.Person = exports.columns = exports.tableName = void 0;
|
|
4
|
+
exports.tableName = 'person';
|
|
5
|
+
exports.columns = ['id'];
|
|
6
|
+
class Person {
|
|
7
|
+
constructor(props) {
|
|
8
|
+
this.id = props.id;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.Person = Person;
|
|
12
|
+
class Persons {
|
|
13
|
+
constructor({ models }) {
|
|
14
|
+
this.models = models;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.Persons = Persons;
|
|
18
|
+
exports.personEntity = {
|
|
19
|
+
tableName: exports.tableName,
|
|
20
|
+
columns: exports.columns,
|
|
21
|
+
Model: Person,
|
|
22
|
+
Collection: Persons
|
|
23
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { IModel, ICollection, IColumns } from '../../../src/index';
|
|
2
|
+
|
|
3
|
+
export const tableName: string = 'person';
|
|
4
|
+
|
|
5
|
+
export const columns: IColumns = ['id'];
|
|
6
|
+
|
|
7
|
+
export class Person implements IModel {
|
|
8
|
+
id: number;
|
|
9
|
+
|
|
10
|
+
constructor(props: any) {
|
|
11
|
+
this.id = props.id;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export class Persons implements ICollection<Person> {
|
|
16
|
+
models: Array<Person>;
|
|
17
|
+
constructor({ models }: any) {
|
|
18
|
+
this.models = models;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const personEntity = {
|
|
23
|
+
tableName,
|
|
24
|
+
columns,
|
|
25
|
+
Model: Person,
|
|
26
|
+
Collection: Persons
|
|
27
|
+
};
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.entities = void 0;
|
|
4
|
-
const utm_source_1 = require("./models/utm-source");
|
|
5
4
|
const order_1 = require("./models/order");
|
|
5
|
+
const utm_source_1 = require("./models/utm-source");
|
|
6
6
|
const line_item_1 = require("./models/line-item");
|
|
7
7
|
const product_variant_1 = require("./models/product-variant");
|
|
8
8
|
const product_1 = require("./models/product");
|
|
9
9
|
exports.entities = [
|
|
10
|
-
utm_source_1.utmSourceEntity,
|
|
11
10
|
order_1.orderEntity,
|
|
11
|
+
utm_source_1.utmSourceEntity,
|
|
12
12
|
line_item_1.lineItemEntity,
|
|
13
13
|
product_variant_1.productVariantEntity,
|
|
14
14
|
product_1.productEntity
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { utmSourceEntity } from './models/utm-source';
|
|
2
1
|
import { orderEntity } from './models/order';
|
|
2
|
+
import { utmSourceEntity } from './models/utm-source';
|
|
3
3
|
import { lineItemEntity } from './models/line-item';
|
|
4
4
|
import { productVariantEntity } from './models/product-variant';
|
|
5
5
|
import { productEntity } from './models/product';
|
|
6
6
|
|
|
7
7
|
export const entities = [
|
|
8
|
-
utmSourceEntity,
|
|
9
8
|
orderEntity,
|
|
9
|
+
utmSourceEntity,
|
|
10
10
|
lineItemEntity,
|
|
11
11
|
productVariantEntity,
|
|
12
12
|
productEntity
|