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.
Files changed (217) hide show
  1. package/README.md +97 -43
  2. package/coverage/clover.xml +969 -626
  3. package/coverage/coverage-final.json +34 -22
  4. package/coverage/lcov-report/dist/src/core.js.html +220 -190
  5. package/coverage/lcov-report/dist/src/driver-integrations/index.html +97 -0
  6. package/coverage/lcov-report/dist/src/driver-integrations/pgp.js.html +240 -0
  7. package/coverage/lcov-report/dist/src/index.html +44 -18
  8. package/coverage/lcov-report/dist/src/index.js.html +2 -2
  9. package/coverage/lcov-report/dist/src/orm.js.html +125 -119
  10. package/coverage/lcov-report/dist/test-utils/blog/entities.js.html +1 -1
  11. package/coverage/lcov-report/dist/test-utils/blog/index.html +1 -1
  12. package/coverage/lcov-report/dist/test-utils/blog/models/article.js.html +15 -15
  13. package/coverage/lcov-report/dist/test-utils/blog/models/article_tag.js.html +7 -7
  14. package/coverage/lcov-report/dist/test-utils/blog/models/index.html +1 -1
  15. package/coverage/lcov-report/dist/test-utils/blog/models/person.js.html +13 -13
  16. package/coverage/lcov-report/dist/test-utils/blog/models/tag.js.html +4 -4
  17. package/coverage/lcov-report/dist/test-utils/five/entities.js.html +1 -1
  18. package/coverage/lcov-report/dist/test-utils/five/index.html +1 -1
  19. package/coverage/lcov-report/dist/test-utils/five/models/index.html +1 -1
  20. package/coverage/lcov-report/dist/test-utils/five/models/line-item.js.html +1 -1
  21. package/coverage/lcov-report/dist/test-utils/five/models/order.js.html +1 -1
  22. package/coverage/lcov-report/dist/test-utils/five/models/parcel-event.js.html +1 -1
  23. package/coverage/lcov-report/dist/test-utils/five/models/parcel-line-item.js.html +1 -1
  24. package/coverage/lcov-report/dist/test-utils/five/models/parcel.js.html +1 -1
  25. package/coverage/lcov-report/dist/test-utils/fourteen/entities.js.html +87 -0
  26. package/coverage/lcov-report/dist/test-utils/fourteen/index.html +97 -0
  27. package/coverage/lcov-report/dist/test-utils/fourteen/models/customer.js.html +159 -0
  28. package/coverage/lcov-report/dist/test-utils/fourteen/models/index.html +110 -0
  29. package/coverage/lcov-report/dist/test-utils/fourteen/models/person.js.html +138 -0
  30. package/coverage/lcov-report/dist/test-utils/nine/entities.js.html +1 -1
  31. package/coverage/lcov-report/dist/test-utils/nine/index.html +1 -1
  32. package/coverage/lcov-report/dist/test-utils/nine/models/feature-switch.js.html +1 -1
  33. package/coverage/lcov-report/dist/test-utils/nine/models/index.html +1 -1
  34. package/coverage/lcov-report/dist/test-utils/order/entities.js.html +11 -11
  35. package/coverage/lcov-report/dist/test-utils/order/index.html +1 -1
  36. package/coverage/lcov-report/dist/test-utils/order/models/index.html +1 -1
  37. package/coverage/lcov-report/dist/test-utils/order/models/line-item.js.html +24 -24
  38. package/coverage/lcov-report/dist/test-utils/order/models/order.js.html +42 -42
  39. package/coverage/lcov-report/dist/test-utils/order/models/product-variant.js.html +23 -23
  40. package/coverage/lcov-report/dist/test-utils/order/models/product.js.html +17 -17
  41. package/coverage/lcov-report/dist/test-utils/order/models/utm-source.js.html +12 -12
  42. package/coverage/lcov-report/dist/test-utils/order-more/entities.js.html +1 -1
  43. package/coverage/lcov-report/dist/test-utils/order-more/index.html +1 -1
  44. package/coverage/lcov-report/dist/test-utils/order-more/models/actual-product-variant.js.html +1 -1
  45. package/coverage/lcov-report/dist/test-utils/order-more/models/color.js.html +1 -1
  46. package/coverage/lcov-report/dist/test-utils/order-more/models/customer.js.html +1 -1
  47. package/coverage/lcov-report/dist/test-utils/order-more/models/gender.js.html +1 -1
  48. package/coverage/lcov-report/dist/test-utils/order-more/models/index.html +1 -1
  49. package/coverage/lcov-report/dist/test-utils/order-more/models/inventory-level.js.html +1 -1
  50. package/coverage/lcov-report/dist/test-utils/order-more/models/line-item.js.html +1 -1
  51. package/coverage/lcov-report/dist/test-utils/order-more/models/order.js.html +1 -1
  52. package/coverage/lcov-report/dist/test-utils/order-more/models/parcel-event.js.html +1 -1
  53. package/coverage/lcov-report/dist/test-utils/order-more/models/parcel-line-item.js.html +1 -1
  54. package/coverage/lcov-report/dist/test-utils/order-more/models/parcel.js.html +1 -1
  55. package/coverage/lcov-report/dist/test-utils/order-more/models/physical-address.js.html +1 -1
  56. package/coverage/lcov-report/dist/test-utils/order-more/models/product-variant-image.js.html +1 -1
  57. package/coverage/lcov-report/dist/test-utils/order-more/models/product-variant.js.html +1 -1
  58. package/coverage/lcov-report/dist/test-utils/order-more/models/product.js.html +1 -1
  59. package/coverage/lcov-report/dist/test-utils/order-more/models/refund.js.html +1 -1
  60. package/coverage/lcov-report/dist/test-utils/order-more/models/shipment-actual-product-variant.js.html +1 -1
  61. package/coverage/lcov-report/dist/test-utils/order-more/models/shipment.js.html +1 -1
  62. package/coverage/lcov-report/dist/test-utils/order-more/models/size.js.html +1 -1
  63. package/coverage/lcov-report/dist/test-utils/order-more/models/utm-medium.js.html +1 -1
  64. package/coverage/lcov-report/dist/test-utils/order-more/models/utm-source.js.html +1 -1
  65. package/coverage/lcov-report/dist/test-utils/six/entities.js.html +1 -1
  66. package/coverage/lcov-report/dist/test-utils/six/index.html +1 -1
  67. package/coverage/lcov-report/dist/test-utils/six/models/customer.js.html +1 -1
  68. package/coverage/lcov-report/dist/test-utils/six/models/index.html +1 -1
  69. package/coverage/lcov-report/dist/test-utils/six/models/line-item.js.html +1 -1
  70. package/coverage/lcov-report/dist/test-utils/six/models/order.js.html +1 -1
  71. package/coverage/lcov-report/dist/test-utils/six/models/parcel-line-item.js.html +1 -1
  72. package/coverage/lcov-report/dist/test-utils/six/models/parcel.js.html +1 -1
  73. package/coverage/lcov-report/dist/test-utils/thirteen/entities.js.html +1 -1
  74. package/coverage/lcov-report/dist/test-utils/thirteen/index.html +1 -1
  75. package/coverage/lcov-report/dist/test-utils/thirteen/models/audience.js.html +1 -1
  76. package/coverage/lcov-report/dist/test-utils/thirteen/models/brand.js.html +1 -1
  77. package/coverage/lcov-report/dist/test-utils/thirteen/models/category.js.html +1 -1
  78. package/coverage/lcov-report/dist/test-utils/thirteen/models/index.html +1 -1
  79. package/coverage/lcov-report/dist/test-utils/thirteen/models/member.js.html +1 -1
  80. package/coverage/lcov-report/dist/test-utils/thirteen/models/passion.js.html +1 -1
  81. package/coverage/lcov-report/dist/test-utils/thirteen/models/product.js.html +1 -1
  82. package/coverage/lcov-report/dist/test-utils/thirteen/models/recommendation-audience.js.html +1 -1
  83. package/coverage/lcov-report/dist/test-utils/thirteen/models/recommendation.js.html +1 -1
  84. package/coverage/lcov-report/dist/test-utils/three/index.html +1 -1
  85. package/coverage/lcov-report/dist/test-utils/three/results.js.html +1 -1
  86. package/coverage/lcov-report/dist/test-utils/twelve/entities.js.html +1 -1
  87. package/coverage/lcov-report/dist/test-utils/twelve/index.html +1 -1
  88. package/coverage/lcov-report/dist/test-utils/twelve/models/index.html +1 -1
  89. package/coverage/lcov-report/dist/test-utils/twelve/models/member.js.html +1 -1
  90. package/coverage/lcov-report/dist/test-utils/twelve/models/prompt.js.html +1 -1
  91. package/coverage/lcov-report/dist/test-utils/two/index.html +1 -1
  92. package/coverage/lcov-report/dist/test-utils/two/results.js.html +1 -1
  93. package/coverage/lcov-report/index.html +105 -27
  94. package/coverage/lcov-report/src/core.ts.html +235 -196
  95. package/coverage/lcov-report/src/driver-integrations/index.html +97 -0
  96. package/coverage/lcov-report/src/driver-integrations/pgp.ts.html +345 -0
  97. package/coverage/lcov-report/src/index.html +44 -18
  98. package/coverage/lcov-report/src/index.ts.html +3 -15
  99. package/coverage/lcov-report/src/orm.ts.html +256 -130
  100. package/coverage/lcov-report/test-utils/blog/entities.ts.html +1 -1
  101. package/coverage/lcov-report/test-utils/blog/index.html +1 -1
  102. package/coverage/lcov-report/test-utils/blog/models/article.ts.html +15 -15
  103. package/coverage/lcov-report/test-utils/blog/models/article_tag.ts.html +7 -7
  104. package/coverage/lcov-report/test-utils/blog/models/index.html +1 -1
  105. package/coverage/lcov-report/test-utils/blog/models/person.ts.html +13 -13
  106. package/coverage/lcov-report/test-utils/blog/models/tag.ts.html +4 -4
  107. package/coverage/lcov-report/test-utils/five/entities.ts.html +1 -1
  108. package/coverage/lcov-report/test-utils/five/index.html +1 -1
  109. package/coverage/lcov-report/test-utils/five/models/index.html +1 -1
  110. package/coverage/lcov-report/test-utils/five/models/line-item.ts.html +1 -1
  111. package/coverage/lcov-report/test-utils/five/models/order.ts.html +1 -1
  112. package/coverage/lcov-report/test-utils/five/models/parcel-event.ts.html +1 -1
  113. package/coverage/lcov-report/test-utils/five/models/parcel-line-item.ts.html +1 -1
  114. package/coverage/lcov-report/test-utils/five/models/parcel.ts.html +1 -1
  115. package/coverage/lcov-report/test-utils/fourteen/entities.ts.html +78 -0
  116. package/coverage/lcov-report/test-utils/fourteen/index.html +97 -0
  117. package/coverage/lcov-report/test-utils/fourteen/models/customer.ts.html +177 -0
  118. package/coverage/lcov-report/test-utils/fourteen/models/index.html +110 -0
  119. package/coverage/lcov-report/test-utils/fourteen/models/person.ts.html +150 -0
  120. package/coverage/lcov-report/test-utils/nine/entities.ts.html +1 -1
  121. package/coverage/lcov-report/test-utils/nine/index.html +1 -1
  122. package/coverage/lcov-report/test-utils/nine/models/feature-switch.ts.html +1 -1
  123. package/coverage/lcov-report/test-utils/nine/models/index.html +1 -1
  124. package/coverage/lcov-report/test-utils/order/entities.ts.html +5 -5
  125. package/coverage/lcov-report/test-utils/order/index.html +1 -1
  126. package/coverage/lcov-report/test-utils/order/models/index.html +1 -1
  127. package/coverage/lcov-report/test-utils/order/models/line-item.ts.html +18 -18
  128. package/coverage/lcov-report/test-utils/order/models/order.ts.html +37 -37
  129. package/coverage/lcov-report/test-utils/order/models/product-variant.ts.html +18 -18
  130. package/coverage/lcov-report/test-utils/order/models/product.ts.html +13 -13
  131. package/coverage/lcov-report/test-utils/order/models/utm-source.ts.html +8 -8
  132. package/coverage/lcov-report/test-utils/order-more/entities.ts.html +1 -1
  133. package/coverage/lcov-report/test-utils/order-more/index.html +1 -1
  134. package/coverage/lcov-report/test-utils/order-more/models/actual-product-variant.ts.html +1 -1
  135. package/coverage/lcov-report/test-utils/order-more/models/color.ts.html +1 -1
  136. package/coverage/lcov-report/test-utils/order-more/models/customer.ts.html +1 -1
  137. package/coverage/lcov-report/test-utils/order-more/models/gender.ts.html +1 -1
  138. package/coverage/lcov-report/test-utils/order-more/models/index.html +1 -1
  139. package/coverage/lcov-report/test-utils/order-more/models/inventory-level.ts.html +1 -1
  140. package/coverage/lcov-report/test-utils/order-more/models/line-item.ts.html +1 -1
  141. package/coverage/lcov-report/test-utils/order-more/models/order.ts.html +1 -1
  142. package/coverage/lcov-report/test-utils/order-more/models/parcel-event.ts.html +1 -1
  143. package/coverage/lcov-report/test-utils/order-more/models/parcel-line-item.ts.html +1 -1
  144. package/coverage/lcov-report/test-utils/order-more/models/parcel.ts.html +1 -1
  145. package/coverage/lcov-report/test-utils/order-more/models/physical-address.ts.html +1 -1
  146. package/coverage/lcov-report/test-utils/order-more/models/product-variant-image.ts.html +1 -1
  147. package/coverage/lcov-report/test-utils/order-more/models/product-variant.ts.html +1 -1
  148. package/coverage/lcov-report/test-utils/order-more/models/product.ts.html +1 -1
  149. package/coverage/lcov-report/test-utils/order-more/models/refund.ts.html +1 -1
  150. package/coverage/lcov-report/test-utils/order-more/models/shipment-actual-product-variant.ts.html +1 -1
  151. package/coverage/lcov-report/test-utils/order-more/models/shipment.ts.html +1 -1
  152. package/coverage/lcov-report/test-utils/order-more/models/size.ts.html +1 -1
  153. package/coverage/lcov-report/test-utils/order-more/models/utm-medium.ts.html +1 -1
  154. package/coverage/lcov-report/test-utils/order-more/models/utm-source.ts.html +1 -1
  155. package/coverage/lcov-report/test-utils/six/entities.ts.html +1 -1
  156. package/coverage/lcov-report/test-utils/six/index.html +1 -1
  157. package/coverage/lcov-report/test-utils/six/models/customer.ts.html +1 -1
  158. package/coverage/lcov-report/test-utils/six/models/index.html +1 -1
  159. package/coverage/lcov-report/test-utils/six/models/line-item.ts.html +1 -1
  160. package/coverage/lcov-report/test-utils/six/models/order.ts.html +1 -1
  161. package/coverage/lcov-report/test-utils/six/models/parcel-line-item.ts.html +1 -1
  162. package/coverage/lcov-report/test-utils/six/models/parcel.ts.html +1 -1
  163. package/coverage/lcov-report/test-utils/thirteen/entities.ts.html +1 -1
  164. package/coverage/lcov-report/test-utils/thirteen/index.html +1 -1
  165. package/coverage/lcov-report/test-utils/thirteen/models/audience.ts.html +1 -1
  166. package/coverage/lcov-report/test-utils/thirteen/models/brand.ts.html +1 -1
  167. package/coverage/lcov-report/test-utils/thirteen/models/category.ts.html +1 -1
  168. package/coverage/lcov-report/test-utils/thirteen/models/index.html +1 -1
  169. package/coverage/lcov-report/test-utils/thirteen/models/member.ts.html +1 -1
  170. package/coverage/lcov-report/test-utils/thirteen/models/passion.ts.html +1 -1
  171. package/coverage/lcov-report/test-utils/thirteen/models/product.ts.html +1 -1
  172. package/coverage/lcov-report/test-utils/thirteen/models/recommendation-audience.ts.html +1 -1
  173. package/coverage/lcov-report/test-utils/thirteen/models/recommendation.ts.html +1 -1
  174. package/coverage/lcov-report/test-utils/three/index.html +1 -1
  175. package/coverage/lcov-report/test-utils/three/results.js.html +1 -1
  176. package/coverage/lcov-report/test-utils/twelve/entities.ts.html +1 -1
  177. package/coverage/lcov-report/test-utils/twelve/index.html +1 -1
  178. package/coverage/lcov-report/test-utils/twelve/models/index.html +1 -1
  179. package/coverage/lcov-report/test-utils/twelve/models/member.ts.html +1 -1
  180. package/coverage/lcov-report/test-utils/twelve/models/prompt.ts.html +1 -1
  181. package/coverage/lcov-report/test-utils/two/index.html +1 -1
  182. package/coverage/lcov-report/test-utils/two/results.js.html +1 -1
  183. package/coverage/lcov.info +1686 -1005
  184. package/dist/src/core.d.ts +1 -1
  185. package/dist/src/core.js +18 -8
  186. package/dist/src/core.spec.js +643 -540
  187. package/dist/src/driver-integrations/index.d.ts +1 -0
  188. package/dist/src/orm.d.ts +21 -0
  189. package/dist/src/orm.js +6 -2
  190. package/dist/src/orm.spec.d.ts +1 -0
  191. package/dist/src/orm.spec.js +102 -0
  192. package/dist/test-utils/fourteen/entities.d.ts +6 -0
  193. package/dist/test-utils/fourteen/entities.js +6 -0
  194. package/dist/test-utils/fourteen/entities.ts +3 -0
  195. package/dist/test-utils/fourteen/models/customer.d.ts +19 -0
  196. package/dist/test-utils/fourteen/models/customer.js +30 -0
  197. package/dist/test-utils/fourteen/models/customer.ts +36 -0
  198. package/dist/test-utils/fourteen/models/person.d.ts +17 -0
  199. package/dist/test-utils/fourteen/models/person.js +23 -0
  200. package/dist/test-utils/fourteen/models/person.ts +27 -0
  201. package/dist/test-utils/fourteen/results.json +8 -0
  202. package/dist/test-utils/order/entities.js +2 -2
  203. package/dist/test-utils/order/entities.ts +2 -2
  204. package/dist/test-utils/order/models/order.js +1 -1
  205. package/dist/test-utils/order/models/order.ts +1 -1
  206. package/package.json +1 -1
  207. package/src/core.spec.ts +1112 -986
  208. package/src/core.ts +27 -14
  209. package/src/driver-integrations/index.ts +2 -0
  210. package/src/orm.spec.ts +113 -0
  211. package/src/orm.ts +54 -8
  212. package/test-utils/fourteen/entities.ts +3 -0
  213. package/test-utils/fourteen/models/customer.ts +36 -0
  214. package/test-utils/fourteen/models/person.ts +27 -0
  215. package/test-utils/fourteen/results.json +8 -0
  216. package/test-utils/order/entities.ts +2 -2
  217. 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
