oxygen-cli 1.39.3 → 1.40.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.
- package/CHANGELOG.md +14 -0
- package/build/core/OxygenCore.js +2 -2
- package/build/errors/helper.js +2 -4
- package/build/lib/cli-util.js +5 -4
- package/build/lib/cli.js +4 -1
- package/build/lib/parallel-launcher.js +11 -2
- package/build/ox_modules/module-web.js +6 -9
- package/build/ox_reporters/reporter-rp.js +63 -31
- package/build/reporter/ReportAggregator.js +29 -8
- package/build/runners/oxygen/index.js +4 -3
- package/package.json +1 -1
|
@@ -9,6 +9,8 @@ require("source-map-support/register");
|
|
|
9
9
|
|
|
10
10
|
var _ReporterBase = _interopRequireDefault(require("../reporter/ReporterBase"));
|
|
11
11
|
|
|
12
|
+
var _status = _interopRequireDefault(require("../model/status"));
|
|
13
|
+
|
|
12
14
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
15
|
|
|
14
16
|
const RPClient = require('@oxygenhq/rp-client-javascript');
|
|
@@ -33,6 +35,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
33
35
|
this.cbSuiteToRpIdHash = {};
|
|
34
36
|
this.cbCaseToRpIdHash = {};
|
|
35
37
|
this.cbStepToRpIdHash = {};
|
|
38
|
+
this.cbSuiteResultListByRefId = {};
|
|
36
39
|
this.currentTransactionStepId = undefined;
|
|
37
40
|
this.currentSubStepId = undefined;
|
|
38
41
|
|
|
@@ -57,10 +60,8 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
57
60
|
|
|
58
61
|
async generate(results) {}
|
|
59
62
|
|
|
60
|
-
async
|
|
61
|
-
|
|
62
|
-
opts,
|
|
63
|
-
caps
|
|
63
|
+
async onLaunchStart({
|
|
64
|
+
options
|
|
64
65
|
}) {
|
|
65
66
|
const {
|
|
66
67
|
tempId,
|
|
@@ -75,14 +76,15 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
75
76
|
});
|
|
76
77
|
}
|
|
77
78
|
|
|
78
|
-
async
|
|
79
|
-
|
|
80
|
-
result
|
|
79
|
+
async onLaunchEnd({
|
|
80
|
+
results
|
|
81
81
|
}) {
|
|
82
|
+
await this._reportEndOfStartedSuites();
|
|
83
|
+
const hasFailed = results.some(x => x.status === _status.default.FAILED);
|
|
82
84
|
const {
|
|
83
85
|
promise
|
|
84
86
|
} = await this.rpClient.finishLaunch(this.tempLaunchId, {
|
|
85
|
-
status:
|
|
87
|
+
status: hasFailed ? 'FAILED' : 'PASSED'
|
|
86
88
|
});
|
|
87
89
|
|
|
88
90
|
try {
|
|
@@ -92,11 +94,30 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
92
94
|
}
|
|
93
95
|
}
|
|
94
96
|
|
|
97
|
+
async onRunnerStart({
|
|
98
|
+
rid,
|
|
99
|
+
opts,
|
|
100
|
+
caps
|
|
101
|
+
}) {}
|
|
102
|
+
|
|
103
|
+
async onRunnerEnd({
|
|
104
|
+
rid,
|
|
105
|
+
result
|
|
106
|
+
}) {}
|
|
107
|
+
|
|
95
108
|
async onSuiteStart({
|
|
96
109
|
rid,
|
|
97
110
|
suiteId,
|
|
98
111
|
suite: suiteDef
|
|
99
112
|
}) {
|
|
113
|
+
const suiteRefId = suiteDef.refId;
|
|
114
|
+
|
|
115
|
+
if (this.cbSuiteToRpIdHash[suiteRefId]) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
this.cbSuiteToRpIdHash[suiteRefId] = {};
|
|
120
|
+
this.cbSuiteResultListByRefId[suiteRefId] = [];
|
|
100
121
|
const startTestItemReq = {
|
|
101
122
|
name: suiteDef.name || this.options.name,
|
|
102
123
|
type: TEST_ITEM_TYPES.SUITE
|
|
@@ -105,7 +126,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
105
126
|
tempId,
|
|
106
127
|
promise
|
|
107
128
|
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);
|
|
108
|
-
this.cbSuiteToRpIdHash[
|
|
129
|
+
this.cbSuiteToRpIdHash[suiteRefId] = tempId;
|
|
109
130
|
|
|
110
131
|
try {
|
|
111
132
|
await this.promiseWithTimeout(promise);
|
|
@@ -119,28 +140,14 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
119
140
|
suiteId,
|
|
120
141
|
result
|
|
121
142
|
}) {
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
const rpSuiteId = this.cbSuiteToRpIdHash[suiteId];
|
|
127
|
-
const finishTestItemReq = {
|
|
128
|
-
status: result.status.toLowerCase()
|
|
129
|
-
};
|
|
130
|
-
const {
|
|
131
|
-
promise
|
|
132
|
-
} = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);
|
|
133
|
-
|
|
134
|
-
try {
|
|
135
|
-
await this.promiseWithTimeout(promise);
|
|
136
|
-
} catch (e) {
|
|
137
|
-
console.dir(`RP - Failed to finish suite item: ${e}`);
|
|
138
|
-
}
|
|
143
|
+
const suiteRefId = result.refId;
|
|
144
|
+
this.cbSuiteResultListByRefId[suiteRefId] && this.cbSuiteResultListByRefId[suiteRefId].push(result);
|
|
139
145
|
}
|
|
140
146
|
|
|
141
147
|
async onCaseStart({
|
|
142
148
|
rid,
|
|
143
149
|
suiteId,
|
|
150
|
+
suiteRefId,
|
|
144
151
|
caseId,
|
|
145
152
|
'case': caseDef
|
|
146
153
|
}) {
|
|
@@ -149,7 +156,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
149
156
|
type: TEST_ITEM_TYPES.TEST,
|
|
150
157
|
codeRef: caseDef.path
|
|
151
158
|
};
|
|
152
|
-
const rpSuiteId = this.cbSuiteToRpIdHash[
|
|
159
|
+
const rpSuiteId = this.cbSuiteToRpIdHash[suiteRefId];
|
|
153
160
|
|
|
154
161
|
if (!rpSuiteId) {
|
|
155
162
|
return;
|
|
@@ -171,6 +178,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
171
178
|
async onCaseEnd({
|
|
172
179
|
rid,
|
|
173
180
|
suiteId,
|
|
181
|
+
suiteRefId,
|
|
174
182
|
caseId,
|
|
175
183
|
result
|
|
176
184
|
}) {
|
|
@@ -220,6 +228,8 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
220
228
|
} catch (e) {
|
|
221
229
|
console.dir(`RP - Failed to finish test item: ${e}`);
|
|
222
230
|
}
|
|
231
|
+
|
|
232
|
+
this.currentTransactionStepId = undefined;
|
|
223
233
|
}
|
|
224
234
|
|
|
225
235
|
async onStepStart({
|
|
@@ -241,10 +251,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
241
251
|
|
|
242
252
|
if (step.name === 'transaction') {
|
|
243
253
|
this.currentTransactionStepId = step.id;
|
|
244
|
-
|
|
254
|
+
this.currentSubStepId = undefined;
|
|
255
|
+
rpParentId = rpCaseId;
|
|
245
256
|
} else {
|
|
246
257
|
this.currentSubStepId = step.id;
|
|
247
|
-
rpParentId = this.currentTransactionStepId ? this.cbStepToRpIdHash[this.currentTransactionStepId] :
|
|
258
|
+
rpParentId = this.currentTransactionStepId ? this.cbStepToRpIdHash[this.currentTransactionStepId] : rpCaseId;
|
|
248
259
|
}
|
|
249
260
|
|
|
250
261
|
if (!rpParentId || !rpCaseId) {
|
|
@@ -281,7 +292,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
281
292
|
return;
|
|
282
293
|
}
|
|
283
294
|
|
|
284
|
-
if (result.
|
|
295
|
+
if (result.name && result.name.startsWith('log.')) {
|
|
285
296
|
return;
|
|
286
297
|
}
|
|
287
298
|
|
|
@@ -441,6 +452,27 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
441
452
|
}
|
|
442
453
|
}
|
|
443
454
|
|
|
455
|
+
async _reportEndOfStartedSuites() {
|
|
456
|
+
for (const suiteRefId of Object.keys(this.cbSuiteToRpIdHash)) {
|
|
457
|
+
const rpSuiteId = this.cbSuiteToRpIdHash[suiteRefId];
|
|
458
|
+
const results = this.cbSuiteResultListByRefId[suiteRefId];
|
|
459
|
+
delete this.cbSuiteToRpIdHash[suiteRefId];
|
|
460
|
+
const hasFailedSuite = results.some(x => x.status === _status.default.FAILED);
|
|
461
|
+
const finishTestItemReq = {
|
|
462
|
+
status: hasFailedSuite ? 'failed' : 'passed'
|
|
463
|
+
};
|
|
464
|
+
const {
|
|
465
|
+
promise
|
|
466
|
+
} = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);
|
|
467
|
+
|
|
468
|
+
try {
|
|
469
|
+
await this.promiseWithTimeout(promise);
|
|
470
|
+
} catch (e) {
|
|
471
|
+
console.dir(`RP - Failed to finish suite item: ${e}`);
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
|
|
444
476
|
_getRpLevel(oxLevel) {
|
|
445
477
|
if (oxLevel) {
|
|
446
478
|
return oxLevel.toLowerCase();
|
|
@@ -499,4 +531,4 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
499
531
|
}
|
|
500
532
|
|
|
501
533
|
exports.default = ReportPortalReporter;
|
|
502
|
-
//# 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","currentTransactionStepId","undefined","currentSubStepId","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","logMsg","_stringify","logReq","level","sendLog","onStepStart","step","module","reportLogStep","rpCaseId","rpParentId","id","stepName","_getStepName","location","testCaseId","hasStats","onStepEnd","rpStepId","file","onLog","stepId","msg","time","src","rpLevel","_getRpLevel","args","length","sendRpLog","oxLevel","signature","substring","String","JSON","stringify","timeout","Promise","resolve","reject","setTimeout"],"mappings":"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","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 || true;\r\n        this.reportLogs = reporterOpts.reportLogs || false;\r\n        this.cbSuiteToRpIdHash = {};\r\n        this.cbCaseToRpIdHash = {};\r\n        this.cbStepToRpIdHash = {};\r\n        this.currentTransactionStepId = undefined;\r\n        this.currentSubStepId = undefined;\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\r\n            const logMsg = this._stringify(result.failure.message);\r\n            if (logMsg) {\r\n                const logReq = {\r\n                    message: logMsg,\r\n                    level: 'error'\r\n                };\r\n                const { promise } = this.rpClient.sendLog(rpTestId, logReq, rpFile);\r\n\r\n                try {\r\n                    await this.promiseWithTimeout(promise);\r\n                } catch (e) {\r\n                    console.dir(`RP - Failed to send log for finished test item: ${e}`);\r\n                }\r\n            }\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        if (step.module && step.module === 'log') {\r\n            await this.reportLogStep(caseId, step);\r\n            return;\r\n        }\r\n        const rpCaseId = this.cbCaseToRpIdHash[caseId];\r\n        let rpParentId; /* = this.currentTransactionStepId ?\r\n            this.cbStepToRpIdHash[this.currentTransactionStepId]\r\n            : this.cbStepToRpIdHash[caseId];*/\r\n        // const rpCaseId = this.cbCaseToRpIdHash[caseId];\r\n        if (step.name === 'transaction') {\r\n            this.currentTransactionStepId = step.id;\r\n            rpParentId = this.cbCaseToRpIdHash[caseId];\r\n        }\r\n        else {\r\n            this.currentSubStepId = step.id;\r\n            rpParentId = this.currentTransactionStepId ?\r\n                this.cbStepToRpIdHash[this.currentTransactionStepId]: this.cbStepToRpIdHash[caseId];\r\n        }\r\n        if (!rpParentId || !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, rpParentId);\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        if (result.module && result.module === 'log') {\r\n            return;\r\n        }\r\n        const rpStepId = this.cbStepToRpIdHash[result.id];\r\n        if (!rpStepId) {\r\n            return;\r\n        }\r\n        if (result.name !== 'transaction') {\r\n            this.currentSubStepId = undefined;\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\r\n            const logMsg = this._stringify(result.failure.message);\r\n            if (logMsg) {\r\n                const logReq = {\r\n                    message: logMsg,\r\n                    level: 'error',\r\n                    file: rpFile,\r\n                };\r\n                const { promise } = this.rpClient.sendLog(rpStepId, logReq, rpFile);\r\n\r\n                try {\r\n                    await this.promiseWithTimeout(promise);\r\n                } catch (e) {\r\n                    console.dir(`RP - Failed to send log for finished test item: ${e}`);\r\n                }\r\n            }\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\r\n        const logMsg = this._stringify(msg);\r\n        if (logMsg) {\r\n            const logReq = {\r\n                message: logMsg,\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    }\r\n    async reportLogStep(caseId, step) {\r\n        if (!step.args || !step.args.length) {\r\n            return;\r\n        }\r\n        const level = step.name;\r\n        const msg = step.args[0];\r\n        const time = step.time;\r\n        let stepId = undefined;\r\n        if (this.currentSubStepId) {\r\n            stepId = this.currentSubStepId;\r\n        }\r\n        else if (this.currentTransactionStepId) {\r\n            stepId = this.currentTransactionStepId;\r\n        }\r\n        await this.sendRpLog({ suiteId: undefined, caseId, stepId, level, msg, time });\r\n    }\r\n    async sendRpLog({ suiteId, caseId, stepId, level, msg, time }) {\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\r\n        const logMsg = this._stringify(msg);\r\n        if (logMsg) {\r\n            const logReq = {\r\n                message: logMsg,\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    }\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\r\n    // returns null if msg cannot be stringified, or strigifies it if it's not a string already\r\n    _stringify(msg) {\r\n        // we test for undefined and null explicitly on purpose because other falsy values (e.g. 0) are ok\r\n        if (typeof msg === 'undefined' || msg === null) {\r\n            return null;\r\n        }\r\n\r\n        if (typeof msg === 'string' || msg instanceof String) {\r\n            return msg;\r\n        }\r\n\r\n        try {\r\n            return JSON.stringify(msg);\r\n        } catch (e) {\r\n            console.error('RP - error sending log: msg object cannot be serialized');\r\n        }\r\n    }\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(new Error(`Promise await timeout of ${timeout} ms`));\r\n            }\r\n            promise.then(resolve, reject);\r\n            setTimeout(reject, timeout);\r\n        });\r\n    }\r\n}\r\n\r\n"]}
|
|
534
|
+
//# 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","cbSuiteResultListByRefId","currentTransactionStepId","undefined","currentSubStepId","apiKey","endpoint","project","Error","rpClient","launch","name","init","checkConnect","e","message","generate","results","onLaunchStart","tempId","promise","startLaunch","mode","debug","tempLaunchId","then","response","error","console","dir","onLaunchEnd","_reportEndOfStartedSuites","hasFailed","some","x","status","Status","FAILED","finishLaunch","promiseWithTimeout","onRunnerStart","rid","opts","caps","onRunnerEnd","result","onSuiteStart","suiteId","suite","suiteDef","suiteRefId","refId","startTestItemReq","type","startTestItem","onSuiteEnd","push","onCaseStart","caseId","caseDef","codeRef","path","rpSuiteId","onCaseEnd","rpTestId","toLowerCase","failure","rpFile","screenshot","content","logMsg","_stringify","logReq","level","sendLog","finishTestItemReq","finishTestItem","onStepStart","step","module","reportLogStep","rpCaseId","rpParentId","id","stepName","_getStepName","location","testCaseId","hasStats","onStepEnd","startsWith","rpStepId","file","onLog","stepId","msg","time","src","rpLevel","_getRpLevel","args","length","sendRpLog","Object","keys","hasFailedSuite","oxLevel","signature","substring","String","JSON","stringify","timeout","Promise","resolve","reject","setTimeout"],"mappings":"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","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\nimport Status from '../model/status';\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 || true;\r\n        this.reportLogs = reporterOpts.reportLogs || false;\r\n        this.cbSuiteToRpIdHash = {};\r\n        this.cbCaseToRpIdHash = {};\r\n        this.cbStepToRpIdHash = {};\r\n        this.cbSuiteResultListByRefId = {};\r\n        this.currentTransactionStepId = undefined;\r\n        this.currentSubStepId = undefined;\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 onLaunchStart({ options }) {\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 onLaunchEnd({ results }) {\r\n        // report the end of all started suites\r\n        await this._reportEndOfStartedSuites();\r\n        // Calculate launch status\r\n        const hasFailed = results.some(x => x.status === Status.FAILED);\r\n        const { promise } = await this.rpClient.finishLaunch(this.tempLaunchId, {\r\n            status: hasFailed ? 'FAILED' : 'PASSED'\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 onRunnerStart({ rid, opts, caps }) {\r\n    }\r\n    async onRunnerEnd({ rid, result }) {\r\n    }\r\n    async onSuiteStart({ rid, suiteId, suite: suiteDef }) {\r\n        // in parallel test execution, onSuiteStart will be called multiple times for the same suite \r\n        // make sure we call \"startTestItem\" the same suite only once\r\n        const suiteRefId = suiteDef.refId;\r\n        if (this.cbSuiteToRpIdHash[suiteRefId]) {\r\n            return;\r\n        }\r\n        // assign empty object as a form of multi-thread lock,\r\n        // so the parallel call to onSuiteStart from the next thread\r\n        // will not try to proceed with the code below\r\n        this.cbSuiteToRpIdHash[suiteRefId] = {};\r\n        this.cbSuiteResultListByRefId[suiteRefId] = [];\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[suiteRefId] = 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        const suiteRefId = result.refId;\r\n        this.cbSuiteResultListByRefId[suiteRefId] && this.cbSuiteResultListByRefId[suiteRefId].push(result);\r\n    }\r\n    async onCaseStart({ rid, suiteId, suiteRefId, 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[suiteRefId];\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, suiteRefId, 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\r\n            const logMsg = this._stringify(result.failure.message);\r\n            if (logMsg) {\r\n                const logReq = {\r\n                    message: logMsg,\r\n                    level: 'error'\r\n                };\r\n                const { promise } = this.rpClient.sendLog(rpTestId, logReq, rpFile);\r\n\r\n                try {\r\n                    await this.promiseWithTimeout(promise);\r\n                } catch (e) {\r\n                    console.dir(`RP - Failed to send log for finished test item: ${e}`);\r\n                }\r\n            }\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        this.currentTransactionStepId = undefined;\r\n    }\r\n    async onStepStart({ rid, caseId, step }) {\r\n        if (!this.reportSteps) {\r\n            return;\r\n        }\r\n        if (step.module && step.module === 'log') {\r\n            await this.reportLogStep(caseId, step);\r\n            return;\r\n        }\r\n        const rpCaseId = this.cbCaseToRpIdHash[caseId];\r\n        let rpParentId;\r\n\r\n        if (step.name === 'transaction') {\r\n            this.currentTransactionStepId = step.id;\r\n            this.currentSubStepId = undefined;\r\n            rpParentId = rpCaseId;\r\n        }\r\n        else {\r\n            this.currentSubStepId = step.id;\r\n            rpParentId = this.currentTransactionStepId ? this.cbStepToRpIdHash[this.currentTransactionStepId] : rpCaseId;\r\n        }\r\n\r\n        if (!rpParentId || !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, rpParentId);\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        if (result.name && result.name.startsWith('log.')) {\r\n            return;\r\n        }\r\n        const rpStepId = this.cbStepToRpIdHash[result.id];\r\n        if (!rpStepId) {\r\n            return;\r\n        }\r\n        if (result.name !== 'transaction') {\r\n            this.currentSubStepId = undefined;\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\r\n            const logMsg = this._stringify(result.failure.message);\r\n            if (logMsg) {\r\n                const logReq = {\r\n                    message: logMsg,\r\n                    level: 'error',\r\n                    file: rpFile,\r\n                };\r\n                const { promise } = this.rpClient.sendLog(rpStepId, logReq, rpFile);\r\n\r\n                try {\r\n                    await this.promiseWithTimeout(promise);\r\n                } catch (e) {\r\n                    console.dir(`RP - Failed to send log for finished test item: ${e}`);\r\n                }\r\n            }\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\r\n        const logMsg = this._stringify(msg);\r\n        if (logMsg) {\r\n            const logReq = {\r\n                message: logMsg,\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    }\r\n    async reportLogStep(caseId, step) {\r\n        if (!step.args || !step.args.length) {\r\n            return;\r\n        }\r\n        const level = step.name;\r\n        const msg = step.args[0];\r\n        const time = step.time;\r\n        let stepId = undefined;\r\n        if (this.currentSubStepId) {\r\n            stepId = this.currentSubStepId;\r\n        }\r\n        else if (this.currentTransactionStepId) {\r\n            stepId = this.currentTransactionStepId;\r\n        }\r\n        await this.sendRpLog({ suiteId: undefined, caseId, stepId, level, msg, time });\r\n    }\r\n    async sendRpLog({ suiteId, caseId, stepId, level, msg, time }) {\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\r\n        const logMsg = this._stringify(msg);\r\n        if (logMsg) {\r\n            const logReq = {\r\n                message: logMsg,\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    }\r\n    async _reportEndOfStartedSuites() {\r\n        for (const suiteRefId of Object.keys(this.cbSuiteToRpIdHash)) {\r\n            const rpSuiteId = this.cbSuiteToRpIdHash[suiteRefId];\r\n            const results = this.cbSuiteResultListByRefId[suiteRefId];\r\n            delete this.cbSuiteToRpIdHash[suiteRefId];\r\n            const hasFailedSuite = results.some(x => x.status === Status.FAILED);\r\n            const finishTestItemReq = {\r\n                status: hasFailedSuite ? 'failed' : 'passed',\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    }\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\r\n    // returns null if msg cannot be stringified, or strigifies it if it's not a string already\r\n    _stringify(msg) {\r\n        // we test for undefined and null explicitly on purpose because other falsy values (e.g. 0) are ok\r\n        if (typeof msg === 'undefined' || msg === null) {\r\n            return null;\r\n        }\r\n\r\n        if (typeof msg === 'string' || msg instanceof String) {\r\n            return msg;\r\n        }\r\n\r\n        try {\r\n            return JSON.stringify(msg);\r\n        } catch (e) {\r\n            console.error('RP - error sending log: msg object cannot be serialized');\r\n        }\r\n    }\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(new Error(`Promise await timeout of ${timeout} ms`));\r\n            }\r\n            promise.then(resolve, reject);\r\n            setTimeout(reject, timeout);\r\n        });\r\n    }\r\n}\r\n\r\n"]}
|