oxygen-cli 1.37.8 → 1.38.0

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.
@@ -0,0 +1,376 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ require("source-map-support/register");
9
+
10
+ var _ReporterBase = _interopRequireDefault(require("../reporter/ReporterBase"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ const RPClient = require('@oxygenhq/rp-client-javascript');
15
+
16
+ const LAUNCH_MODES = {
17
+ DEFAULT: 'DEFAULT',
18
+ DEBUG: 'DEBUG'
19
+ };
20
+ const TEST_ITEM_TYPES = {
21
+ SUITE: 'SUITE',
22
+ TEST: 'TEST',
23
+ STEP: 'STEP'
24
+ };
25
+ const MAX_NAME_LENGTH = 128;
26
+
27
+ class ReportPortalReporter extends _ReporterBase.default {
28
+ constructor(options, reporterOpts, aggregator) {
29
+ super(options);
30
+ this.reporterOpts = reporterOpts || options.rp;
31
+ this.reportSteps = reporterOpts.reportSteps || false;
32
+ this.reportLogs = reporterOpts.reportLogs || false;
33
+ this.cbSuiteToRpIdHash = {};
34
+ this.cbCaseToRpIdHash = {};
35
+ this.cbStepToRpIdHash = {};
36
+
37
+ if (!this.reporterOpts || !this.reporterOpts.apiKey || !this.reporterOpts.endpoint || !this.reporterOpts.project) {
38
+ throw new Error('ReportPortal options are missing in oxygen.conf file.');
39
+ }
40
+
41
+ this.aggregator = aggregator;
42
+ this.rpClient = new RPClient({
43
+ launch: this.reporterOpts.launch || this.options.name,
44
+ ...this.reporterOpts
45
+ });
46
+ }
47
+
48
+ async init() {
49
+ try {
50
+ await this.rpClient.checkConnect();
51
+ } catch (e) {
52
+ throw new Error(`RP - Error connecting to the server: ${e.message}`);
53
+ }
54
+ }
55
+
56
+ async generate(results) {}
57
+
58
+ async onRunnerStart({
59
+ rid,
60
+ opts,
61
+ caps
62
+ }) {
63
+ const {
64
+ tempId,
65
+ promise
66
+ } = this.rpClient.startLaunch({
67
+ mode: this.reporterOpts.mode || LAUNCH_MODES.DEFAULT,
68
+ debug: false
69
+ });
70
+ this.tempLaunchId = tempId;
71
+ promise.then(response => {}, error => {
72
+ console.dir(`RP - Error at the start of launch: ${error}`);
73
+ });
74
+ }
75
+
76
+ async onRunnerEnd({
77
+ rid,
78
+ result
79
+ }) {
80
+ const {
81
+ promise
82
+ } = await this.rpClient.finishLaunch(this.tempLaunchId, {
83
+ status: result.status.toLowerCase()
84
+ });
85
+
86
+ try {
87
+ await this.promiseWithTimeout(promise);
88
+ } catch (e) {
89
+ console.dir(`RP - Failed to end launch: ${e}`);
90
+ }
91
+ }
92
+
93
+ async onSuiteStart({
94
+ rid,
95
+ suiteId,
96
+ suite: suiteDef
97
+ }) {
98
+ const startTestItemReq = {
99
+ name: suiteDef.name || this.options.name,
100
+ type: TEST_ITEM_TYPES.SUITE
101
+ };
102
+ const {
103
+ tempId,
104
+ promise
105
+ } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);
106
+ this.cbSuiteToRpIdHash[suiteId] = tempId;
107
+
108
+ try {
109
+ await this.promiseWithTimeout(promise);
110
+ } catch (e) {
111
+ console.dir(`RP - Failed to start suite item: ${e}`);
112
+ }
113
+ }
114
+
115
+ async onSuiteEnd({
116
+ rid,
117
+ suiteId,
118
+ result
119
+ }) {
120
+ if (!this.cbSuiteToRpIdHash[suiteId]) {
121
+ return;
122
+ }
123
+
124
+ const rpSuiteId = this.cbSuiteToRpIdHash[suiteId];
125
+ const finishTestItemReq = {
126
+ status: result.status.toLowerCase()
127
+ };
128
+ const {
129
+ promise
130
+ } = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);
131
+
132
+ try {
133
+ await this.promiseWithTimeout(promise);
134
+ } catch (e) {
135
+ console.dir(`RP - Failed to finish suite item: ${e}`);
136
+ }
137
+ }
138
+
139
+ async onCaseStart({
140
+ rid,
141
+ suiteId,
142
+ caseId,
143
+ 'case': caseDef
144
+ }) {
145
+ const startTestItemReq = {
146
+ name: caseDef.name,
147
+ type: TEST_ITEM_TYPES.TEST,
148
+ codeRef: caseDef.path
149
+ };
150
+ const rpSuiteId = this.cbSuiteToRpIdHash[suiteId];
151
+
152
+ if (!rpSuiteId) {
153
+ return;
154
+ }
155
+
156
+ const {
157
+ tempId,
158
+ promise
159
+ } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpSuiteId);
160
+ this.cbCaseToRpIdHash[caseId] = tempId;
161
+
162
+ try {
163
+ await this.promiseWithTimeout(promise);
164
+ } catch (e) {
165
+ console.dir(`RP - Failed to start test item: ${e}`);
166
+ }
167
+ }
168
+
169
+ async onCaseEnd({
170
+ rid,
171
+ suiteId,
172
+ caseId,
173
+ result
174
+ }) {
175
+ const rpTestId = this.cbCaseToRpIdHash[caseId];
176
+
177
+ if (!rpTestId) {
178
+ return;
179
+ }
180
+
181
+ const status = result.status.toLowerCase();
182
+
183
+ if (status === 'failed' && result.failure) {
184
+ const rpFile = result.screenshot ? {
185
+ name: 'screenshot',
186
+ type: 'image/png',
187
+ content: result.screenshot
188
+ } : undefined;
189
+ const logReq = {
190
+ message: result.failure.message,
191
+ level: 'error'
192
+ };
193
+ const {
194
+ promise: sendLogPromise
195
+ } = rpFile ? this.rpClient.sendLogWithFile(rpTestId, logReq, rpFile) : this.rpClient.sendLog(rpTestId, logReq);
196
+ await this.promiseWithTimeout(sendLogPromise);
197
+ }
198
+
199
+ const finishTestItemReq = {
200
+ status: result.status.toLowerCase()
201
+ };
202
+ const {
203
+ promise
204
+ } = this.rpClient.finishTestItem(rpTestId, finishTestItemReq);
205
+
206
+ try {
207
+ await this.promiseWithTimeout(promise);
208
+ } catch (e) {
209
+ console.dir(`RP - Failed to finish test item: ${e}`);
210
+ }
211
+ }
212
+
213
+ async onStepStart({
214
+ rid,
215
+ caseId,
216
+ step
217
+ }) {
218
+ if (!this.reportSteps) {
219
+ return;
220
+ }
221
+
222
+ const rpCaseId = this.cbCaseToRpIdHash[caseId];
223
+
224
+ if (!rpCaseId) {
225
+ return;
226
+ }
227
+
228
+ const stepName = this._getStepName(step);
229
+
230
+ const startTestItemReq = {
231
+ name: stepName,
232
+ type: TEST_ITEM_TYPES.STEP,
233
+ codeRef: step.location,
234
+ testCaseId: rpCaseId,
235
+ hasStats: false
236
+ };
237
+ const {
238
+ tempId,
239
+ promise
240
+ } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpCaseId);
241
+ this.cbStepToRpIdHash[step.id] = tempId;
242
+
243
+ try {
244
+ await this.promiseWithTimeout(promise);
245
+ } catch (e) {
246
+ console.dir(`RP - Failed to start step item: ${e}`);
247
+ }
248
+ }
249
+
250
+ async onStepEnd({
251
+ rid,
252
+ step: result
253
+ }) {
254
+ if (!this.reportSteps) {
255
+ return;
256
+ }
257
+
258
+ const rpStepId = this.cbStepToRpIdHash[result.id];
259
+
260
+ if (!rpStepId) {
261
+ return;
262
+ }
263
+
264
+ const status = result.status.toLowerCase();
265
+
266
+ if (status === 'failed' && result.failure) {
267
+ const rpFile = result.screenshot ? {
268
+ name: 'screenshot',
269
+ type: 'image/png',
270
+ content: result.screenshot
271
+ } : undefined;
272
+ const logReq = {
273
+ message: result.failure.message,
274
+ level: 'error',
275
+ file: rpFile
276
+ };
277
+ const {
278
+ promise: sendLogPromise
279
+ } = this.rpClient.sendLog(rpStepId, logReq, rpFile);
280
+ await this.promiseWithTimeout(sendLogPromise);
281
+ }
282
+
283
+ const finishTestItemReq = {
284
+ status: result.status.toLowerCase()
285
+ };
286
+ const {
287
+ promise
288
+ } = this.rpClient.finishTestItem(rpStepId, finishTestItemReq);
289
+
290
+ try {
291
+ await this.promiseWithTimeout(promise);
292
+ } catch (e) {
293
+ console.dir(`RP - Failed to finish step item: ${e}`);
294
+ }
295
+ }
296
+
297
+ async onLog({
298
+ suiteId,
299
+ caseId,
300
+ stepId,
301
+ level,
302
+ msg,
303
+ time,
304
+ src
305
+ }) {
306
+ if (!this.reportLogs) {
307
+ return;
308
+ }
309
+
310
+ if (!this.tempLaunchId) {
311
+ return;
312
+ }
313
+
314
+ const rpParentId = stepId ? this.cbStepToRpIdHash[stepId] : caseId ? this.cbCaseToRpIdHash[caseId] : suiteId ? this.cbSuiteToRpIdHash[suiteId] : undefined;
315
+
316
+ const rpLevel = this._getRpLevel(level);
317
+
318
+ const logReq = {
319
+ message: msg,
320
+ level: rpLevel,
321
+ time: time
322
+ };
323
+ const {
324
+ promise
325
+ } = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);
326
+
327
+ try {
328
+ await this.promiseWithTimeout(promise);
329
+ } catch (e) {
330
+ console.dir(`RP - Failed to create log item: ${e}`);
331
+ }
332
+ }
333
+
334
+ _getRpLevel(oxLevel) {
335
+ if (oxLevel) {
336
+ return oxLevel.toLowerCase();
337
+ }
338
+
339
+ return 'info';
340
+ }
341
+
342
+ _getStepName(step) {
343
+ let name;
344
+
345
+ if (step.name === 'transaction' && step.args.length > 0) {
346
+ name = step.args[0];
347
+ } else if (step.signature) {
348
+ name = step.signature;
349
+ } else if (step.module) {
350
+ name = `${step.module}.${step.name}`;
351
+ } else {
352
+ name = step.name;
353
+ }
354
+
355
+ if (name.length > MAX_NAME_LENGTH) {
356
+ name = name.substring(0, MAX_NAME_LENGTH - 3) + '...';
357
+ }
358
+
359
+ return name;
360
+ }
361
+
362
+ promiseWithTimeout(promise, timeout = 10 * 1000) {
363
+ return new Promise((resolve, reject) => {
364
+ if (!promise || !promise.then) {
365
+ reject();
366
+ }
367
+
368
+ promise.then(resolve, reject);
369
+ setTimeout(reject, timeout);
370
+ });
371
+ }
372
+
373
+ }
374
+
375
+ exports.default = ReportPortalReporter;
376
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_reporters/reporter-rp.js"],"names":["RPClient","require","LAUNCH_MODES","DEFAULT","DEBUG","TEST_ITEM_TYPES","SUITE","TEST","STEP","MAX_NAME_LENGTH","ReportPortalReporter","ReporterBase","constructor","options","reporterOpts","aggregator","rp","reportSteps","reportLogs","cbSuiteToRpIdHash","cbCaseToRpIdHash","cbStepToRpIdHash","apiKey","endpoint","project","Error","rpClient","launch","name","init","checkConnect","e","message","generate","results","onRunnerStart","rid","opts","caps","tempId","promise","startLaunch","mode","debug","tempLaunchId","then","response","error","console","dir","onRunnerEnd","result","finishLaunch","status","toLowerCase","promiseWithTimeout","onSuiteStart","suiteId","suite","suiteDef","startTestItemReq","type","startTestItem","onSuiteEnd","rpSuiteId","finishTestItemReq","finishTestItem","onCaseStart","caseId","caseDef","codeRef","path","onCaseEnd","rpTestId","failure","rpFile","screenshot","content","undefined","logReq","level","sendLogPromise","sendLogWithFile","sendLog","onStepStart","step","rpCaseId","stepName","_getStepName","location","testCaseId","hasStats","id","onStepEnd","rpStepId","file","onLog","stepId","msg","time","src","rpParentId","rpLevel","_getRpLevel","oxLevel","args","length","signature","module","substring","timeout","Promise","resolve","reject","setTimeout"],"mappings":";;;;;;;;;AAYA;;;;AACA,MAAMA,QAAQ,GAAGC,OAAO,CAAC,gCAAD,CAAxB;;AACA,MAAMC,YAAY,GAAG;AACjBC,EAAAA,OAAO,EAAE,SADQ;AAEjBC,EAAAA,KAAK,EAAE;AAFU,CAArB;AAIA,MAAMC,eAAe,GAAG;AACpBC,EAAAA,KAAK,EAAE,OADa;AAEpBC,EAAAA,IAAI,EAAE,MAFc;AAGpBC,EAAAA,IAAI,EAAE;AAHc,CAAxB;AAKA,MAAMC,eAAe,GAAG,GAAxB;;AAEe,MAAMC,oBAAN,SAAmCC,qBAAnC,CAAgD;AAC3DC,EAAAA,WAAW,CAACC,OAAD,EAAUC,YAAV,EAAwBC,UAAxB,EAAoC;AAC3C,UAAMF,OAAN;AACA,SAAKC,YAAL,GAAoBA,YAAY,IAAID,OAAO,CAACG,EAA5C;AACA,SAAKC,WAAL,GAAmBH,YAAY,CAACG,WAAb,IAA4B,KAA/C;AACA,SAAKC,UAAL,GAAkBJ,YAAY,CAACI,UAAb,IAA2B,KAA7C;AACA,SAAKC,iBAAL,GAAyB,EAAzB;AACA,SAAKC,gBAAL,GAAwB,EAAxB;AACA,SAAKC,gBAAL,GAAwB,EAAxB;;AACA,QACI,CAAC,KAAKP,YAAN,IACG,CAAC,KAAKA,YAAL,CAAkBQ,MADtB,IAEG,CAAC,KAAKR,YAAL,CAAkBS,QAFtB,IAGG,CAAC,KAAKT,YAAL,CAAkBU,OAJ1B,EAKE;AACE,YAAM,IAAIC,KAAJ,CAAU,uDAAV,CAAN;AACH;;AACD,SAAKV,UAAL,GAAkBA,UAAlB;AACA,SAAKW,QAAL,GAAgB,IAAI1B,QAAJ,CAAa;AACzB2B,MAAAA,MAAM,EAAE,KAAKb,YAAL,CAAkBa,MAAlB,IAA4B,KAAKd,OAAL,CAAae,IADxB;AAEzB,SAAG,KAAKd;AAFiB,KAAb,CAAhB;AAIH;;AAES,QAAJe,IAAI,GAAG;AACT,QAAI;AACA,YAAM,KAAKH,QAAL,CAAcI,YAAd,EAAN;AACH,KAFD,CAGA,OAAOC,CAAP,EAAU;AACN,YAAM,IAAIN,KAAJ,CAAW,wCAAuCM,CAAC,CAACC,OAAQ,EAA5D,CAAN;AACH;AACJ;;AACa,QAARC,QAAQ,CAACC,OAAD,EAAU,CACvB;;AAEkB,QAAbC,aAAa,CAAC;AAAEC,IAAAA,GAAF;AAAOC,IAAAA,IAAP;AAAaC,IAAAA;AAAb,GAAD,EAAsB;AACrC,UAAM;AAAEC,MAAAA,MAAF;AAAUC,MAAAA;AAAV,QAAsB,KAAKd,QAAL,CAAce,WAAd,CAA0B;AAClDC,MAAAA,IAAI,EAAE,KAAK5B,YAAL,CAAkB4B,IAAlB,IAA0BxC,YAAY,CAACC,OADK;AAElDwC,MAAAA,KAAK,EAAE;AAF2C,KAA1B,CAA5B;AAIA,SAAKC,YAAL,GAAoBL,MAApB;AACAC,IAAAA,OAAO,CAACK,IAAR,CAAcC,QAAD,IAAc,CAC1B,CADD,EACIC,KAAD,IAAW;AACVC,MAAAA,OAAO,CAACC,GAAR,CAAa,sCAAqCF,KAAM,EAAxD;AACH,KAHD;AAIH;;AACgB,QAAXG,WAAW,CAAC;AAAEd,IAAAA,GAAF;AAAOe,IAAAA;AAAP,GAAD,EAAkB;AAE/B,UAAM;AAAEX,MAAAA;AAAF,QAAc,MAAM,KAAKd,QAAL,CAAc0B,YAAd,CAA2B,KAAKR,YAAhC,EAA8C;AACpES,MAAAA,MAAM,EAAEF,MAAM,CAACE,MAAP,CAAcC,WAAd;AAD4D,KAA9C,CAA1B;;AAGA,QAAI;AACA,YAAM,KAAKC,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,8BAA6BlB,CAAE,EAA5C;AACH;AACJ;;AACiB,QAAZyB,YAAY,CAAC;AAAEpB,IAAAA,GAAF;AAAOqB,IAAAA,OAAP;AAAgBC,IAAAA,KAAK,EAAEC;AAAvB,GAAD,EAAoC;AAClD,UAAMC,gBAAgB,GAAG;AACrBhC,MAAAA,IAAI,EAAE+B,QAAQ,CAAC/B,IAAT,IAAiB,KAAKf,OAAL,CAAae,IADf;AAErBiC,MAAAA,IAAI,EAAExD,eAAe,CAACC;AAFD,KAAzB;AAIA,UAAM;AAAEiC,MAAAA,MAAF;AAAUC,MAAAA;AAAV,QAAsB,KAAKd,QAAL,CAAcoC,aAAd,CAA4BF,gBAA5B,EAA8C,KAAKhB,YAAnD,CAA5B;AACA,SAAKzB,iBAAL,CAAuBsC,OAAvB,IAAkClB,MAAlC;;AACA,QAAI;AACA,YAAM,KAAKgB,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,oCAAmClB,CAAE,EAAlD;AACH;AACJ;;AACe,QAAVgC,UAAU,CAAC;AAAE3B,IAAAA,GAAF;AAAOqB,IAAAA,OAAP;AAAgBN,IAAAA;AAAhB,GAAD,EAA2B;AACvC,QAAI,CAAC,KAAKhC,iBAAL,CAAuBsC,OAAvB,CAAL,EAAsC;AAClC;AACH;;AACD,UAAMO,SAAS,GAAG,KAAK7C,iBAAL,CAAuBsC,OAAvB,CAAlB;AACA,UAAMQ,iBAAiB,GAAG;AACtBZ,MAAAA,MAAM,EAAEF,MAAM,CAACE,MAAP,CAAcC,WAAd;AADc,KAA1B;AAGA,UAAM;AAAEd,MAAAA;AAAF,QAAc,KAAKd,QAAL,CAAcwC,cAAd,CAA6BF,SAA7B,EAAwCC,iBAAxC,CAApB;;AACA,QAAI;AACA,YAAM,KAAKV,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,qCAAoClB,CAAE,EAAnD;AACH;AACJ;;AACgB,QAAXoC,WAAW,CAAC;AAAE/B,IAAAA,GAAF;AAAOqB,IAAAA,OAAP;AAAgBW,IAAAA,MAAhB;AAAwB,YAAQC;AAAhC,GAAD,EAA4C;AACzD,UAAMT,gBAAgB,GAAG;AACrBhC,MAAAA,IAAI,EAAEyC,OAAO,CAACzC,IADO;AAErBiC,MAAAA,IAAI,EAAExD,eAAe,CAACE,IAFD;AAGrB+D,MAAAA,OAAO,EAAED,OAAO,CAACE;AAHI,KAAzB;AAKA,UAAMP,SAAS,GAAG,KAAK7C,iBAAL,CAAuBsC,OAAvB,CAAlB;;AACA,QAAI,CAACO,SAAL,EAAgB;AACZ;AACH;;AACD,UAAM;AAAEzB,MAAAA,MAAF;AAAUC,MAAAA;AAAV,QAAsB,KAAKd,QAAL,CAAcoC,aAAd,CAA4BF,gBAA5B,EAA8C,KAAKhB,YAAnD,EAAiEoB,SAAjE,CAA5B;AACA,SAAK5C,gBAAL,CAAsBgD,MAAtB,IAAgC7B,MAAhC;;AACA,QAAI;AACA,YAAM,KAAKgB,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,mCAAkClB,CAAE,EAAjD;AACH;AACJ;;AACc,QAATyC,SAAS,CAAC;AAAEpC,IAAAA,GAAF;AAAOqB,IAAAA,OAAP;AAAgBW,IAAAA,MAAhB;AAAwBjB,IAAAA;AAAxB,GAAD,EAAmC;AAC9C,UAAMsB,QAAQ,GAAG,KAAKrD,gBAAL,CAAsBgD,MAAtB,CAAjB;;AACA,QAAI,CAACK,QAAL,EAAe;AACX;AACH;;AACD,UAAMpB,MAAM,GAAGF,MAAM,CAACE,MAAP,CAAcC,WAAd,EAAf;;AACA,QAAID,MAAM,KAAK,QAAX,IAAuBF,MAAM,CAACuB,OAAlC,EAA2C;AACvC,YAAMC,MAAM,GAAGxB,MAAM,CAACyB,UAAP,GACf;AACIhD,QAAAA,IAAI,EAAE,YADV;AAEIiC,QAAAA,IAAI,EAAE,WAFV;AAGIgB,QAAAA,OAAO,EAAE1B,MAAM,CAACyB;AAHpB,OADe,GAKXE,SALJ;AAMA,YAAMC,MAAM,GAAG;AACX/C,QAAAA,OAAO,EAAEmB,MAAM,CAACuB,OAAP,CAAe1C,OADb;AAEXgD,QAAAA,KAAK,EAAE;AAFI,OAAf;AAIA,YAAM;AAAExC,QAAAA,OAAO,EAAEyC;AAAX,UAA8BN,MAAM,GACtC,KAAKjD,QAAL,CAAcwD,eAAd,CAA8BT,QAA9B,EAAwCM,MAAxC,EAAgDJ,MAAhD,CADsC,GAEpC,KAAKjD,QAAL,CAAcyD,OAAd,CAAsBV,QAAtB,EAAgCM,MAAhC,CAFN;AAIA,YAAM,KAAKxB,kBAAL,CAAwB0B,cAAxB,CAAN;AACH;;AACD,UAAMhB,iBAAiB,GAAG;AACtBZ,MAAAA,MAAM,EAAEF,MAAM,CAACE,MAAP,CAAcC,WAAd;AADc,KAA1B;AAGA,UAAM;AAAEd,MAAAA;AAAF,QAAc,KAAKd,QAAL,CAAcwC,cAAd,CAA6BO,QAA7B,EAAuCR,iBAAvC,CAApB;;AACA,QAAI;AACA,YAAM,KAAKV,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,oCAAmClB,CAAE,EAAlD;AACH;AACJ;;AACgB,QAAXqD,WAAW,CAAC;AAAEhD,IAAAA,GAAF;AAAOgC,IAAAA,MAAP;AAAeiB,IAAAA;AAAf,GAAD,EAAwB;AACrC,QAAI,CAAC,KAAKpE,WAAV,EAAuB;AACnB;AACH;;AACD,UAAMqE,QAAQ,GAAG,KAAKlE,gBAAL,CAAsBgD,MAAtB,CAAjB;;AACA,QAAI,CAACkB,QAAL,EAAe;AACX;AACH;;AACD,UAAMC,QAAQ,GAAG,KAAKC,YAAL,CAAkBH,IAAlB,CAAjB;;AACA,UAAMzB,gBAAgB,GAAG;AACrBhC,MAAAA,IAAI,EAAE2D,QADe;AAErB1B,MAAAA,IAAI,EAAExD,eAAe,CAACG,IAFD;AAOrB8D,MAAAA,OAAO,EAAEe,IAAI,CAACI,QAPO;AAQrBC,MAAAA,UAAU,EAAEJ,QARS;AASrBK,MAAAA,QAAQ,EAAE;AATW,KAAzB;AAWA,UAAM;AAAEpD,MAAAA,MAAF;AAAUC,MAAAA;AAAV,QAAsB,KAAKd,QAAL,CAAcoC,aAAd,CAA4BF,gBAA5B,EAA8C,KAAKhB,YAAnD,EAAiE0C,QAAjE,CAA5B;AACA,SAAKjE,gBAAL,CAAsBgE,IAAI,CAACO,EAA3B,IAAiCrD,MAAjC;;AACA,QAAI;AACA,YAAM,KAAKgB,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,mCAAkClB,CAAE,EAAjD;AACH;AACJ;;AACc,QAAT8D,SAAS,CAAC;AAAEzD,IAAAA,GAAF;AAAOiD,IAAAA,IAAI,EAAElC;AAAb,GAAD,EAAwB;AACnC,QAAI,CAAC,KAAKlC,WAAV,EAAuB;AACnB;AACH;;AACD,UAAM6E,QAAQ,GAAG,KAAKzE,gBAAL,CAAsB8B,MAAM,CAACyC,EAA7B,CAAjB;;AACA,QAAI,CAACE,QAAL,EAAe;AACX;AACH;;AACD,UAAMzC,MAAM,GAAGF,MAAM,CAACE,MAAP,CAAcC,WAAd,EAAf;;AACA,QAAID,MAAM,KAAK,QAAX,IAAuBF,MAAM,CAACuB,OAAlC,EAA2C;AACvC,YAAMC,MAAM,GAAGxB,MAAM,CAACyB,UAAP,GACf;AACIhD,QAAAA,IAAI,EAAE,YADV;AAEIiC,QAAAA,IAAI,EAAE,WAFV;AAGIgB,QAAAA,OAAO,EAAE1B,MAAM,CAACyB;AAHpB,OADe,GAKXE,SALJ;AAMA,YAAMC,MAAM,GAAG;AACX/C,QAAAA,OAAO,EAAEmB,MAAM,CAACuB,OAAP,CAAe1C,OADb;AAEXgD,QAAAA,KAAK,EAAE,OAFI;AAGXe,QAAAA,IAAI,EAAEpB;AAHK,OAAf;AAKA,YAAM;AAAEnC,QAAAA,OAAO,EAAEyC;AAAX,UAA8B,KAAKvD,QAAL,CAAcyD,OAAd,CAAsBW,QAAtB,EAAgCf,MAAhC,EAAwCJ,MAAxC,CAApC;AACA,YAAM,KAAKpB,kBAAL,CAAwB0B,cAAxB,CAAN;AACH;;AACD,UAAMhB,iBAAiB,GAAG;AACtBZ,MAAAA,MAAM,EAAEF,MAAM,CAACE,MAAP,CAAcC,WAAd;AADc,KAA1B;AAGA,UAAM;AAAEd,MAAAA;AAAF,QAAc,KAAKd,QAAL,CAAcwC,cAAd,CAA6B4B,QAA7B,EAAuC7B,iBAAvC,CAApB;;AACA,QAAI;AACA,YAAM,KAAKV,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,oCAAmClB,CAAE,EAAlD;AACH;AACJ;;AACU,QAALiE,KAAK,CAAC;AAAEvC,IAAAA,OAAF;AAAWW,IAAAA,MAAX;AAAmB6B,IAAAA,MAAnB;AAA2BjB,IAAAA,KAA3B;AAAkCkB,IAAAA,GAAlC;AAAuCC,IAAAA,IAAvC;AAA6CC,IAAAA;AAA7C,GAAD,EAAqD;AAC5D,QAAI,CAAC,KAAKlF,UAAV,EAAsB;AAClB;AACH;;AAED,QAAI,CAAC,KAAK0B,YAAV,EAAwB;AACpB;AACH;;AACD,UAAMyD,UAAU,GAAGJ,MAAM,GACrB,KAAK5E,gBAAL,CAAsB4E,MAAtB,CADqB,GAEnB7B,MAAM,GAAG,KAAKhD,gBAAL,CAAsBgD,MAAtB,CAAH,GACNX,OAAO,GAAG,KAAKtC,iBAAL,CAAuBsC,OAAvB,CAAH,GACPqB,SAJN;;AAKA,UAAMwB,OAAO,GAAG,KAAKC,WAAL,CAAiBvB,KAAjB,CAAhB;;AACA,UAAMD,MAAM,GAAG;AACX/C,MAAAA,OAAO,EAAEkE,GADE;AAEXlB,MAAAA,KAAK,EAAEsB,OAFI;AAGXH,MAAAA,IAAI,EAAEA;AAHK,KAAf;AAKA,UAAM;AAAE3D,MAAAA;AAAF,QAAc,KAAKd,QAAL,CAAcyD,OAAd,CAAsBkB,UAAU,IAAI,KAAKzD,YAAzC,EAAuDmC,MAAvD,CAApB;;AACA,QAAI;AACA,YAAM,KAAKxB,kBAAL,CAAwBf,OAAxB,CAAN;AACH,KAFD,CAGA,OAAOT,CAAP,EAAU;AACNiB,MAAAA,OAAO,CAACC,GAAR,CAAa,mCAAkClB,CAAE,EAAjD;AACH;AACJ;;AACDwE,EAAAA,WAAW,CAACC,OAAD,EAAU;AACjB,QAAIA,OAAJ,EAAa;AACT,aAAOA,OAAO,CAAClD,WAAR,EAAP;AACH;;AACD,WAAO,MAAP;AACH;;AAgBDkC,EAAAA,YAAY,CAACH,IAAD,EAAO;AACf,QAAIzD,IAAJ;;AAEA,QAAIyD,IAAI,CAACzD,IAAL,KAAc,aAAd,IAA+ByD,IAAI,CAACoB,IAAL,CAAUC,MAAV,GAAmB,CAAtD,EAAyD;AACrD9E,MAAAA,IAAI,GAAGyD,IAAI,CAACoB,IAAL,CAAU,CAAV,CAAP;AACH,KAFD,MAGK,IAAIpB,IAAI,CAACsB,SAAT,EAAoB;AACrB/E,MAAAA,IAAI,GAAGyD,IAAI,CAACsB,SAAZ;AACH,KAFI,MAGA,IAAItB,IAAI,CAACuB,MAAT,EAAiB;AAClBhF,MAAAA,IAAI,GAAI,GAAEyD,IAAI,CAACuB,MAAO,IAAGvB,IAAI,CAACzD,IAAK,EAAnC;AACH,KAFI,MAGA;AACDA,MAAAA,IAAI,GAAGyD,IAAI,CAACzD,IAAZ;AACH;;AAID,QAAIA,IAAI,CAAC8E,MAAL,GAAcjG,eAAlB,EAAmC;AAC/BmB,MAAAA,IAAI,GAAGA,IAAI,CAACiF,SAAL,CAAe,CAAf,EAAkBpG,eAAe,GAAC,CAAlC,IAAuC,KAA9C;AACH;;AACD,WAAOmB,IAAP;AACH;;AACD2B,EAAAA,kBAAkB,CAACf,OAAD,EAAUsE,OAAO,GAAG,KAAK,IAAzB,EAA+B;AAC7C,WAAO,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AACpC,UAAI,CAACzE,OAAD,IAAY,CAACA,OAAO,CAACK,IAAzB,EAA+B;AAC3BoE,QAAAA,MAAM;AACT;;AACDzE,MAAAA,OAAO,CAACK,IAAR,CAAamE,OAAb,EAAsBC,MAAtB;AACAC,MAAAA,UAAU,CAACD,MAAD,EAASH,OAAT,CAAV;AACH,KANM,CAAP;AAOH;;AA5R0D","sourcesContent":["/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\n/*\r\n * Oxygen Reporter for ReportPortal\r\n */\r\nimport ReporterBase from '../reporter/ReporterBase';\r\nconst RPClient = require('@oxygenhq/rp-client-javascript');\r\nconst LAUNCH_MODES = {\r\n    DEFAULT: 'DEFAULT',\r\n    DEBUG: 'DEBUG',\r\n};\r\nconst TEST_ITEM_TYPES = {\r\n    SUITE: 'SUITE',\r\n    TEST: 'TEST',\r\n    STEP: 'STEP',\r\n};\r\nconst MAX_NAME_LENGTH = 128;\r\n\r\nexport default class ReportPortalReporter extends ReporterBase {\r\n    constructor(options, reporterOpts, aggregator) {\r\n        super(options);\r\n        this.reporterOpts = reporterOpts || options.rp;\r\n        this.reportSteps = reporterOpts.reportSteps || false;\r\n        this.reportLogs = reporterOpts.reportLogs || false;\r\n        this.cbSuiteToRpIdHash = {};\r\n        this.cbCaseToRpIdHash = {};\r\n        this.cbStepToRpIdHash = {};\r\n        if (\r\n            !this.reporterOpts\r\n            || !this.reporterOpts.apiKey\r\n            || !this.reporterOpts.endpoint\r\n            || !this.reporterOpts.project\r\n        ) {\r\n            throw new Error('ReportPortal options are missing in oxygen.conf file.');\r\n        }\r\n        this.aggregator = aggregator;\r\n        this.rpClient = new RPClient({\r\n            launch: this.reporterOpts.launch || this.options.name,\r\n            ...this.reporterOpts\r\n        });\r\n    }\r\n\r\n    async init() {\r\n        try {\r\n            await this.rpClient.checkConnect();\r\n        }\r\n        catch (e) {\r\n            throw new Error(`RP - Error connecting to the server: ${e.message}`);\r\n        }\r\n    }\r\n    async generate(results) {\r\n    }\r\n    // Events\r\n    async onRunnerStart({ rid, opts, caps }) {\r\n        const { tempId, promise } = this.rpClient.startLaunch({\r\n            mode: this.reporterOpts.mode || LAUNCH_MODES.DEFAULT,\r\n            debug: false,\r\n        });\r\n        this.tempLaunchId = tempId;\r\n        promise.then((response) => {\r\n        }, (error) => {\r\n            console.dir(`RP - Error at the start of launch: ${error}`);\r\n        });\r\n    }\r\n    async onRunnerEnd({ rid, result }) {\r\n        // await this.rpClient.getPromiseFinishAllItems(this.tempLaunchId);\r\n        const { promise } = await this.rpClient.finishLaunch(this.tempLaunchId, {\r\n            status: result.status.toLowerCase(),\r\n        });\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to end launch: ${e}`);\r\n        }\r\n    }\r\n    async onSuiteStart({ rid, suiteId, suite: suiteDef }) {\r\n        const startTestItemReq = {\r\n            name: suiteDef.name || this.options.name,\r\n            type: TEST_ITEM_TYPES.SUITE,\r\n        };\r\n        const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);\r\n        this.cbSuiteToRpIdHash[suiteId] = tempId;\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to start suite item: ${e}`);\r\n        }\r\n    }\r\n    async onSuiteEnd({ rid, suiteId, result }) {\r\n        if (!this.cbSuiteToRpIdHash[suiteId]) {\r\n            return;\r\n        }\r\n        const rpSuiteId = this.cbSuiteToRpIdHash[suiteId];\r\n        const finishTestItemReq = {\r\n            status: result.status.toLowerCase(),\r\n        };\r\n        const { promise } = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to finish suite item: ${e}`);\r\n        }\r\n    }\r\n    async onCaseStart({ rid, suiteId, caseId, 'case': caseDef }) {\r\n        const startTestItemReq = {\r\n            name: caseDef.name,\r\n            type: TEST_ITEM_TYPES.TEST,\r\n            codeRef: caseDef.path,\r\n        };\r\n        const rpSuiteId = this.cbSuiteToRpIdHash[suiteId];\r\n        if (!rpSuiteId) {\r\n            return;\r\n        }\r\n        const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpSuiteId);\r\n        this.cbCaseToRpIdHash[caseId] = tempId;\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to start test item: ${e}`);\r\n        }\r\n    }\r\n    async onCaseEnd({ rid, suiteId, caseId, result }) {\r\n        const rpTestId = this.cbCaseToRpIdHash[caseId];\r\n        if (!rpTestId) {\r\n            return;\r\n        }\r\n        const status = result.status.toLowerCase();\r\n        if (status === 'failed' && result.failure) {\r\n            const rpFile = result.screenshot ?\r\n            {\r\n                name: 'screenshot',\r\n                type: 'image/png',\r\n                content: result.screenshot,\r\n            } : undefined;\r\n            const logReq = {\r\n                message: result.failure.message,\r\n                level: 'error'\r\n            };\r\n            const { promise: sendLogPromise } = rpFile ?\r\n                this.rpClient.sendLogWithFile(rpTestId, logReq, rpFile)\r\n                : this.rpClient.sendLog(rpTestId, logReq);\r\n\r\n            await this.promiseWithTimeout(sendLogPromise);\r\n        }\r\n        const finishTestItemReq = {\r\n            status: result.status.toLowerCase(),\r\n        };\r\n        const { promise } = this.rpClient.finishTestItem(rpTestId, finishTestItemReq);\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to finish test item: ${e}`);\r\n        }\r\n    }\r\n    async onStepStart({ rid, caseId, step }) {\r\n        if (!this.reportSteps) {\r\n            return;\r\n        }\r\n        const rpCaseId = this.cbCaseToRpIdHash[caseId];\r\n        if (!rpCaseId) {\r\n            return;\r\n        }\r\n        const stepName = this._getStepName(step);\r\n        const startTestItemReq = {\r\n            name: stepName,\r\n            type: TEST_ITEM_TYPES.STEP,\r\n            // \"codeRef\" + \"parameters\" used by RP lib to generate testCaseId if testCaseId is not defined\r\n            // see https://github.com/reportportal/client-javascript/blob/486ef70c638a9a23267290c62df1faf900f7df6a/lib/report-portal-client.js#L497\r\n            // this is disabled for now. not sure if actually needed...\r\n            //parameters: this._getRpArgs(step.args),\r\n            codeRef: step.location,\r\n            testCaseId: rpCaseId,\r\n            hasStats: false,\r\n        };\r\n        const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpCaseId);\r\n        this.cbStepToRpIdHash[step.id] = tempId;\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to start step item: ${e}`);\r\n        }\r\n    }\r\n    async onStepEnd({ rid, step: result }) {\r\n        if (!this.reportSteps) {\r\n            return;\r\n        }\r\n        const rpStepId = this.cbStepToRpIdHash[result.id];\r\n        if (!rpStepId) {\r\n            return;\r\n        }\r\n        const status = result.status.toLowerCase();\r\n        if (status === 'failed' && result.failure) {\r\n            const rpFile = result.screenshot ?\r\n            {\r\n                name: 'screenshot',\r\n                type: 'image/png',\r\n                content: result.screenshot,\r\n            } : undefined;\r\n            const logReq = {\r\n                message: result.failure.message,\r\n                level: 'error',\r\n                file: rpFile,\r\n            };\r\n            const { promise: sendLogPromise } = this.rpClient.sendLog(rpStepId, logReq, rpFile);\r\n            await this.promiseWithTimeout(sendLogPromise);\r\n        }\r\n        const finishTestItemReq = {\r\n            status: result.status.toLowerCase(),\r\n        };\r\n        const { promise } = this.rpClient.finishTestItem(rpStepId, finishTestItemReq);\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to finish step item: ${e}`);\r\n        }\r\n    }\r\n    async onLog({ suiteId, caseId, stepId, level, msg, time, src }) {\r\n        if (!this.reportLogs) {\r\n            return;\r\n        }\r\n        // Oxygen might start generating logs before onRunnerStart event, ignore them\r\n        if (!this.tempLaunchId) {\r\n            return;\r\n        }\r\n        const rpParentId = stepId ?\r\n            this.cbStepToRpIdHash[stepId]\r\n            : caseId ? this.cbCaseToRpIdHash[caseId]\r\n            : suiteId ? this.cbSuiteToRpIdHash[suiteId]\r\n            : undefined;\r\n        const rpLevel = this._getRpLevel(level);\r\n        const logReq = {\r\n            message: msg,\r\n            level: rpLevel,\r\n            time: time,\r\n        };\r\n        const { promise } = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);\r\n        try {\r\n            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to create log item: ${e}`);\r\n        }\r\n    }\r\n    _getRpLevel(oxLevel) {\r\n        if (oxLevel) {\r\n            return oxLevel.toLowerCase();\r\n        }\r\n        return 'info';\r\n    }\r\n    /*_getRpArgs(cbArgs) {\r\n        if (!cbArgs || !cbArgs.length) {\r\n            return undefined;\r\n        }\r\n        const rpArgs = [];\r\n        for (let i=0; i < cbArgs.length; i++) {\r\n            const arg = cbArgs[i];\r\n            let argStr = typeof arg === 'string' || arg instanceof String ? arg : JSON.stringify(arg);\r\n            rpArgs.push({\r\n                key: `arg${i}`,\r\n                value: argStr\r\n            });\r\n        }\r\n        return rpArgs;\r\n    }*/\r\n    _getStepName(step) {\r\n        let name;\r\n\r\n        if (step.name === 'transaction' && step.args.length > 0) {  // FIXME: steps need to be nested under transactions\r\n            name = step.args[0];\r\n        }\r\n        else if (step.signature) {\r\n            name = step.signature;\r\n        }\r\n        else if (step.module) {                         // FIXME: is this ever reached? \"step.signature\" seems to always exist\r\n            name = `${step.module}.${step.name}`;\r\n        }\r\n        else {\r\n            name = step.name;\r\n        }\r\n\r\n        // maximum allowed name length in RP is 1024 bytes\r\n        // we truncate it even lower so it will display nicely\r\n        if (name.length > MAX_NAME_LENGTH) {\r\n            name = name.substring(0, MAX_NAME_LENGTH-3) + '...';\r\n        }\r\n        return name;\r\n    }\r\n    promiseWithTimeout(promise, timeout = 10 * 1000) {\r\n        return new Promise((resolve, reject) => {\r\n            if (!promise || !promise.then) {\r\n                reject();\r\n            }\r\n            promise.then(resolve, reject);\r\n            setTimeout(reject, timeout);\r\n        });\r\n    }\r\n}\r\n\r\n"]}