@contrail/flexplm 1.3.0 → 1.3.1-alpha.56221f6

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 (149) hide show
  1. package/lib/cli/commands/compile.d.ts +1 -0
  2. package/lib/cli/commands/compile.js +71 -0
  3. package/lib/cli/commands/compile.spec.d.ts +1 -0
  4. package/lib/cli/commands/compile.spec.js +80 -0
  5. package/lib/cli/commands/create.d.ts +1 -0
  6. package/lib/cli/commands/create.js +75 -0
  7. package/lib/cli/commands/create.spec.d.ts +1 -0
  8. package/lib/cli/commands/create.spec.js +78 -0
  9. package/lib/cli/commands/upload.d.ts +10 -0
  10. package/lib/cli/commands/upload.js +219 -0
  11. package/lib/cli/commands/upload.spec.d.ts +1 -0
  12. package/lib/cli/commands/upload.spec.js +88 -0
  13. package/lib/cli/index.d.ts +2 -0
  14. package/lib/cli/index.js +64 -0
  15. package/lib/cli/index.spec.d.ts +1 -0
  16. package/lib/cli/index.spec.js +79 -0
  17. package/lib/cli/template/mapping-template.ts.template +18 -0
  18. package/lib/entity-processor/base-entity-processor.d.ts +89 -42
  19. package/lib/entity-processor/base-entity-processor.js +438 -385
  20. package/lib/entity-processor/base-entity-processor.spec.d.ts +1 -1
  21. package/lib/entity-processor/base-entity-processor.spec.js +398 -397
  22. package/lib/flexplm-request.d.ts +3 -3
  23. package/lib/flexplm-request.js +34 -34
  24. package/lib/flexplm-utils.d.ts +5 -5
  25. package/lib/flexplm-utils.js +33 -33
  26. package/lib/flexplm-utils.spec.d.ts +1 -1
  27. package/lib/flexplm-utils.spec.js +26 -26
  28. package/lib/index.d.ts +23 -22
  29. package/lib/index.js +39 -38
  30. package/lib/interfaces/interfaces.d.ts +105 -105
  31. package/lib/interfaces/interfaces.js +2 -2
  32. package/lib/interfaces/item-family-changes.d.ts +20 -20
  33. package/lib/interfaces/item-family-changes.js +56 -56
  34. package/lib/interfaces/mapping-file.d.ts +429 -0
  35. package/lib/interfaces/mapping-file.js +2 -0
  36. package/lib/interfaces/publish-change-data.d.ts +19 -19
  37. package/lib/interfaces/publish-change-data.js +32 -32
  38. package/lib/publish/base-process-publish-assortment-callback.d.ts +9 -9
  39. package/lib/publish/base-process-publish-assortment-callback.js +38 -38
  40. package/lib/publish/base-process-publish-assortment.d.ts +118 -93
  41. package/lib/publish/base-process-publish-assortment.js +998 -944
  42. package/lib/publish/base-process-publish-assortment.spec.d.ts +1 -1
  43. package/lib/publish/base-process-publish-assortment.spec.js +1688 -1670
  44. package/lib/publish/mockData.d.ts +1389 -1389
  45. package/lib/publish/mockData.js +4524 -4519
  46. package/lib/transform/identifier-conversion-spec-mockData.js +472 -444
  47. package/lib/transform/identifier-conversion.d.ts +51 -15
  48. package/lib/transform/identifier-conversion.js +248 -212
  49. package/lib/transform/identifier-conversion.spec.d.ts +1 -1
  50. package/lib/transform/identifier-conversion.spec.js +343 -339
  51. package/lib/util/config-defaults.d.ts +8 -8
  52. package/lib/util/config-defaults.js +88 -85
  53. package/lib/util/config-defaults.spec.d.ts +1 -1
  54. package/lib/util/config-defaults.spec.js +302 -293
  55. package/lib/util/data-converter-spec-mockData.js +219 -205
  56. package/lib/util/data-converter.d.ts +136 -39
  57. package/lib/util/data-converter.js +718 -592
  58. package/lib/util/data-converter.spec.d.ts +1 -1
  59. package/lib/util/data-converter.spec.js +906 -904
  60. package/lib/util/error-response-object.d.ts +9 -4
  61. package/lib/util/error-response-object.js +54 -47
  62. package/lib/util/error-response-object.spec.d.ts +1 -1
  63. package/lib/util/error-response-object.spec.js +99 -99
  64. package/lib/util/event-short-message-status.d.ts +19 -19
  65. package/lib/util/event-short-message-status.js +24 -23
  66. package/lib/util/federation.d.ts +15 -15
  67. package/lib/util/federation.js +157 -149
  68. package/lib/util/flexplm-connect.d.ts +29 -22
  69. package/lib/util/flexplm-connect.js +190 -176
  70. package/lib/util/flexplm-connect.spec.d.ts +1 -1
  71. package/lib/util/flexplm-connect.spec.js +88 -88
  72. package/lib/util/logger-config.d.ts +1 -1
  73. package/lib/util/logger-config.js +27 -26
  74. package/lib/util/map-util-spec-mockData.js +219 -205
  75. package/lib/util/map-utils.d.ts +33 -6
  76. package/lib/util/map-utils.js +42 -15
  77. package/lib/util/map-utils.spec.d.ts +1 -1
  78. package/lib/util/map-utils.spec.js +89 -89
  79. package/lib/util/mockData.d.ts +80 -80
  80. package/lib/util/mockData.js +103 -103
  81. package/lib/util/thumbnail-util.d.ts +55 -34
  82. package/lib/util/thumbnail-util.js +242 -215
  83. package/lib/util/thumbnail-util.spec.d.ts +1 -1
  84. package/lib/util/thumbnail-util.spec.js +440 -434
  85. package/lib/util/type-conversion-utils-spec-mockData.js +259 -259
  86. package/lib/util/type-conversion-utils.d.ts +163 -23
  87. package/lib/util/type-conversion-utils.js +408 -265
  88. package/lib/util/type-conversion-utils.spec.d.ts +1 -1
  89. package/lib/util/type-conversion-utils.spec.js +868 -868
  90. package/lib/util/type-defaults.d.ts +74 -16
  91. package/lib/util/type-defaults.js +279 -221
  92. package/lib/util/type-defaults.spec.d.ts +1 -1
  93. package/lib/util/type-defaults.spec.js +516 -516
  94. package/lib/util/type-utils.d.ts +34 -13
  95. package/lib/util/type-utils.js +137 -114
  96. package/lib/util/type-utils.spec.d.ts +1 -1
  97. package/lib/util/type-utils.spec.js +192 -190
  98. package/package.json +21 -6
  99. package/scripts/copy-template.js +10 -0
  100. package/.claude/settings.local.json +0 -8
  101. package/.github/pull_request_template.md +0 -31
  102. package/.github/workflows/flexplm-lib.yml +0 -27
  103. package/.github/workflows/publish-to-npm.yml +0 -124
  104. package/CHANGELOG.md +0 -32
  105. package/publish.bat +0 -5
  106. package/publish.sh +0 -5
  107. package/src/entity-processor/base-entity-processor.spec.ts +0 -460
  108. package/src/entity-processor/base-entity-processor.ts +0 -515
  109. package/src/flexplm-request.ts +0 -28
  110. package/src/flexplm-utils.spec.ts +0 -27
  111. package/src/flexplm-utils.ts +0 -29
  112. package/src/index.ts +0 -22
  113. package/src/interfaces/interfaces.ts +0 -122
  114. package/src/interfaces/item-family-changes.ts +0 -67
  115. package/src/interfaces/publish-change-data.ts +0 -43
  116. package/src/publish/base-process-publish-assortment-callback.ts +0 -50
  117. package/src/publish/base-process-publish-assortment.spec.ts +0 -1992
  118. package/src/publish/base-process-publish-assortment.ts +0 -1134
  119. package/src/publish/mockData.ts +0 -4561
  120. package/src/transform/identifier-conversion-spec-mockData.ts +0 -496
  121. package/src/transform/identifier-conversion.spec.ts +0 -354
  122. package/src/transform/identifier-conversion.ts +0 -282
  123. package/src/util/config-defaults.spec.ts +0 -350
  124. package/src/util/config-defaults.ts +0 -93
  125. package/src/util/data-converter-spec-mockData.ts +0 -231
  126. package/src/util/data-converter.spec.ts +0 -1041
  127. package/src/util/data-converter.ts +0 -762
  128. package/src/util/error-response-object.spec.ts +0 -116
  129. package/src/util/error-response-object.ts +0 -50
  130. package/src/util/event-short-message-status.ts +0 -22
  131. package/src/util/federation.ts +0 -172
  132. package/src/util/flexplm-connect.spec.ts +0 -132
  133. package/src/util/flexplm-connect.ts +0 -208
  134. package/src/util/logger-config.ts +0 -20
  135. package/src/util/map-util-spec-mockData.ts +0 -231
  136. package/src/util/map-utils.spec.ts +0 -103
  137. package/src/util/map-utils.ts +0 -41
  138. package/src/util/mockData.ts +0 -101
  139. package/src/util/thumbnail-util.spec.ts +0 -508
  140. package/src/util/thumbnail-util.ts +0 -272
  141. package/src/util/type-conversion-utils-spec-mockData.ts +0 -271
  142. package/src/util/type-conversion-utils.spec.ts +0 -968
  143. package/src/util/type-conversion-utils.ts +0 -460
  144. package/src/util/type-defaults.spec.ts +0 -669
  145. package/src/util/type-defaults.ts +0 -281
  146. package/src/util/type-utils.spec.ts +0 -227
  147. package/src/util/type-utils.ts +0 -144
  148. package/tsconfig.json +0 -29
  149. package/tslint.json +0 -57