+ export declare const entities: {
2
+ tableName: string;
3
+ columns: import("../../src/core").IColumn[];
4
+ Model: typeof import("./models/person").Person;
5
+ Collection: typeof import("./models/person").Persons;
6
+ }[];
@@ -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,3 @@
1
+ import { personEntity } from './models/person';
2
+ import { customerEntity } from './models/customer';
3
+ export const entities = [personEntity, 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
+ };
@@ -0,0 +1,8 @@
1
+ [
2
+ {
3
+ "person#id": 67,
4
+ "customer#id": 4,
5
+ "customer#locked_to_affiliate_id": null,
6
+ "customer#locked_to_salesperson_id": 67
7
+ }
8
+ ]
@@ -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
@@ -6,7 +6,7 @@ exports.tableName = 'order';
6
6
  exports.columns = [
7
7
  'id',
8
8
  'email',
9
- 'browser_ip',
9
+ { column: 'browser_ip', property: 'browserIP' },
10
10
  'browser_user_agent',
11
11
  'kujo_imported_date',
12
12
  'created_date',
@@ -6,7 +6,7 @@ export const tableName: string = 'order';
6
6
  export const columns: IColumns = [
7
7
  'id',
8
8
  'email',
9
- 'browser_ip',
9
+ { column: 'browser_ip', property: 'browserIP' },
10
10
  'browser_user_agent',
11
11
  'kujo_imported_date',
12
12
  'created_date',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pure-orm",
3
- "version": "4.0.0",
3
+ "version": "4.0.2",
4
4
  "main": "dist/src/index.js",
5
5
  "types": "dist/src/index.d.ts",
6
6
  "engines": {