oxygen-cli 1.40.0 → 1.40.1
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 +6 -0
- package/build/lib/cli.js +1 -1
- package/build/ox_reporters/reporter-rp.js +56 -55
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
package/build/lib/cli.js
CHANGED
|
@@ -147,4 +147,4 @@ Web test options:
|
|
|
147
147
|
Mobile test options:
|
|
148
148
|
-s, --server=SERVER_URL Appium server URL. Default is http://localhost:4723/wd/hub.`);
|
|
149
149
|
}
|
|
150
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/cli.js"],"names":["process","on","handleSigInt","error","console","argv","require","slice","v","version","log","exit","_","help","printUsage","d","delay","parseInt","targetFile","cliutil","processTargetPath","cwd","config","getConfigurations","generateTestOptions","then","options","prepareAndStartTheTest","code","e","framework","suites","Array","isArray","Error","capsArr","capabilities","exitCode","reporter","ReportAggregator","init","wsReporter","wsPort","undefined","WebSocketReporter","launcher","parallel","workers","isNaN","ParallelLauncher","Launcher","startAndWaitForClient","onLaunchStart","run","onLaunchEnd","generateReports","stop","getExitCode","trace","setTimeout"],"mappings":"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","sourcesContent":["#! /usr/bin/env node\r\n/*\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\nimport * as cliutil from './cli-util';\r\nimport Launcher from './launcher';\r\nimport ParallelLauncher from './parallel-launcher';\r\nimport ReportAggregator from '../reporter/ReportAggregator';\r\nimport WebSocketReporter from '../reporter/WebSocketReporter';\r\n\r\nprocess.on('SIGINT', handleSigInt);\r\nprocess.on('uncaughtException', error => {\r\n    console.error('uncaughtException', error);\r\n});\r\n\r\nprocess.on('unhandledRejection', error => {\r\n    console.error('unhandledRejection', error);\r\n});\r\n\r\n// parse command line arguments\r\nconst argv = require('minimist')(process.argv.slice(2));\r\n\r\nif (argv.v || argv.version) {\r\n    console.log(require('../../package.json').version);\r\n    process.exit(0);\r\n} else if (typeof(argv._[0]) === 'undefined' || argv.help) {\r\n    printUsage();\r\n    process.exit(1);\r\n}\r\nif (argv.d || argv.delay) {\r\n    const delay = argv.d || argv.delay;\r\n    if (!(parseInt(delay) > 0)) {\r\n        console.error(\"Invalid argument - 'delay' should be a non-negative number.\");\r\n        printUsage();\r\n        process.exit(1);\r\n    }\r\n}\r\n\r\nconst targetFile = cliutil.processTargetPath(argv._[0], argv.cwd);\r\nif (targetFile == null) {\r\n    printUsage();\r\n    process.exit(1);\r\n}\r\n\r\nconst config = cliutil.getConfigurations(targetFile, argv);\r\n\r\ncliutil.generateTestOptions(config, argv).then(\r\n    (options) => {\r\n        prepareAndStartTheTest(options).then(\r\n            (code) => {\r\n                console.log('Done!');\r\n                process.exit(code);\r\n            },\r\n            (e) => {\r\n                console.error('Test failed: ', e);\r\n                process.exit(1);\r\n            }\r\n        );\r\n    },\r\n    (e) => {\r\n        console.error('Test failed on generate state: ', e);\r\n        process.exit(1);\r\n    }\r\n);\r\n\r\nasync function prepareAndStartTheTest(options) {\r\n    if (options.framework === 'oxygen' && (!options.suites || !Array.isArray(options.suites))) {\r\n        throw new Error('Cannot start the test - no suites are specified.');\r\n    }\r\n    let capsArr = options.capabilities || [{}];\r\n    // check if capabilities object is an array or a hashtable\r\n    if (!(capsArr instanceof Array)) {\r\n        capsArr = [capsArr];\r\n    }\r\n    let exitCode = 0;\r\n    // start launcher\r\n    try {\r\n        const reporter = new ReportAggregator(options);\r\n        await reporter.init();\r\n        const wsReporter = options.wsPort !== undefined ?\r\n            new WebSocketReporter(reporter) : undefined;\r\n        const launcher = options.parallel && options.parallel.workers && !isNaN(options.parallel.workers) && options.parallel.workers > 1\r\n            ? new ParallelLauncher(options, reporter) : new Launcher(options, reporter);\r\n        await wsReporter?.startAndWaitForClient(options.wsPort);\r\n        console.log('Test started...');\r\n        await reporter.onLaunchStart(options);\r\n        await launcher.run(capsArr);\r\n        await reporter.onLaunchEnd();\r\n        // Generate file report only when no wsport argument is provided\r\n        if (!wsReporter) {\r\n            await reporter.generateReports();\r\n        }\r\n        wsReporter?.stop();\r\n        exitCode = reporter.getExitCode();\r\n    }\r\n    catch (e) {\r\n        console.error('Fatal error', e);\r\n        console.trace();\r\n        process.exit(1);\r\n    }\r\n    return exitCode;\r\n}\r\n\r\nfunction handleSigInt() {\r\n    // delay process exit to let Oxygen to properly dispose\r\n    setTimeout(() => process.exit(0), 2000);\r\n}\r\n\r\nfunction printUsage() {\r\n    console.log(`Usage: oxygen [OPTIONS]... FILE\r\n\r\nFILE - Path to a test script (.js) or a project configuration (.json) file.\r\n\r\nGeneral options:\r\n  -d, --delay=SECONDS        Delay between each command in seconds.\r\n      --rf={html|pdf|xml|excel|junit|json}  Reports file format. Default is html.\r\n      --ro=PATH              Output path for report file. If specified, the report\r\n                             will overwrite any previous reports.\r\n  -i, --iter=COUNT           Number of times to run the test. Default is 1.\r\n  -p, --param=FILE           Parameters file. If not specified an attempt will\r\n                             be made to load parameters from a file named same\r\n                             as the test script, located in the same directory,\r\n                             and having extension - xlsx, xls, csv, or txt.\r\n      --pm={seq|random|all}  Order in which to read the parameters - sequential,\r\n                             random, all. Default is seq.\r\n                             In 'seq' and 'random' modes test will run exact number\r\n                             of times specified with the -i option.\r\n                             In 'all' mode, all available parameters will be read\r\n                             sequentially. This option is mutually exclusive with\r\n                             -i option.\r\n      --dbgport=PORT         Debugger port.\r\n      --wsport=PORT          WebSocket events reporter port.\r\n      --suites               Filter out suites by name\r\n  -h, --help                 Display this information and exit.\r\n  -v, --version              Display version information and exit.\r\n\r\nWeb test options:\r\n  -b, --browser={chrome|ie|safari|firefox}  Browser name. Default is chrome.\r\n  -s, --server=SERVER_URL    Selenium hub URL. Default is http://localhost:4444/wd/hub.\r\n      --reopen={true|false}  Reopen browser on each iteration. Default is false.\r\n      \r\nMobile test options:\r\n    -s, --server=SERVER_URL  Appium server URL. Default is http://localhost:4723/wd/hub.`);\r\n}"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/cli.js"],"names":["process","on","handleSigInt","error","console","argv","require","slice","v","version","log","exit","_","help","printUsage","d","delay","parseInt","targetFile","cliutil","processTargetPath","cwd","config","getConfigurations","generateTestOptions","then","options","prepareAndStartTheTest","code","e","framework","suites","Array","isArray","Error","capsArr","capabilities","exitCode","reporter","ReportAggregator","init","wsReporter","wsPort","undefined","WebSocketReporter","launcher","parallel","workers","isNaN","ParallelLauncher","Launcher","startAndWaitForClient","onLaunchStart","run","onLaunchEnd","generateReports","stop","getExitCode","trace","setTimeout"],"mappings":"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","sourcesContent":["#! /usr/bin/env node\n/*\n * Copyright (C) 2015-present CloudBeat Limited\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n */\nimport * as cliutil from './cli-util';\nimport Launcher from './launcher';\nimport ParallelLauncher from './parallel-launcher';\nimport ReportAggregator from '../reporter/ReportAggregator';\nimport WebSocketReporter from '../reporter/WebSocketReporter';\n\nprocess.on('SIGINT', handleSigInt);\nprocess.on('uncaughtException', error => {\n    console.error('uncaughtException', error);\n});\n\nprocess.on('unhandledRejection', error => {\n    console.error('unhandledRejection', error);\n});\n\n// parse command line arguments\nconst argv = require('minimist')(process.argv.slice(2));\n\nif (argv.v || argv.version) {\n    console.log(require('../../package.json').version);\n    process.exit(0);\n} else if (typeof(argv._[0]) === 'undefined' || argv.help) {\n    printUsage();\n    process.exit(1);\n}\nif (argv.d || argv.delay) {\n    const delay = argv.d || argv.delay;\n    if (!(parseInt(delay) > 0)) {\n        console.error(\"Invalid argument - 'delay' should be a non-negative number.\");\n        printUsage();\n        process.exit(1);\n    }\n}\n\nconst targetFile = cliutil.processTargetPath(argv._[0], argv.cwd);\nif (targetFile == null) {\n    printUsage();\n    process.exit(1);\n}\n\nconst config = cliutil.getConfigurations(targetFile, argv);\n\ncliutil.generateTestOptions(config, argv).then(\n    (options) => {\n        prepareAndStartTheTest(options).then(\n            (code) => {\n                console.log('Done!');\n                process.exit(code);\n            },\n            (e) => {\n                console.error('Test failed: ', e);\n                process.exit(1);\n            }\n        );\n    },\n    (e) => {\n        console.error('Test failed on generate state: ', e);\n        process.exit(1);\n    }\n);\n\nasync function prepareAndStartTheTest(options) {\n    if (options.framework === 'oxygen' && (!options.suites || !Array.isArray(options.suites))) {\n        throw new Error('Cannot start the test - no suites are specified.');\n    }\n    let capsArr = options.capabilities || [{}];\n    // check if capabilities object is an array or a hashtable\n    if (!(capsArr instanceof Array)) {\n        capsArr = [capsArr];\n    }\n    let exitCode = 0;\n    // start launcher\n    try {\n        const reporter = new ReportAggregator(options);\n        await reporter.init();\n        const wsReporter = options.wsPort !== undefined ?\n            new WebSocketReporter(reporter) : undefined;\n        const launcher = options.parallel && options.parallel.workers && !isNaN(options.parallel.workers) && options.parallel.workers > 1\n            ? new ParallelLauncher(options, reporter) : new Launcher(options, reporter);\n        await wsReporter?.startAndWaitForClient(options.wsPort);\n        console.log('Test started...');\n        await reporter.onLaunchStart(options);\n        await launcher.run(capsArr);\n        await reporter.onLaunchEnd();\n        // Generate file report only when no wsport argument is provided\n        if (!wsReporter) {\n            await reporter.generateReports();\n        }\n        wsReporter?.stop();\n        exitCode = reporter.getExitCode();\n    }\n    catch (e) {\n        console.error('Fatal error', e);\n        console.trace();\n        process.exit(1);\n    }\n    return exitCode;\n}\n\nfunction handleSigInt() {\n    // delay process exit to let Oxygen to properly dispose\n    setTimeout(() => process.exit(0), 2000);\n}\n\nfunction printUsage() {\n    console.log(`Usage: oxygen [OPTIONS]... FILE\n\nFILE - Path to a test script (.js) or a project configuration (.json) file.\n\nGeneral options:\n  -d, --delay=SECONDS        Delay between each command in seconds.\n      --rf={html|pdf|xml|excel|junit|json}  Reports file format. Default is html.\n      --ro=PATH              Output path for report file. If specified, the report\n                             will overwrite any previous reports.\n  -i, --iter=COUNT           Number of times to run the test. Default is 1.\n  -p, --param=FILE           Parameters file. If not specified an attempt will\n                             be made to load parameters from a file named same\n                             as the test script, located in the same directory,\n                             and having extension - xlsx, xls, csv, or txt.\n      --pm={seq|random|all}  Order in which to read the parameters - sequential,\n                             random, all. Default is seq.\n                             In 'seq' and 'random' modes test will run exact number\n                             of times specified with the -i option.\n                             In 'all' mode, all available parameters will be read\n                             sequentially. This option is mutually exclusive with\n                             -i option.\n      --dbgport=PORT         Debugger port.\n      --wsport=PORT          WebSocket events reporter port.\n      --suites               Filter out suites by name\n  -h, --help                 Display this information and exit.\n  -v, --version              Display version information and exit.\n\nWeb test options:\n  -b, --browser={chrome|ie|safari|firefox}  Browser name. Default is chrome.\n  -s, --server=SERVER_URL    Selenium hub URL. Default is http://localhost:4444/wd/hub.\n      --reopen={true|false}  Reopen browser on each iteration. Default is false.\n      \nMobile test options:\n    -s, --server=SERVER_URL  Appium server URL. Default is http://localhost:4723/wd/hub.`);\n}"]}
|
|
@@ -63,17 +63,19 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
63
63
|
async onLaunchStart({
|
|
64
64
|
options
|
|
65
65
|
}) {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
})
|
|
66
|
+
try {
|
|
67
|
+
const {
|
|
68
|
+
tempId,
|
|
69
|
+
promise
|
|
70
|
+
} = this.rpClient.startLaunch({
|
|
71
|
+
mode: this.reporterOpts.mode || LAUNCH_MODES.DEFAULT,
|
|
72
|
+
debug: false
|
|
73
|
+
});
|
|
74
|
+
this.tempLaunchId = tempId;
|
|
75
|
+
await this.promiseWithTimeout(promise);
|
|
76
|
+
} catch (e) {
|
|
77
|
+
console.dir(`RP - Failed to start launch: ${e}`);
|
|
78
|
+
}
|
|
77
79
|
}
|
|
78
80
|
|
|
79
81
|
async onLaunchEnd({
|
|
@@ -81,13 +83,13 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
81
83
|
}) {
|
|
82
84
|
await this._reportEndOfStartedSuites();
|
|
83
85
|
const hasFailed = results.some(x => x.status === _status.default.FAILED);
|
|
84
|
-
const {
|
|
85
|
-
promise
|
|
86
|
-
} = await this.rpClient.finishLaunch(this.tempLaunchId, {
|
|
87
|
-
status: hasFailed ? 'FAILED' : 'PASSED'
|
|
88
|
-
});
|
|
89
86
|
|
|
90
87
|
try {
|
|
88
|
+
const {
|
|
89
|
+
promise
|
|
90
|
+
} = await this.rpClient.finishLaunch(this.tempLaunchId, {
|
|
91
|
+
status: hasFailed ? 'FAILED' : 'PASSED'
|
|
92
|
+
});
|
|
91
93
|
await this.promiseWithTimeout(promise);
|
|
92
94
|
} catch (e) {
|
|
93
95
|
console.dir(`RP - Failed to end launch: ${e}`);
|
|
@@ -122,13 +124,13 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
122
124
|
name: suiteDef.name || this.options.name,
|
|
123
125
|
type: TEST_ITEM_TYPES.SUITE
|
|
124
126
|
};
|
|
125
|
-
const {
|
|
126
|
-
tempId,
|
|
127
|
-
promise
|
|
128
|
-
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);
|
|
129
|
-
this.cbSuiteToRpIdHash[suiteRefId] = tempId;
|
|
130
127
|
|
|
131
128
|
try {
|
|
129
|
+
const {
|
|
130
|
+
tempId,
|
|
131
|
+
promise
|
|
132
|
+
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);
|
|
133
|
+
this.cbSuiteToRpIdHash[suiteRefId] = tempId;
|
|
132
134
|
await this.promiseWithTimeout(promise);
|
|
133
135
|
} catch (e) {
|
|
134
136
|
console.dir(`RP - Failed to start suite item: ${e}`);
|
|
@@ -162,13 +164,12 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
162
164
|
return;
|
|
163
165
|
}
|
|
164
166
|
|
|
165
|
-
const {
|
|
166
|
-
tempId,
|
|
167
|
-
promise
|
|
168
|
-
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpSuiteId);
|
|
169
|
-
this.cbCaseToRpIdHash[caseId] = tempId;
|
|
170
|
-
|
|
171
167
|
try {
|
|
168
|
+
const {
|
|
169
|
+
tempId,
|
|
170
|
+
promise
|
|
171
|
+
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpSuiteId);
|
|
172
|
+
this.cbCaseToRpIdHash[caseId] = tempId;
|
|
172
173
|
await this.promiseWithTimeout(promise);
|
|
173
174
|
} catch (e) {
|
|
174
175
|
console.dir(`RP - Failed to start test item: ${e}`);
|
|
@@ -204,11 +205,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
204
205
|
message: logMsg,
|
|
205
206
|
level: 'error'
|
|
206
207
|
};
|
|
207
|
-
const {
|
|
208
|
-
promise
|
|
209
|
-
} = this.rpClient.sendLog(rpTestId, logReq, rpFile);
|
|
210
208
|
|
|
211
209
|
try {
|
|
210
|
+
const {
|
|
211
|
+
promise
|
|
212
|
+
} = this.rpClient.sendLog(rpTestId, logReq, rpFile);
|
|
212
213
|
await this.promiseWithTimeout(promise);
|
|
213
214
|
} catch (e) {
|
|
214
215
|
console.dir(`RP - Failed to send log for finished test item: ${e}`);
|
|
@@ -219,11 +220,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
219
220
|
const finishTestItemReq = {
|
|
220
221
|
status: result.status.toLowerCase()
|
|
221
222
|
};
|
|
222
|
-
const {
|
|
223
|
-
promise
|
|
224
|
-
} = this.rpClient.finishTestItem(rpTestId, finishTestItemReq);
|
|
225
223
|
|
|
226
224
|
try {
|
|
225
|
+
const {
|
|
226
|
+
promise
|
|
227
|
+
} = this.rpClient.finishTestItem(rpTestId, finishTestItemReq);
|
|
227
228
|
await this.promiseWithTimeout(promise);
|
|
228
229
|
} catch (e) {
|
|
229
230
|
console.dir(`RP - Failed to finish test item: ${e}`);
|
|
@@ -271,13 +272,13 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
271
272
|
testCaseId: rpCaseId,
|
|
272
273
|
hasStats: false
|
|
273
274
|
};
|
|
274
|
-
const {
|
|
275
|
-
tempId,
|
|
276
|
-
promise
|
|
277
|
-
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpParentId);
|
|
278
|
-
this.cbStepToRpIdHash[step.id] = tempId;
|
|
279
275
|
|
|
280
276
|
try {
|
|
277
|
+
const {
|
|
278
|
+
tempId,
|
|
279
|
+
promise
|
|
280
|
+
} = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpParentId);
|
|
281
|
+
this.cbStepToRpIdHash[step.id] = tempId;
|
|
281
282
|
await this.promiseWithTimeout(promise);
|
|
282
283
|
} catch (e) {
|
|
283
284
|
console.dir(`RP - Failed to start step item: ${e}`);
|
|
@@ -323,11 +324,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
323
324
|
level: 'error',
|
|
324
325
|
file: rpFile
|
|
325
326
|
};
|
|
326
|
-
const {
|
|
327
|
-
promise
|
|
328
|
-
} = this.rpClient.sendLog(rpStepId, logReq, rpFile);
|
|
329
327
|
|
|
330
328
|
try {
|
|
329
|
+
const {
|
|
330
|
+
promise
|
|
331
|
+
} = this.rpClient.sendLog(rpStepId, logReq, rpFile);
|
|
331
332
|
await this.promiseWithTimeout(promise);
|
|
332
333
|
} catch (e) {
|
|
333
334
|
console.dir(`RP - Failed to send log for finished test item: ${e}`);
|
|
@@ -338,11 +339,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
338
339
|
const finishTestItemReq = {
|
|
339
340
|
status: result.status.toLowerCase()
|
|
340
341
|
};
|
|
341
|
-
const {
|
|
342
|
-
promise
|
|
343
|
-
} = this.rpClient.finishTestItem(rpStepId, finishTestItemReq);
|
|
344
342
|
|
|
345
343
|
try {
|
|
344
|
+
const {
|
|
345
|
+
promise
|
|
346
|
+
} = this.rpClient.finishTestItem(rpStepId, finishTestItemReq);
|
|
346
347
|
await this.promiseWithTimeout(promise);
|
|
347
348
|
} catch (e) {
|
|
348
349
|
console.dir(`RP - Failed to finish step item: ${e}`);
|
|
@@ -378,11 +379,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
378
379
|
level: rpLevel,
|
|
379
380
|
time: time
|
|
380
381
|
};
|
|
381
|
-
const {
|
|
382
|
-
promise
|
|
383
|
-
} = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);
|
|
384
382
|
|
|
385
383
|
try {
|
|
384
|
+
const {
|
|
385
|
+
promise
|
|
386
|
+
} = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);
|
|
386
387
|
await this.promiseWithTimeout(promise);
|
|
387
388
|
} catch (e) {
|
|
388
389
|
console.dir(`RP - Failed to create log item: ${e}`);
|
|
@@ -440,11 +441,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
440
441
|
level: rpLevel,
|
|
441
442
|
time: time
|
|
442
443
|
};
|
|
443
|
-
const {
|
|
444
|
-
promise
|
|
445
|
-
} = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);
|
|
446
444
|
|
|
447
445
|
try {
|
|
446
|
+
const {
|
|
447
|
+
promise
|
|
448
|
+
} = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);
|
|
448
449
|
await this.promiseWithTimeout(promise);
|
|
449
450
|
} catch (e) {
|
|
450
451
|
console.dir(`RP - Failed to create log item: ${e}`);
|
|
@@ -461,11 +462,11 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
461
462
|
const finishTestItemReq = {
|
|
462
463
|
status: hasFailedSuite ? 'failed' : 'passed'
|
|
463
464
|
};
|
|
464
|
-
const {
|
|
465
|
-
promise
|
|
466
|
-
} = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);
|
|
467
465
|
|
|
468
466
|
try {
|
|
467
|
+
const {
|
|
468
|
+
promise
|
|
469
|
+
} = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);
|
|
469
470
|
await this.promiseWithTimeout(promise);
|
|
470
471
|
} catch (e) {
|
|
471
472
|
console.dir(`RP - Failed to finish suite item: ${e}`);
|
|
@@ -517,7 +518,7 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
517
518
|
}
|
|
518
519
|
}
|
|
519
520
|
|
|
520
|
-
promiseWithTimeout(promise, timeout =
|
|
521
|
+
promiseWithTimeout(promise, timeout = 30 * 1000) {
|
|
521
522
|
return new Promise((resolve, reject) => {
|
|
522
523
|
if (!promise || !promise.then) {
|
|
523
524
|
reject(new Error(`Promise await timeout of ${timeout} ms`));
|
|
@@ -531,4 +532,4 @@ class ReportPortalReporter extends _ReporterBase.default {
|
|
|
531
532
|
}
|
|
532
533
|
|
|
533
534
|
exports.default = ReportPortalReporter;
|
|
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"]}
|
|
535
|
+
//# 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","promiseWithTimeout","console","dir","onLaunchEnd","_reportEndOfStartedSuites","hasFailed","some","x","status","Status","FAILED","finishLaunch","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","error","timeout","Promise","resolve","reject","then","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        try {\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            await this.promiseWithTimeout(promise);\r\n        }\r\n        catch (e) {\r\n            console.dir(`RP - Failed to start launch: ${e}`);\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\r\n        try {\r\n            const { promise } = await this.rpClient.finishLaunch(this.tempLaunchId, {\r\n                status: hasFailed ? 'FAILED' : 'PASSED'\r\n            });\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\r\n        try {\r\n            const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId);\r\n            this.cbSuiteToRpIdHash[suiteRefId] = tempId;\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\r\n        try {\r\n            const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpSuiteId);\r\n            this.cbCaseToRpIdHash[caseId] = tempId;\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\r\n                try {\r\n                    const { promise } = this.rpClient.sendLog(rpTestId, logReq, rpFile);\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\r\n        try {\r\n            const { promise } = this.rpClient.finishTestItem(rpTestId, finishTestItemReq);\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\r\n        try {\r\n            const { tempId, promise } = this.rpClient.startTestItem(startTestItemReq, this.tempLaunchId, rpParentId);\r\n            this.cbStepToRpIdHash[step.id] = tempId;\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\r\n                try {\r\n                    const { promise } = this.rpClient.sendLog(rpStepId, logReq, rpFile);\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\r\n        try {\r\n            const { promise } = this.rpClient.finishTestItem(rpStepId, finishTestItemReq);\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\r\n            try {\r\n                const { promise } = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);\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\r\n            try {\r\n                const { promise } = this.rpClient.sendLog(rpParentId || this.tempLaunchId, logReq);\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\r\n            try {\r\n                const { promise } = this.rpClient.finishTestItem(rpSuiteId, finishTestItemReq);\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 = 30 * 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"]}
|