@@ -1,339 +1,343 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const transform_data_1 = require("@contrail/transform-data");
4
- const identifier_conversion_1 = require("./identifier-conversion");
5
- const data_converter_1 = require("../util/data-converter");
6
- const sdk_1 = require("@contrail/sdk");
7
- const mapFile1Data = require('./identifier-conversion-spec-mockData');
8
- const mapFile1Mappings = mapFile1Data?.mapping;
9
- const mapFile2Mappings = mapFile1Data?.mapping2;
10
- const mappings = {
11
- mapFile1: mapFile1Mappings,
12
- mapFile2: mapFile2Mappings
13
- };
14
- describe('getAssortmentFromObject', () => {
15
- const transformMapFile1 = 'mapFile1';
16
- const transformMapFile2 = 'mapFile2';
17
- const config = {};
18
- const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
19
- mapFileUtil.getMapFile = async (fileId) => {
20
- return mappings[fileId];
21
- };
22
- const dc = new data_converter_1.DataConverter(config, mapFileUtil);
23
- dc.getEntityValues = async (objectClass, data, keysToSkip = []) => {
24
- const entityValues = {};
25
- for (const key of Object.keys(data)) {
26
- const value = data[key];
27
- if (value) {
28
- const to = typeof value;
29
- if (['string', 'number', 'boolean'].includes(to)) {
30
- entityValues[key] = value;
31
- }
32
- else if (Array.isArray(value)) {
33
- entityValues[key] = value.map((v) => v.value);
34
- }
35
- else if (value.value) {
36
- entityValues[key] = value.value;
37
- }
38
- }
39
- }
40
- return entityValues;
41
- };
42
- it('should error if no object is provided', async () => {
43
- try {
44
- await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, null);
45
- }
46
- catch (e) {
47
- expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_OBJECT));
48
- }
49
- });
50
- it('should error if no flexPLMObjectClass is provided', async () => {
51
- try {
52
- await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, {});
53
- }
54
- catch (e) {
55
- expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_FLEXPLM_OBJECT_CLASS));
56
- }
57
- });
58
- it('should return the assortment criteria from the object - flexPLMSeasonName', async () => {
59
- const object = {
60
- "brand": {
61
- "display": "Vibe IQ",
62
- "value": "vibeiq"
63
- },
64
- "flexPLMObjectClass": "LCSSeason",
65
- "flexPLMTypePath": "Season",
66
- "seasonName": "Vibe IQ Spring 2004",
67
- "seasonType": {
68
- "display": "Spring",
69
- "value": "spring"
70
- },
71
- "year": {
72
- "display": "2004",
73
- "value": "2004"
74
- }
75
- };
76
- const criteriaObject = {
77
- flexPLMObjectClass: 'LCSSeason',
78
- flexPLMSeasonName: 'Vibe IQ Spring 2004',
79
- flexPLMTypePath: 'Season'
80
- };
81
- const resultsObject = {
82
- flexPLMSeasonName: 'Vibe IQ Spring 2004'
83
- };
84
- let getEntityValuesSpyOn = undefined;
85
- try {
86
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
87
- const result = await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
88
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSeason', criteriaObject, []);
89
- expect(result).toEqual(resultsObject);
90
- }
91
- finally {
92
- if (getEntityValuesSpyOn) {
93
- getEntityValuesSpyOn.mockRestore();
94
- }
95
- }
96
- });
97
- it('should return the assortment criteria from the object - brand,year,seasonType', async () => {
98
- const object = {
99
- brand: {
100
- display: "Vibe IQ",
101
- value: "vibeiq"
102
- },
103
- flexPLMObjectClass: "LCSSeason",
104
- flexPLMTypePath: "Season",
105
- seasonName: "Vibe IQ Spring 2004",
106
- seasonType: {
107
- display: "Spring",
108
- value: "spring"
109
- },
110
- year: {
111
- "display": "2004",
112
- "value": "2004"
113
- }
114
- };
115
- const criteriaObject = {
116
- flexPLMObjectClass: 'LCSSeason',
117
- brand: {
118
- "display": "Vibe IQ",
119
- "value": "vibeiq"
120
- },
121
- year: {
122
- "display": "2004",
123
- "value": "2004"
124
- },
125
- seasonType: {
126
- "display": "Spring",
127
- "value": "spring"
128
- },
129
- flexPLMTypePath: 'Season'
130
- };
131
- const resultsObject = {
132
- brand: 'vibeiq',
133
- year: '2004',
134
- seasonType: 'spring'
135
- };
136
- let getEntityValuesSpyOn = undefined;
137
- try {
138
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
139
- const result = await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile2, mapFileUtil, dc, object);
140
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSeason', criteriaObject, []);
141
- expect(result).toEqual(resultsObject);
142
- }
143
- finally {
144
- if (getEntityValuesSpyOn) {
145
- getEntityValuesSpyOn.mockRestore();
146
- }
147
- }
148
- });
149
- });
150
- describe('getItemCriteriaFromObject', () => {
151
- const transformMapFile1 = 'mapFile1';
152
- const transformMapFile2 = 'mapFile2';
153
- const config = {};
154
- const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
155
- mapFileUtil.getMapFile = async (fileId) => {
156
- return mappings[fileId];
157
- };
158
- const dc = new data_converter_1.DataConverter(config, mapFileUtil);
159
- dc.getEntityValues = async (objectClass, data, keysToSkip = []) => {
160
- const entityValues = {};
161
- for (const key of Object.keys(data)) {
162
- const value = data[key];
163
- if (value) {
164
- const to = typeof value;
165
- if (['string', 'number', 'boolean'].includes(to)) {
166
- entityValues[key] = value;
167
- }
168
- else if (Array.isArray(value)) {
169
- entityValues[key] = value.map((v) => v.value);
170
- }
171
- else if (value.value) {
172
- entityValues[key] = value.value;
173
- }
174
- }
175
- }
176
- return entityValues;
177
- };
178
- it('should error if no object is provided', async () => {
179
- try {
180
- await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, null);
181
- }
182
- catch (e) {
183
- expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_OBJECT));
184
- }
185
- });
186
- it('should error if no flexPLMObjectClass is provided', async () => {
187
- try {
188
- await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, {});
189
- }
190
- catch (e) {
191
- expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_FLEXPLM_OBJECT_CLASS));
192
- }
193
- });
194
- it('should error if missing identifier properties -itemNumber', async () => {
195
- const object = {
196
- "flexBoolean": false,
197
- "flexMultiSelect": [],
198
- "flexNumber": 0,
199
- "flexPLMObjectClass": "LCSProduct",
200
- "flexPLMTypePath": "Product\\Pants",
201
- "flexSingleList": {
202
- "display": "Five",
203
- "value": "five"
204
- },
205
- "productName": "Feb 3 - 1 Option A",
206
- "NotvibeIQIdentifier": 966
207
- };
208
- const criteriaObject = {
209
- flexPLMObjectClass: 'LCSProduct',
210
- flexPLMTypePath: 'Product\\Pants',
211
- };
212
- let getEntityValuesSpyOn = undefined;
213
- try {
214
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
215
- await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
216
- }
217
- catch (e) {
218
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSProduct', criteriaObject, []);
219
- expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.INBOUND_ENTITY_MISSING_IDENIFIER_PROPS));
220
- }
221
- finally {
222
- if (getEntityValuesSpyOn) {
223
- getEntityValuesSpyOn.mockRestore();
224
- }
225
- }
226
- });
227
- it('should return the item family criteria from the object -itemNumber', async () => {
228
- const object = {
229
- "flexBoolean": false,
230
- "flexMultiSelect": [],
231
- "flexNumber": 0,
232
- "flexPLMObjectClass": "LCSProduct",
233
- "flexPLMTypePath": "Product\\Pants",
234
- "flexSingleList": {
235
- "display": "Five",
236
- "value": "five"
237
- },
238
- "productName": "Feb 3 - 1 Option A",
239
- "vibeIQIdentifier": 966
240
- };
241
- const criteriaObject = {
242
- flexPLMObjectClass: 'LCSProduct',
243
- itemNumber: 966,
244
- flexPLMTypePath: 'Product\\Pants',
245
- };
246
- const resultsObject = {
247
- roles: 'family',
248
- itemNumber: 966
249
- };
250
- let getEntityValuesSpyOn = undefined;
251
- try {
252
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
253
- const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
254
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSProduct', criteriaObject, []);
255
- expect(result).toEqual(resultsObject);
256
- }
257
- finally {
258
- if (getEntityValuesSpyOn) {
259
- getEntityValuesSpyOn.mockRestore();
260
- }
261
- }
262
- });
263
- it('should return the item option criteria from the object -itemNumber', async () => {
264
- const object = {
265
- "flexBoolean": false,
266
- "flexMultiSelect": [],
267
- "flexNumber": 0,
268
- "flexPLMObjectClass": "LCSSKU",
269
- "flexPLMTypePath": "Product\\Pants",
270
- "flexSingleList": {
271
- "display": "Five",
272
- "value": "five"
273
- },
274
- "productName": "Feb 3 - 1 Option A",
275
- "vibeIQIdentifier": 2876
276
- };
277
- const criteriaObject = {
278
- flexPLMObjectClass: 'LCSSKU',
279
- itemNumber: 2876,
280
- flexPLMTypePath: 'Product\\Pants',
281
- };
282
- const resultsObject = {
283
- roles: 'color',
284
- itemNumber: 2876
285
- };
286
- let getEntityValuesSpyOn = undefined;
287
- try {
288
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
289
- const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
290
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSKU', criteriaObject, []);
291
- expect(result).toEqual(resultsObject);
292
- }
293
- finally {
294
- if (getEntityValuesSpyOn) {
295
- getEntityValuesSpyOn.mockRestore();
296
- }
297
- }
298
- });
299
- it('should return the item option criteria from the object -uniqueIdentifierA, uniqueIdentifierB', async () => {
300
- const object = {
301
- "flexBoolean": false,
302
- "flexMultiSelect": [],
303
- "flexNumber": 0,
304
- "flexPLMObjectClass": "LCSSKU",
305
- "flexPLMTypePath": "Product\\Pants",
306
- "flexSingleList": {
307
- "display": "Five",
308
- "value": "five"
309
- },
310
- "productName": "Feb 3 - 1 Option A",
311
- uniqueIdentifierA: 28,
312
- uniqueIdentifierB: 29,
313
- "vibeIQIdentifier": 2876
314
- };
315
- const criteriaObject = {
316
- flexPLMObjectClass: 'LCSSKU',
317
- uniqueIdentifierA: 28,
318
- uniqueIdentifierB: 29,
319
- flexPLMTypePath: 'Product\\Pants',
320
- };
321
- const resultsObject = {
322
- roles: 'color',
323
- uniqueIdentifierA: 28,
324
- uniqueIdentifierB: 29,
325
- };
326
- let getEntityValuesSpyOn = undefined;
327
- try {
328
- getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
329
- const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile2, mapFileUtil, dc, object);
330
- expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSKU', criteriaObject, []);
331
- expect(result).toEqual(resultsObject);
332
- }
333
- finally {
334
- if (getEntityValuesSpyOn) {
335
- getEntityValuesSpyOn.mockRestore();
336
- }
337
- }
338
- });
339
- });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const transform_data_1 = require("@contrail/transform-data");
4
+ const identifier_conversion_1 = require("./identifier-conversion");
5
+ const data_converter_1 = require("../util/data-converter");
6
+ const sdk_1 = require("@contrail/sdk");
7
+ const mapFile1Data = require('./identifier-conversion-spec-mockData');
8
+ const mapFile1Mappings = mapFile1Data?.mapping;
9
+ const mapFile2Mappings = mapFile1Data?.mapping2;
10
+ const mappings = {
11
+ mapFile1: mapFile1Mappings,
12
+ mapFile2: mapFile2Mappings
13
+ };
14
+ describe('getAssortmentFromObject', () => {
15
+ const transformMapFile1 = 'mapFile1';
16
+ const transformMapFile2 = 'mapFile2';
17
+ const config = {};
18
+ const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
19
+ mapFileUtil.getMapFile = async (fileId) => {
20
+ return mappings[fileId];
21
+ };
22
+ const dc = new data_converter_1.DataConverter(config, mapFileUtil);
23
+ dc.getEntityValues = async (objectClass, data, keysToSkip = []) => {
24
+ const entityValues = {};
25
+ for (const key of Object.keys(data)) {
26
+ const value = data[key];
27
+ if (value) {
28
+ const to = typeof value;
29
+ if (['string', 'number', 'boolean'].includes(to)) {
30
+ entityValues[key] = value;
31
+ }
32
+ else if (Array.isArray(value)) {
33
+ //multi select
34
+ entityValues[key] = value.map((v) => v.value);
35
+ }
36
+ else if (value.value) {
37
+ //single select
38
+ entityValues[key] = value.value;
39
+ }
40
+ }
41
+ }
42
+ return entityValues;
43
+ };
44
+ it('should error if no object is provided', async () => {
45
+ try {
46
+ await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, null);
47
+ }
48
+ catch (e) {
49
+ expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_OBJECT));
50
+ }
51
+ });
52
+ it('should error if no flexPLMObjectClass is provided', async () => {
53
+ try {
54
+ await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, {});
55
+ }
56
+ catch (e) {
57
+ expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_FLEXPLM_OBJECT_CLASS));
58
+ }
59
+ });
60
+ it('should return the assortment criteria from the object - flexPLMSeasonName', async () => {
61
+ const object = {
62
+ "brand": {
63
+ "display": "Vibe IQ",
64
+ "value": "vibeiq"
65
+ },
66
+ "flexPLMObjectClass": "LCSSeason",
67
+ "flexPLMTypePath": "Season",
68
+ "seasonName": "Vibe IQ Spring 2004",
69
+ "seasonType": {
70
+ "display": "Spring",
71
+ "value": "spring"
72
+ },
73
+ "year": {
74
+ "display": "2004",
75
+ "value": "2004"
76
+ }
77
+ };
78
+ const criteriaObject = {
79
+ flexPLMObjectClass: 'LCSSeason',
80
+ flexPLMSeasonName: 'Vibe IQ Spring 2004',
81
+ flexPLMTypePath: 'Season'
82
+ };
83
+ const resultsObject = {
84
+ flexPLMSeasonName: 'Vibe IQ Spring 2004'
85
+ };
86
+ let getEntityValuesSpyOn = undefined;
87
+ try {
88
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
89
+ const result = await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
90
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSeason', criteriaObject, []);
91
+ expect(result).toEqual(resultsObject);
92
+ }
93
+ finally {
94
+ if (getEntityValuesSpyOn) {
95
+ getEntityValuesSpyOn.mockRestore();
96
+ }
97
+ }
98
+ });
99
+ it('should return the assortment criteria from the object - brand,year,seasonType', async () => {
100
+ const object = {
101
+ brand: {
102
+ display: "Vibe IQ",
103
+ value: "vibeiq"
104
+ },
105
+ flexPLMObjectClass: "LCSSeason",
106
+ flexPLMTypePath: "Season",
107
+ seasonName: "Vibe IQ Spring 2004",
108
+ seasonType: {
109
+ display: "Spring",
110
+ value: "spring"
111
+ },
112
+ year: {
113
+ "display": "2004",
114
+ "value": "2004"
115
+ }
116
+ };
117
+ const criteriaObject = {
118
+ flexPLMObjectClass: 'LCSSeason',
119
+ brand: {
120
+ "display": "Vibe IQ",
121
+ "value": "vibeiq"
122
+ },
123
+ year: {
124
+ "display": "2004",
125
+ "value": "2004"
126
+ },
127
+ seasonType: {
128
+ "display": "Spring",
129
+ "value": "spring"
130
+ },
131
+ flexPLMTypePath: 'Season'
132
+ };
133
+ const resultsObject = {
134
+ brand: 'vibeiq',
135
+ year: '2004',
136
+ seasonType: 'spring'
137
+ };
138
+ let getEntityValuesSpyOn = undefined;
139
+ try {
140
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
141
+ const result = await identifier_conversion_1.IdentifierConversion.getAssortmentCriteriaFromObject(transformMapFile2, mapFileUtil, dc, object);
142
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSeason', criteriaObject, []);
143
+ expect(result).toEqual(resultsObject);
144
+ }
145
+ finally {
146
+ if (getEntityValuesSpyOn) {
147
+ getEntityValuesSpyOn.mockRestore();
148
+ }
149
+ }
150
+ });
151
+ });
152
+ describe('getItemCriteriaFromObject', () => {
153
+ const transformMapFile1 = 'mapFile1';
154
+ const transformMapFile2 = 'mapFile2';
155
+ const config = {};
156
+ const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
157
+ mapFileUtil.getMapFile = async (fileId) => {
158
+ return mappings[fileId];
159
+ };
160
+ const dc = new data_converter_1.DataConverter(config, mapFileUtil);
161
+ dc.getEntityValues = async (objectClass, data, keysToSkip = []) => {
162
+ const entityValues = {};
163
+ for (const key of Object.keys(data)) {
164
+ const value = data[key];
165
+ if (value) {
166
+ const to = typeof value;
167
+ if (['string', 'number', 'boolean'].includes(to)) {
168
+ entityValues[key] = value;
169
+ }
170
+ else if (Array.isArray(value)) {
171
+ //multi select
172
+ entityValues[key] = value.map((v) => v.value);
173
+ }
174
+ else if (value.value) {
175
+ //single select
176
+ entityValues[key] = value.value;
177
+ }
178
+ }
179
+ }
180
+ return entityValues;
181
+ };
182
+ it('should error if no object is provided', async () => {
183
+ try {
184
+ await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, null);
185
+ }
186
+ catch (e) {
187
+ expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_OBJECT));
188
+ }
189
+ });
190
+ it('should error if no flexPLMObjectClass is provided', async () => {
191
+ try {
192
+ await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, {});
193
+ }
194
+ catch (e) {
195
+ expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.MISSING_FLEXPLM_OBJECT_CLASS));
196
+ }
197
+ });
198
+ it('should error if missing identifier properties -itemNumber', async () => {
199
+ const object = {
200
+ "flexBoolean": false,
201
+ "flexMultiSelect": [],
202
+ "flexNumber": 0,
203
+ "flexPLMObjectClass": "LCSProduct",
204
+ "flexPLMTypePath": "Product\\Pants",
205
+ "flexSingleList": {
206
+ "display": "Five",
207
+ "value": "five"
208
+ },
209
+ "productName": "Feb 3 - 1 Option A",
210
+ "NotvibeIQIdentifier": 966
211
+ };
212
+ const criteriaObject = {
213
+ flexPLMObjectClass: 'LCSProduct',
214
+ flexPLMTypePath: 'Product\\Pants',
215
+ };
216
+ let getEntityValuesSpyOn = undefined;
217
+ try {
218
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
219
+ await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
220
+ }
221
+ catch (e) {
222
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSProduct', criteriaObject, []);
223
+ expect(e.message).toEqual(expect.stringContaining(identifier_conversion_1.IdentifierConversion.INBOUND_ENTITY_MISSING_IDENIFIER_PROPS));
224
+ }
225
+ finally {
226
+ if (getEntityValuesSpyOn) {
227
+ getEntityValuesSpyOn.mockRestore();
228
+ }
229
+ }
230
+ });
231
+ it('should return the item family criteria from the object -itemNumber', async () => {
232
+ const object = {
233
+ "flexBoolean": false,
234
+ "flexMultiSelect": [],
235
+ "flexNumber": 0,
236
+ "flexPLMObjectClass": "LCSProduct",
237
+ "flexPLMTypePath": "Product\\Pants",
238
+ "flexSingleList": {
239
+ "display": "Five",
240
+ "value": "five"
241
+ },
242
+ "productName": "Feb 3 - 1 Option A",
243
+ "vibeIQIdentifier": 966
244
+ };
245
+ const criteriaObject = {
246
+ flexPLMObjectClass: 'LCSProduct',
247
+ itemNumber: 966,
248
+ flexPLMTypePath: 'Product\\Pants',
249
+ };
250
+ const resultsObject = {
251
+ roles: 'family',
252
+ itemNumber: 966
253
+ };
254
+ let getEntityValuesSpyOn = undefined;
255
+ try {
256
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
257
+ const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
258
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSProduct', criteriaObject, []);
259
+ expect(result).toEqual(resultsObject);
260
+ }
261
+ finally {
262
+ if (getEntityValuesSpyOn) {
263
+ getEntityValuesSpyOn.mockRestore();
264
+ }
265
+ }
266
+ });
267
+ it('should return the item option criteria from the object -itemNumber', async () => {
268
+ const object = {
269
+ "flexBoolean": false,
270
+ "flexMultiSelect": [],
271
+ "flexNumber": 0,
272
+ "flexPLMObjectClass": "LCSSKU",
273
+ "flexPLMTypePath": "Product\\Pants",
274
+ "flexSingleList": {
275
+ "display": "Five",
276
+ "value": "five"
277
+ },
278
+ "productName": "Feb 3 - 1 Option A",
279
+ "vibeIQIdentifier": 2876
280
+ };
281
+ const criteriaObject = {
282
+ flexPLMObjectClass: 'LCSSKU',
283
+ itemNumber: 2876,
284
+ flexPLMTypePath: 'Product\\Pants',
285
+ };
286
+ const resultsObject = {
287
+ roles: 'color',
288
+ itemNumber: 2876
289
+ };
290
+ let getEntityValuesSpyOn = undefined;
291
+ try {
292
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
293
+ const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile1, mapFileUtil, dc, object);
294
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSKU', criteriaObject, []);
295
+ expect(result).toEqual(resultsObject);
296
+ }
297
+ finally {
298
+ if (getEntityValuesSpyOn) {
299
+ getEntityValuesSpyOn.mockRestore();
300
+ }
301
+ }
302
+ });
303
+ it('should return the item option criteria from the object -uniqueIdentifierA, uniqueIdentifierB', async () => {
304
+ const object = {
305
+ "flexBoolean": false,
306
+ "flexMultiSelect": [],
307
+ "flexNumber": 0,
308
+ "flexPLMObjectClass": "LCSSKU",
309
+ "flexPLMTypePath": "Product\\Pants",
310
+ "flexSingleList": {
311
+ "display": "Five",
312
+ "value": "five"
313
+ },
314
+ "productName": "Feb 3 - 1 Option A",
315
+ uniqueIdentifierA: 28,
316
+ uniqueIdentifierB: 29,
317
+ "vibeIQIdentifier": 2876
318
+ };
319
+ const criteriaObject = {
320
+ flexPLMObjectClass: 'LCSSKU',
321
+ uniqueIdentifierA: 28,
322
+ uniqueIdentifierB: 29,
323
+ flexPLMTypePath: 'Product\\Pants',
324
+ };
325
+ const resultsObject = {
326
+ roles: 'color',
327
+ uniqueIdentifierA: 28,
328
+ uniqueIdentifierB: 29,
329
+ };
330
+ let getEntityValuesSpyOn = undefined;
331
+ try {
332
+ getEntityValuesSpyOn = jest.spyOn(dc, 'getEntityValues');
333
+ const result = await identifier_conversion_1.IdentifierConversion.getItemCriteriaFromObject(transformMapFile2, mapFileUtil, dc, object);
334
+ expect(getEntityValuesSpyOn).toHaveBeenCalledWith('LCSSKU', criteriaObject, []);
335
+ expect(result).toEqual(resultsObject);
336
+ }
337
+ finally {
338
+ if (getEntityValuesSpyOn) {
339
+ getEntityValuesSpyOn.mockRestore();
340
+ }
341
+ }
342
+ });
343
+ });