oxygen-cli 1.29.1 → 1.30.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 CHANGED
@@ -1,5 +1,16 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## v1.30.1 (2023-08-29)
4
+
5
+ #### :beetle: Bug Fix
6
+ * Fix step's Warning status not being properly processed.
7
+ * Improve the way test result status for suites with Skipped and Warning statuses is determined.
8
+
9
+ ## v1.30.0 (2023-08-15)
10
+
11
+ #### :tada: New Feature
12
+ * Add `utils.transaction` command.
13
+
3
14
  ## v1.29.1 (2023-07-26)
4
15
 
5
16
  #### :beetle: Bug Fix
@@ -247,8 +247,25 @@ class UtilsModule extends _OxygenModule.default {
247
247
  throw new _OxygenError.default(_helper.default.errorCode.XML_ERROR, e.message);
248
248
  }
249
249
  }
250
+ /**
251
+ * @summary Opens new transaction.
252
+ * @description The transaction will persist untill a new one is opened. Transaction names must be unique.
253
+ * @function transaction
254
+ * @param {String} name - The transaction name.
255
+ */
256
+
257
+
258
+ async transaction(name) {
259
+ if (!name) {
260
+ return;
261
+ } // just in case user passed a complex object by mistake
262
+
263
+
264
+ name = name.toString();
265
+ global._lastTransactionName = name;
266
+ }
250
267
 
251
268
  }
252
269
 
253
270
  exports.default = UtilsModule;
254
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-utils.js"],"names":["MODULE_NAME","UtilsModule","OxygenModule","constructor","options","context","rs","logger","modules","services","_alwaysInitialized","_isInitialized","name","pause","ms","utils","assertArgumentNumberNonNegative","libUtils","sleep","decrypt","text","encrypt","readCsv","filePath","parse","require","fs","path","ext","extname","OxError","errorHelper","errorCode","CSV_ERROR","data","readFileSync","e","replace","bom","charCodeAt","table","columns","trim","message","writeCsv","ObjectsToCsv","csv","toDisk","allColumns","readXlsx","reader","ExcelReader","read","dnsResolve","hostname","rrType","assertArgumentNonEmptyString","rrTypes","includes","SCRIPT_ERROR","join","dnsPromises","promises","resolve","DNS_ERROR","xmlToJson","xmlDataStr","parser","fastXmlParser","XMLParser","output","XML_ERROR"],"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 * @name utils\r\n * @description Provides miscellaneous utility methods.\r\n */\r\n\r\nconst MODULE_NAME = 'utils';\r\nimport fastXmlParser from 'fast-xml-parser';\r\nimport OxygenModule from '../core/OxygenModule';\r\nimport utils from './utils';\r\nimport libUtils from '../lib/util';\r\nimport OxError from '../errors/OxygenError';\r\nimport errorHelper from '../errors/helper';\r\nimport ExcelReader from '../lib/param-reader-excel';\r\n\r\nexport default class UtilsModule extends OxygenModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this._alwaysInitialized = true;\r\n        this._isInitialized = true;\r\n    }\r\n\r\n    /*\r\n     * @summary Gets module name\r\n     * @function name\r\n     * @return {String} Constant value \"utils\".\r\n     */\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @summary Pause test execution for the given amount of milliseconds.\r\n     * @function pause\r\n     * @param {Number} ms - Milliseconds to pause the execution for.\r\n     */\r\n    async pause(ms) {\r\n        utils.assertArgumentNumberNonNegative(ms, 'ms');\r\n        await libUtils.sleep(ms);\r\n    }\r\n\r\n    /**\r\n     * @summary Decrypt text\r\n     * @function decrypt\r\n     * @param {String} text - Text\r\n     * @return {Object} DecryptResult Object with getDecryptResult method\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // to encrypt plaintext into ciphertext \r\n     * const encrypt = utils.encrypt('https://www.wikipedia.org');\r\n     * log.info(encrypt); // will print b757ba2c2fc50fbb511d596816ca06c4fa56f4e98ce222f30bc58d5251ed635e\r\n     * \r\n     * // to decrypt ciphertext and use it in script  \r\n     * const decrypt = utils.decrypt(encrypt);\r\n     * log.info(decrypt); // will print ENCRYPTED\r\n     * \r\n     * web.init();\r\n     * web.open(decrypt); // will open https://www.wikipedia.org\r\n     * \r\n     * // to get original plaintext use getDecryptResult\r\n     * const value = decrypt.getDecryptResult();\r\n     * log.info(value); //will print https://www.wikipedia.org\r\n     */\r\n    decrypt(text) {\r\n        return libUtils.decrypt(text);\r\n    }\r\n\r\n    /**\r\n     * @summary Encrypt text\r\n     * @function encrypt\r\n     * @param {String} text - Text\r\n     * @return {String} Encrypted text\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // to encrypt plaintext into ciphertext \r\n     * const encrypt = utils.encrypt('https://www.wikipedia.org');\r\n     * log.info(encrypt); // will print b757ba2c2fc50fbb511d596816ca06c4fa56f4e98ce222f30bc58d5251ed635e\r\n     * \r\n     * // to decrypt ciphertext and use it in script  \r\n     * const decrypt = utils.decrypt(encrypt);\r\n     * log.info(decrypt); // will print ENCRYPTED\r\n     * \r\n     * web.init();\r\n     * web.open(decrypt); // will open https://www.wikipedia.org\r\n     * \r\n     * // to get original plaintext use getDecryptResult\r\n     * const value = decrypt.getDecryptResult();\r\n     * log.info(value); //will print https://www.wikipedia.org\r\n     */\r\n    encrypt(text) {\r\n        return libUtils.encrypt(text);\r\n    }\r\n    /**\r\n     * @summary Reads data from csv file\r\n     * @function readCsv\r\n     * @param {String} filePath - Absolute path to file\r\n     * @param {Object=} options - [Options](https://csv.js.org/parse/options/)\r\n     */\r\n    readCsv(filePath, options = {}) {\r\n        const parse = require('csv-parse/lib/sync');\r\n        var fs = require('fs');\r\n        var path = require('path');\r\n\r\n        var ext = path.extname(filePath);\r\n        if (ext !== '.csv' && ext !== '.txt') {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, 'Unsupported file extension: ' + ext);\r\n        }\r\n\r\n        var data;\r\n        try {\r\n            data = fs.readFileSync(filePath, 'utf8');\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, 'Unable to read parameters file: ' + e);\r\n        }\r\n\r\n        // CSVs produced by OS X Excel have header terminated with 0d0d0a\r\n        data = data.replace(/\\r\\r/g, '\\r');\r\n\r\n        // strip BOM for UTF-8\r\n        var bom = false;\r\n        // catches 0xEFBBBF (UTF-8 BOM) because the buffer-to-string\r\n        // conversion translates it to 0xFEFF (UTF-16 BOM)\r\n        if (data.charCodeAt(0) === 0xFEFF) {\r\n            bom = true;\r\n        }\r\n\r\n        try {\r\n            var table = parse(data, { bom: bom, columns: true, trim: true, ...options });\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, e.message);\r\n        }\r\n\r\n        return table;\r\n    }\r\n\r\n    /**\r\n     * @summary Writes data into csv file\r\n     * @function writeCsv\r\n     * @param {String} filePath - Absolute path to file\r\n     * @param {Array} data - CSV data in format [{column_name_1: 'foo', column_name_2: 'bar'}]\r\n     * @param {Object=} options - [Options](https://github.com/anton-bot/objects-to-csv#async-todiskfilename-options)\r\n     */\r\n    async writeCsv(filePath, data, options = {}) {\r\n        try {\r\n            const ObjectsToCsv = require('objects-to-csv');\r\n            const csv = new ObjectsToCsv(data);\r\n            await csv.toDisk(filePath, { allColumns: true, ...options });\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, e.message);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Reads data from Xlsx file\r\n     * @function readXlsx\r\n     * @param {String} filePath - Absolute path to file\r\n     * @return {Array} - Array of xlsx data\r\n     */\r\n    async readXlsx(filePath) {\r\n        const reader = new ExcelReader();\r\n        return await reader.read(filePath);\r\n    }\r\n\r\n    /**\r\n     * @summary Uses the DNS protocol to resolve a host name\r\n     * @function dnsResolve\r\n     * @param {String} hostname - Host name to resolve.\r\n     * @param {String=} rrType - Resource record type. Default: 'A'.\r\n     * @return {String[] | Object} - Array or Object of resource records. The type and structure of individual results vary based on rrtype\r\n     */\r\n    async dnsResolve(hostname, rrType = 'A') {\r\n        utils.assertArgumentNonEmptyString(hostname, 'hostname');\r\n        const rrTypes = ['A', 'AAAA', 'ANY', 'CNAME', 'MX', 'NAPTR', 'NS', 'PTR', 'SOA', 'SRV', 'TXT'];\r\n\r\n        if (!rrTypes.includes(rrType)) {\r\n            throw new OxError(errorHelper.errorCode.SCRIPT_ERROR, `Invalid argument - 'rrType'. Available rrType values: ${rrTypes.join(', ')}`);\r\n        }\r\n\r\n        const dnsPromises = require('dns').promises;\r\n        try {\r\n            return await dnsPromises.resolve(hostname, rrType);\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.DNS_ERROR, e.message);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Parse XML data to JS object \r\n     * @function xmlToJson\r\n     * @param {string|Buffer} xmlDataStr - Like <root a=\"nice\" b=\"very nice\" ><a>wow</a></root>\r\n     * @param {boolean|Object} options - [Options](https://github.com/NaturalIntelligence/fast-xml-parser/blob/master/docs/v4/2.XMLparseOptions.md) \r\n     */\r\n    xmlToJson(xmlDataStr, options = {}) {\r\n        try {\r\n            const parser = new fastXmlParser.XMLParser(options);\r\n            const output = parser.parse(xmlDataStr);\r\n            return output;\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.XML_ERROR, e.message);\r\n        }\r\n    }\r\n}"]}
271
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-utils.js"],"names":["MODULE_NAME","UtilsModule","OxygenModule","constructor","options","context","rs","logger","modules","services","_alwaysInitialized","_isInitialized","name","pause","ms","utils","assertArgumentNumberNonNegative","libUtils","sleep","decrypt","text","encrypt","readCsv","filePath","parse","require","fs","path","ext","extname","OxError","errorHelper","errorCode","CSV_ERROR","data","readFileSync","e","replace","bom","charCodeAt","table","columns","trim","message","writeCsv","ObjectsToCsv","csv","toDisk","allColumns","readXlsx","reader","ExcelReader","read","dnsResolve","hostname","rrType","assertArgumentNonEmptyString","rrTypes","includes","SCRIPT_ERROR","join","dnsPromises","promises","resolve","DNS_ERROR","xmlToJson","xmlDataStr","parser","fastXmlParser","XMLParser","output","XML_ERROR","transaction","toString","global","_lastTransactionName"],"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 * @name utils\r\n * @description Provides miscellaneous utility methods.\r\n */\r\n\r\nconst MODULE_NAME = 'utils';\r\nimport fastXmlParser from 'fast-xml-parser';\r\nimport OxygenModule from '../core/OxygenModule';\r\nimport utils from './utils';\r\nimport libUtils from '../lib/util';\r\nimport OxError from '../errors/OxygenError';\r\nimport errorHelper from '../errors/helper';\r\nimport ExcelReader from '../lib/param-reader-excel';\r\n\r\nexport default class UtilsModule extends OxygenModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this._alwaysInitialized = true;\r\n        this._isInitialized = true;\r\n    }\r\n\r\n    /*\r\n     * @summary Gets module name\r\n     * @function name\r\n     * @return {String} Constant value \"utils\".\r\n     */\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @summary Pause test execution for the given amount of milliseconds.\r\n     * @function pause\r\n     * @param {Number} ms - Milliseconds to pause the execution for.\r\n     */\r\n    async pause(ms) {\r\n        utils.assertArgumentNumberNonNegative(ms, 'ms');\r\n        await libUtils.sleep(ms);\r\n    }\r\n\r\n    /**\r\n     * @summary Decrypt text\r\n     * @function decrypt\r\n     * @param {String} text - Text\r\n     * @return {Object} DecryptResult Object with getDecryptResult method\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // to encrypt plaintext into ciphertext \r\n     * const encrypt = utils.encrypt('https://www.wikipedia.org');\r\n     * log.info(encrypt); // will print b757ba2c2fc50fbb511d596816ca06c4fa56f4e98ce222f30bc58d5251ed635e\r\n     * \r\n     * // to decrypt ciphertext and use it in script  \r\n     * const decrypt = utils.decrypt(encrypt);\r\n     * log.info(decrypt); // will print ENCRYPTED\r\n     * \r\n     * web.init();\r\n     * web.open(decrypt); // will open https://www.wikipedia.org\r\n     * \r\n     * // to get original plaintext use getDecryptResult\r\n     * const value = decrypt.getDecryptResult();\r\n     * log.info(value); //will print https://www.wikipedia.org\r\n     */\r\n    decrypt(text) {\r\n        return libUtils.decrypt(text);\r\n    }\r\n\r\n    /**\r\n     * @summary Encrypt text\r\n     * @function encrypt\r\n     * @param {String} text - Text\r\n     * @return {String} Encrypted text\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // to encrypt plaintext into ciphertext \r\n     * const encrypt = utils.encrypt('https://www.wikipedia.org');\r\n     * log.info(encrypt); // will print b757ba2c2fc50fbb511d596816ca06c4fa56f4e98ce222f30bc58d5251ed635e\r\n     * \r\n     * // to decrypt ciphertext and use it in script  \r\n     * const decrypt = utils.decrypt(encrypt);\r\n     * log.info(decrypt); // will print ENCRYPTED\r\n     * \r\n     * web.init();\r\n     * web.open(decrypt); // will open https://www.wikipedia.org\r\n     * \r\n     * // to get original plaintext use getDecryptResult\r\n     * const value = decrypt.getDecryptResult();\r\n     * log.info(value); //will print https://www.wikipedia.org\r\n     */\r\n    encrypt(text) {\r\n        return libUtils.encrypt(text);\r\n    }\r\n    /**\r\n     * @summary Reads data from csv file\r\n     * @function readCsv\r\n     * @param {String} filePath - Absolute path to file\r\n     * @param {Object=} options - [Options](https://csv.js.org/parse/options/)\r\n     */\r\n    readCsv(filePath, options = {}) {\r\n        const parse = require('csv-parse/lib/sync');\r\n        var fs = require('fs');\r\n        var path = require('path');\r\n\r\n        var ext = path.extname(filePath);\r\n        if (ext !== '.csv' && ext !== '.txt') {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, 'Unsupported file extension: ' + ext);\r\n        }\r\n\r\n        var data;\r\n        try {\r\n            data = fs.readFileSync(filePath, 'utf8');\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, 'Unable to read parameters file: ' + e);\r\n        }\r\n\r\n        // CSVs produced by OS X Excel have header terminated with 0d0d0a\r\n        data = data.replace(/\\r\\r/g, '\\r');\r\n\r\n        // strip BOM for UTF-8\r\n        var bom = false;\r\n        // catches 0xEFBBBF (UTF-8 BOM) because the buffer-to-string\r\n        // conversion translates it to 0xFEFF (UTF-16 BOM)\r\n        if (data.charCodeAt(0) === 0xFEFF) {\r\n            bom = true;\r\n        }\r\n\r\n        try {\r\n            var table = parse(data, { bom: bom, columns: true, trim: true, ...options });\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, e.message);\r\n        }\r\n\r\n        return table;\r\n    }\r\n\r\n    /**\r\n     * @summary Writes data into csv file\r\n     * @function writeCsv\r\n     * @param {String} filePath - Absolute path to file\r\n     * @param {Array} data - CSV data in format [{column_name_1: 'foo', column_name_2: 'bar'}]\r\n     * @param {Object=} options - [Options](https://github.com/anton-bot/objects-to-csv#async-todiskfilename-options)\r\n     */\r\n    async writeCsv(filePath, data, options = {}) {\r\n        try {\r\n            const ObjectsToCsv = require('objects-to-csv');\r\n            const csv = new ObjectsToCsv(data);\r\n            await csv.toDisk(filePath, { allColumns: true, ...options });\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.CSV_ERROR, e.message);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Reads data from Xlsx file\r\n     * @function readXlsx\r\n     * @param {String} filePath - Absolute path to file\r\n     * @return {Array} - Array of xlsx data\r\n     */\r\n    async readXlsx(filePath) {\r\n        const reader = new ExcelReader();\r\n        return await reader.read(filePath);\r\n    }\r\n\r\n    /**\r\n     * @summary Uses the DNS protocol to resolve a host name\r\n     * @function dnsResolve\r\n     * @param {String} hostname - Host name to resolve.\r\n     * @param {String=} rrType - Resource record type. Default: 'A'.\r\n     * @return {String[] | Object} - Array or Object of resource records. The type and structure of individual results vary based on rrtype\r\n     */\r\n    async dnsResolve(hostname, rrType = 'A') {\r\n        utils.assertArgumentNonEmptyString(hostname, 'hostname');\r\n        const rrTypes = ['A', 'AAAA', 'ANY', 'CNAME', 'MX', 'NAPTR', 'NS', 'PTR', 'SOA', 'SRV', 'TXT'];\r\n\r\n        if (!rrTypes.includes(rrType)) {\r\n            throw new OxError(errorHelper.errorCode.SCRIPT_ERROR, `Invalid argument - 'rrType'. Available rrType values: ${rrTypes.join(', ')}`);\r\n        }\r\n\r\n        const dnsPromises = require('dns').promises;\r\n        try {\r\n            return await dnsPromises.resolve(hostname, rrType);\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.DNS_ERROR, e.message);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Parse XML data to JS object \r\n     * @function xmlToJson\r\n     * @param {string|Buffer} xmlDataStr - Like <root a=\"nice\" b=\"very nice\" ><a>wow</a></root>\r\n     * @param {boolean|Object} options - [Options](https://github.com/NaturalIntelligence/fast-xml-parser/blob/master/docs/v4/2.XMLparseOptions.md) \r\n     */\r\n    xmlToJson(xmlDataStr, options = {}) {\r\n        try {\r\n            const parser = new fastXmlParser.XMLParser(options);\r\n            const output = parser.parse(xmlDataStr);\r\n            return output;\r\n        } catch (e) {\r\n            throw new OxError(errorHelper.errorCode.XML_ERROR, e.message);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Opens new transaction.\r\n     * @description The transaction will persist untill a new one is opened. Transaction names must be unique.\r\n     * @function transaction\r\n     * @param {String} name - The transaction name.\r\n     */\r\n    async transaction(name) {\r\n        if (!name) {\r\n            return;\r\n        }\r\n        // just in case user passed a complex object by mistake\r\n        name = name.toString();\r\n        global._lastTransactionName = name;\r\n    }\r\n}"]}
@@ -150,7 +150,7 @@ class ReportAggregator extends _events.EventEmitter {
150
150
  if (testResult) {
151
151
  testResult.endTime = _util.default.getTimeStamp();
152
152
  testResult.duration = testResult.endTime - testResult.startTime;
153
- testResult.status = fatalError ? _status.default.FAILED : testResult.suites.some(x => x.status === _status.default.FAILED) ? _status.default.FAILED : _status.default.PASSED;
153
+ testResult.status = this._determineTestStatusBySuites(testResult, fatalError);
154
154
 
155
155
  if (testResult.status === _status.default.FAILED) {
156
156
  if (fatalError) {
@@ -189,6 +189,32 @@ class ReportAggregator extends _events.EventEmitter {
189
189
  }
190
190
  }
191
191
 
192
+ _determineTestStatusBySuites(testResult, fatalError) {
193
+ if (fatalError) {
194
+ return _status.default.FAILED;
195
+ }
196
+
197
+ const hasFailedSuites = testResult.suites.some(x => x.status === _status.default.FAILED);
198
+
199
+ if (hasFailedSuites) {
200
+ return _status.default.FAILED;
201
+ }
202
+
203
+ const hasWarningSuites = testResult.suites.some(x => x.status === _status.default.WARNING);
204
+
205
+ if (hasWarningSuites) {
206
+ return _status.default.WARNING;
207
+ }
208
+
209
+ const allSuitesSkipped = testResult.suites.every(x => x.status === _status.default.SKIPPED);
210
+
211
+ if (allSuitesSkipped) {
212
+ return _status.default.SKIPPED;
213
+ }
214
+
215
+ return _status.default.PASSED;
216
+ }
217
+
192
218
  onIterationStart(rid, iteration, start) {
193
219
  if (iteration) {
194
220
  const msg = `${start} Iteration #${iteration} started...`;
@@ -338,10 +364,6 @@ class ReportAggregator extends _events.EventEmitter {
338
364
 
339
365
  const resultKey = result.options._groupResult.resultKey;
340
366
  const suiteKey = result.options._groupResult.suiteKey;
341
- console.log('resultKey', resultKey);
342
- console.log('suiteKey', suiteKey);
343
- console.log('startTime', result.startTime);
344
- console.log('endTime', result.endTime);
345
367
  let groupedResult = groupedResults[resultKey];
346
368
 
347
369
  if (!groupedResult) {
@@ -363,7 +385,6 @@ class ReportAggregator extends _events.EventEmitter {
363
385
  } else {
364
386
  for (const currentSuiteResult of result.suites) {
365
387
  const groupKey = `${suiteKey}-${currentSuiteResult.iterationNum}`;
366
- console.log('groupKey', groupKey);
367
388
  const groupedSuiteResult = groupedResult._suitesHash[groupKey];
368
389
 
369
390
  if (!groupedSuiteResult) {
@@ -375,8 +396,10 @@ class ReportAggregator extends _events.EventEmitter {
375
396
  groupedSuiteResult.duration = groupedSuiteResult.endTime - groupedSuiteResult.startTime;
376
397
  groupedSuiteResult.cases = [...groupedSuiteResult.cases, ...currentSuiteResult.cases];
377
398
 
378
- if (currentSuiteResult.cases.some(c => c.status === 'failed')) {
379
- groupedSuiteResult.status = 'failed';
399
+ if (currentSuiteResult.cases.some(c => c.status === _status.default.FAILED)) {
400
+ groupedSuiteResult.status = _status.default.FAILED;
401
+ } else if (currentSuiteResult.cases.some(c => c.status === _status.default.WARNING)) {
402
+ groupedSuiteResult.status = _status.default.WARNING;
380
403
  }
381
404
  }
382
405
  }
@@ -391,11 +414,18 @@ class ReportAggregator extends _events.EventEmitter {
391
414
  }
392
415
 
393
416
  groupedResult.suites = [...groupedResult.suites, ...Object.keys(groupedResult._suitesHash).map(suiteGroupKey => groupedResult._suitesHash[suiteGroupKey])];
394
- const firstFailedSuite = groupedResult.suites.find(s => s.status === 'failed');
417
+ const firstFailedSuite = groupedResult.suites.find(s => s.status === _status.default.FAILED);
395
418
 
396
419
  if (firstFailedSuite) {
397
- groupedResult.status = 'failed';
420
+ groupedResult.status = _status.default.FAILED;
398
421
  groupedResult.failure = firstFailedSuite.failure || groupedResult.failure;
422
+ } else {
423
+ const firstSuiteWithWarning = groupedResult.suites.find(s => s.status === _status.default.WARNING);
424
+
425
+ if (firstSuiteWithWarning) {
426
+ groupedResult.status = _status.default.WARNING;
427
+ groupedResult.failure = firstSuiteWithWarning.failure || groupedResult.failure;
428
+ }
399
429
  }
400
430
 
401
431
  delete groupedResult['_suitesHash'];
@@ -410,10 +440,12 @@ class ReportAggregator extends _events.EventEmitter {
410
440
  recalculateResultForStatus(results) {
411
441
  return results.map(result => {
412
442
  if (result && result.suites && Array.isArray(result.suites) && result.suites.length > 0) {
413
- const failed = result.suites.find(suite => suite.status === 'failed');
443
+ const failed = result.suites.find(suite => suite.status === _status.default.FAILED);
414
444
 
415
445
  if (failed) {
416
- result.status = 'failed';
446
+ result.status = _status.default.FAILED;
447
+ } else if (result.suites.find(suite => suite.status === _status.default.WARNING)) {
448
+ result.status = _status.default.WARNING;
417
449
  }
418
450
  }
419
451
 
@@ -437,4 +469,4 @@ class ReportAggregator extends _events.EventEmitter {
437
469
  }
438
470
 
439
471
  exports.default = ReportAggregator;
440
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reporter/ReportAggregator.js"],"names":["Reporters","json","JsonReporter","junit","JUnitReporter","html","HtmlReporter","excel","ExcelReporter","pdf","PdfReporter","xml","XmlReporter","DEFAULT_TEST_NAME","DEFAULT_REPORTERS","ReportAggregator","EventEmitter","constructor","options","results","runnerEndPromises","instantiateReporters","getExitCode","exitCode","Array","isArray","length","testFailded","find","item","status","reporters","generalReportingOpts","reporting","reporter","Object","prototype","hasOwnProperty","call","reporterName","name","reporterOpts","push","getResults","generateReports","groupedResults","groupResults","reportPath","generate","console","log","waitForResult","rid","waitForResults","Promise","all","onRunnerStart","opts","caps","Error","testResult","TestResult","startTime","oxutil","getTimeStamp","capabilities","environment","envVars","emit","onRunnerEnd","finalResult","fatalError","x","endTime","duration","Status","FAILED","suites","some","PASSED","failure","errorHelper","getFailureFromError","_getFirstFailure","type","location","toUpperCase","result","process","nextTick","resolve","onIterationStart","iteration","start","msg","onLogEntry","onIterationEnd","iterationNum","onSuiteStart","suiteId","suite","onSuiteEnd","suiteResult","onCaseStart","caseId","caseDef","case","onCaseEnd","caseResult","onStepStart","step","rootPath","framework","fullPath","path","onStepEnd","stepResult","toFixed","time","level","src","cases","steps","ungroupedResults","_groupResult","resultKey","suiteKey","groupedResult","Math","min","max","currentSuiteResult","groupKey","groupedSuiteResult","_suitesHash","c","groupedResultsList","keys","map","suiteGroupKey","firstFailedSuite","s","recalculateResultForStatus","validateResult","failed","uniqueSuitesIterationIds","includes","warn"],"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 * Report aggregator\r\n */\r\nimport { EventEmitter } from 'events';\r\nimport path from 'path';\r\nimport TestResult from '../model/test-result';\r\nimport oxutil from '../lib/util';\r\nimport { defer } from 'when';\r\n\r\n// import all built-in reporters\r\nimport JsonReporter from '../ox_reporters/reporter-json';\r\nimport JUnitReporter from '../ox_reporters/reporter-junit';\r\nimport HtmlReporter from '../ox_reporters/reporter-html';\r\nimport ExcelReporter from '../ox_reporters/reporter-excel';\r\nimport PdfReporter from '../ox_reporters/reporter-pdf';\r\nimport XmlReporter from '../ox_reporters/reporter-xml';\r\nimport errorHelper from '../errors/helper';\r\nimport Status from '../model/status';\r\n\r\nconst Reporters = {\r\n    json: JsonReporter,\r\n    junit: JUnitReporter,\r\n    html: HtmlReporter,\r\n    excel: ExcelReporter,\r\n    pdf: PdfReporter,\r\n    xml: XmlReporter\r\n};\r\n\r\nconst DEFAULT_TEST_NAME = 'Oxygen Test';\r\nconst DEFAULT_REPORTERS = [];\r\n\r\nexport default class ReportAggregator extends EventEmitter {\r\n    constructor(options) {\r\n        super();\r\n        // results hash table based on runner id key\r\n        this.results = [];\r\n        // a hash list of runnerEnd event promises, keyed by runner id\r\n        this.runnerEndPromises = {};\r\n        this.options = options;\r\n        this.instantiateReporters();\r\n    }\r\n\r\n    getExitCode() {\r\n        let exitCode = 0;\r\n\r\n        if (\r\n            this.results &&\r\n            Array.isArray(this.results) &&\r\n            this.results.length > 0\r\n        ) {\r\n            const testFailded = this.results.find((item) => item.status === 'failed');\r\n\r\n            if (testFailded) {\r\n                exitCode = -1;\r\n            }\r\n        } else {\r\n            // something broken ?\r\n            exitCode = -1;\r\n        }\r\n\r\n        return exitCode;\r\n    }\r\n\r\n    instantiateReporters() {\r\n        this.reporters = [];\r\n        const generalReportingOpts = this.options.reporting || {};\r\n        for (let reporter of generalReportingOpts.reporters || DEFAULT_REPORTERS) {\r\n            if (typeof reporter !== 'string' && !Object.prototype.hasOwnProperty.call(reporter, 'name')) {\r\n                // ignore reporters that do not have 'name' property as it's essential to load the corresponding Reporter class\r\n                continue;\r\n            }\r\n\r\n            const reporterName = typeof reporter === 'string' ? reporter : reporter.name;\r\n            const reporterOpts = typeof reporter === 'object' ? reporter : generalReportingOpts;\r\n\r\n            if (Object.prototype.hasOwnProperty.call(Reporters, reporterName)) {\r\n                this.reporters.push(new Reporters[reporterName](this.options, reporterOpts));\r\n            }\r\n        }\r\n    }\r\n\r\n    getResults() {\r\n        return this.results;\r\n    }\r\n\r\n    generateReports() {\r\n        if (!Array.isArray(this.reporters) || this.reporters.length == 0) {\r\n            return false;\r\n        }\r\n        const groupedResults = this.groupResults();\r\n        for (let reporter of this.reporters) {\r\n            const reportPath = reporter.generate(groupedResults);\r\n            console.log(`Your report is ready: ${reportPath}`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    async waitForResult(rid) {\r\n        if (!rid || !this.runnerEndPromises[rid]) {\r\n            return null;\r\n        }\r\n        return this.runnerEndPromises[rid];\r\n    }\r\n\r\n    async waitForResults() {\r\n        if (this.runnerEndPromises && this.runnerEndPromises.length) {\r\n            return Promise.all(this.runnerEndPromises);\r\n        }\r\n    }\r\n\r\n    onRunnerStart(rid, opts, caps) {\r\n        if (!rid) {\r\n            throw new Error('\"rid\" cannot be empty.');\r\n        }\r\n        const testResult = new TestResult();\r\n        testResult.rid = rid;\r\n        testResult.name = opts.name || DEFAULT_TEST_NAME;\r\n        testResult.startTime = oxutil.getTimeStamp();\r\n        testResult.capabilities = caps;\r\n        testResult.environment = opts.envVars || {};\r\n        testResult.options = opts;\r\n        this.results.push(testResult);\r\n        // create a new promise for later to be resolved on runner:end event\r\n        this.runnerEndPromises[rid] = defer();\r\n        console.log(`Test ${rid} has started...`);\r\n        this.emit('runner:start', {\r\n            rid,\r\n            opts,\r\n            caps\r\n        });\r\n    }\r\n\r\n    onRunnerEnd(rid, finalResult, fatalError) {\r\n        const testResult = this.results.find(x => x.rid === rid);\r\n        if (testResult) {\r\n            testResult.endTime = oxutil.getTimeStamp();\r\n            testResult.duration = testResult.endTime - testResult.startTime;\r\n            testResult.status = fatalError ? Status.FAILED : (testResult.suites.some(x => x.status === Status.FAILED)) ? Status.FAILED : Status.PASSED;\r\n            if (testResult.status === Status.FAILED) {\r\n                if (fatalError) {\r\n                    // assume that if fatalError is not inherited from Error class then we already got Oxygen Failure object\r\n                    testResult.failure = fatalError instanceof Error ? errorHelper.getFailureFromError(fatalError) : fatalError;\r\n                }\r\n                else {\r\n                    testResult.failure = this._getFirstFailure(testResult);\r\n                }\r\n            }\r\n            if (finalResult && finalResult.capabilities) {\r\n                testResult.capabilities = finalResult.capabilities;\r\n            }\r\n            if (testResult.failure) {\r\n                if (testResult.failure.type && testResult.failure.location) {\r\n                    console.log(`Error: ${testResult.failure.type} at ${testResult.failure.location}.`);\r\n                } else if (testResult.failure.type) {\r\n                    console.log(`Error: ${testResult.failure.type}`);\r\n                } else if (typeof testResult.failure === 'string') {\r\n                    console.log(`Error: ${testResult.failure}`);\r\n                }\r\n            }\r\n            console.log(`Test ${rid} has finished with status: ${testResult.status.toUpperCase()}.`);\r\n        }\r\n        this.emit('runner:end', {\r\n            rid,\r\n            result: testResult,\r\n        });\r\n        if (this.runnerEndPromises[rid]) {\r\n            // calling nextTick() will help us to insure that we resolve the promise after emit('runner:end') has completed\r\n            process.nextTick(() => {\r\n                this.runnerEndPromises[rid].resolve(testResult);\r\n            });\r\n        }\r\n    }\r\n\r\n    onIterationStart(rid, iteration, start) {\r\n        if (iteration) {\r\n            const msg = `${start} Iteration #${iteration} started...`;\r\n            console.log(msg);\r\n            this.onLogEntry(null, 'INFO', msg, 'user');\r\n        }\r\n    }\r\n\r\n    onIterationEnd(rid, result, start) {\r\n        if (result && result.iterationNum && result.status && result.status.toUpperCase) {\r\n            const msg = `${start} Iteration #${result.iterationNum} ended with status: ${result.status.toUpperCase()}.`;\r\n            console.log(msg);\r\n            this.onLogEntry(null, 'INFO', msg, 'user');\r\n        }\r\n    }\r\n\r\n    onSuiteStart(rid, suiteId, suite) {\r\n        console.log(`Suite \"${suite.name}\" has started...`);\r\n        this.emit('suite:start', {\r\n            rid,\r\n            suiteId: suiteId,\r\n            suite: suite,\r\n        });\r\n    }\r\n\r\n    onSuiteEnd(rid, suiteId, suiteResult) {\r\n        const testResult = this.results.find(x => x.rid === rid);\r\n        if (!testResult) {\r\n            return;\r\n        }\r\n        testResult.suites.push(suiteResult);\r\n        console.log(`Suite \"${suiteResult.name}\" has ended with status: ${suiteResult.status.toUpperCase()}.`);\r\n        this.emit('suite:end', {\r\n            rid,\r\n            suiteId,\r\n            result: suiteResult,\r\n        });\r\n    }\r\n\r\n    onCaseStart(rid, suiteId, caseId, caseDef) {\r\n        console.log(`- Case \"${caseDef.name}\" has started...`);\r\n        this.emit('case:start', {\r\n            rid,\r\n            suiteId,\r\n            caseId,\r\n            case: caseDef,\r\n        });\r\n    }\r\n\r\n    onCaseEnd(rid, suiteId, caseId, caseResult) {\r\n        console.log(`- Case \"${caseResult.name}\" has ended with status: ${caseResult.status.toUpperCase()}.`);\r\n        this.emit('case:end', {\r\n            rid,\r\n            suiteId,\r\n            caseId,\r\n            result: caseResult,\r\n        });\r\n    }\r\n\r\n    onStepStart(rid, step) {\r\n        console.log(`  - Step \"${step.name}\" has started...`);\r\n\r\n        if (this.options && this.options.rootPath && this.options.framework && this.options.framework === 'cucumber') {\r\n            const fullPath = path.resolve(this.options.rootPath, step.location);\r\n            step.location = fullPath+':1';\r\n        }\r\n\r\n        this.emit('step:start', {\r\n            rid,\r\n            step: step,\r\n        });\r\n    }\r\n\r\n    onStepEnd(rid, stepResult) {\r\n        const status = stepResult.status.toUpperCase();\r\n        const duration = stepResult.duration ? (stepResult.duration / 1000).toFixed(2) : 0;\r\n        console.log(`  - Step \"${stepResult.name}\" has ended in ${duration}s with status: ${status}.`);\r\n        this.emit('step:end', {\r\n            rid,\r\n            step: stepResult,\r\n        });\r\n    }\r\n\r\n    onLogEntry(time, level, msg, src = null) {\r\n        this.emit('log', {\r\n            level, msg, time, src\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Returns the first failure object in one of test result's entities. \r\n     * @param {TestResult} testResult \r\n     */\r\n    _getFirstFailure(testResult) {\r\n        if (testResult.status === Status.FAILED) {\r\n            if (testResult.failure) {\r\n                return testResult.failure;\r\n            }\r\n            for (let suiteResult of testResult.suites) {\r\n                if (suiteResult.status !== Status.FAILED) {\r\n                    continue;\r\n                }\r\n                if (suiteResult.failure) {\r\n                    return suiteResult.failure;\r\n                }\r\n                for (let caseResult of suiteResult.cases) {\r\n                    if (suiteResult.status !== Status.FAILED) {\r\n                        continue;\r\n                    }\r\n                    if (caseResult.failure) {\r\n                        return caseResult.failure;\r\n                    }\r\n                    for (let stepResult of caseResult.steps) {\r\n                        if (stepResult.status !== Status.FAILED) {\r\n                            continue;\r\n                        }\r\n                        return stepResult.failure || null;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return null;\r\n    }\r\n\r\n    groupResults() {\r\n        const groupedResults = {};\r\n        const ungroupedResults = [];\r\n        if (!Array.isArray(this.results) || this.results.length == 0) {\r\n            return false;\r\n        }\r\n        for (let result of this.results) {\r\n            if (!result.options._groupResult || !result.options._groupResult.resultKey) {\r\n                ungroupedResults.push(result);\r\n                continue;\r\n            }\r\n            const resultKey = result.options._groupResult.resultKey;\r\n            const suiteKey = result.options._groupResult.suiteKey;\r\n            console.log('resultKey', resultKey);\r\n            console.log('suiteKey', suiteKey);\r\n            console.log('startTime', result.startTime);\r\n            console.log('endTime', result.endTime);\r\n            let groupedResult = groupedResults[resultKey];\r\n            if (!groupedResult) {\r\n                groupedResult = groupedResults[resultKey] = {\r\n                    ...result,\r\n                    suites: [],\r\n                };\r\n                if (suiteKey) {\r\n                    groupedResult['_suitesHash'] = {};\r\n                }\r\n            }\r\n            else {\r\n                groupedResult.startTime = Math.min(groupedResult.startTime, result.startTime);\r\n                groupedResult.endTime = Math.max(groupedResult.endTime, result.endTime);\r\n                groupedResult.duration = groupedResult.endTime - groupedResult.startTime;\r\n            }\r\n            // if grouping is by result only, then just append current result's suites to the group's suites\r\n            if (!suiteKey) {\r\n                groupedResult.suites = [\r\n                    ...groupedResult.suites,\r\n                    ...result.suites\r\n                ];\r\n            }\r\n            else {\r\n                for (const currentSuiteResult of result.suites) {\r\n                    const groupKey = `${suiteKey}-${currentSuiteResult.iterationNum}`;\r\n                    console.log('groupKey', groupKey);\r\n                    const groupedSuiteResult = groupedResult._suitesHash[groupKey];\r\n                    if (!groupedSuiteResult) {\r\n                        groupedResult._suitesHash[groupKey] = { ...currentSuiteResult };\r\n                    }\r\n                    else {\r\n                        groupedSuiteResult.startTime = Math.min(groupedSuiteResult.startTime, currentSuiteResult.startTime);\r\n                        groupedSuiteResult.endTime = Math.max(groupedSuiteResult.endTime, currentSuiteResult.endTime);\r\n                        groupedSuiteResult.duration = groupedSuiteResult.endTime - groupedSuiteResult.startTime;\r\n                        groupedSuiteResult.cases = [\r\n                            ...groupedSuiteResult.cases,\r\n                            ...currentSuiteResult.cases\r\n                        ];\r\n                        if (currentSuiteResult.cases.some(c => c.status === 'failed')) {\r\n                            groupedSuiteResult.status = 'failed';\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        // convert grouped results hash to an array\r\n        const groupedResultsList = Object.keys(groupedResults).map(\r\n            groupKey => {\r\n                const groupedResult = groupedResults[groupKey];\r\n                if (!groupedResult._suitesHash) {\r\n                    return groupedResult;\r\n                }\r\n                groupedResult.suites = [\r\n                    ...groupedResult.suites,\r\n                    ...Object.keys(groupedResult._suitesHash).map(suiteGroupKey => groupedResult._suitesHash[suiteGroupKey])\r\n                ];\r\n                const firstFailedSuite = groupedResult.suites.find(s => s.status === 'failed');\r\n                if (firstFailedSuite) {\r\n                    groupedResult.status = 'failed';\r\n                    groupedResult.failure = firstFailedSuite.failure || groupedResult.failure;\r\n                }\r\n                delete groupedResult['_suitesHash'];\r\n                return groupedResult;\r\n            }\r\n        );\r\n        let results = [...groupedResultsList, ...ungroupedResults];\r\n        // change results status to faided if failed suites are finded\r\n        results = this.recalculateResultForStatus(results);\r\n\r\n        this.validateResult(results);\r\n        return results;\r\n    }\r\n\r\n    recalculateResultForStatus(results) {\r\n        return results.map((result) => {\r\n            if (\r\n                result &&\r\n                result.suites &&\r\n                Array.isArray(result.suites) &&\r\n                result.suites.length > 0\r\n            ) {\r\n                const failed = result.suites.find((suite) => suite.status === 'failed');\r\n                if (failed) {\r\n                    result.status = 'failed';\r\n                }\r\n            }\r\n\r\n            return result;\r\n        });\r\n    }\r\n\r\n    validateResult(results) {\r\n        const uniqueSuitesIterationIds = [];\r\n\r\n        results.map((result) => {\r\n            result.suites.map((suite) => {\r\n                if (uniqueSuitesIterationIds.includes(suite.iterationNum)) {\r\n                    console.warn('suite.iterationNum', suite.iterationNum, ' not unique');\r\n                } else {\r\n                    uniqueSuitesIterationIds.push(suite.iterationNum);\r\n                }\r\n            });\r\n        });\r\n    }\r\n}"]}
472
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reporter/ReportAggregator.js"],"names":["Reporters","json","JsonReporter","junit","JUnitReporter","html","HtmlReporter","excel","ExcelReporter","pdf","PdfReporter","xml","XmlReporter","DEFAULT_TEST_NAME","DEFAULT_REPORTERS","ReportAggregator","EventEmitter","constructor","options","results","runnerEndPromises","instantiateReporters","getExitCode","exitCode","Array","isArray","length","testFailded","find","item","status","reporters","generalReportingOpts","reporting","reporter","Object","prototype","hasOwnProperty","call","reporterName","name","reporterOpts","push","getResults","generateReports","groupedResults","groupResults","reportPath","generate","console","log","waitForResult","rid","waitForResults","Promise","all","onRunnerStart","opts","caps","Error","testResult","TestResult","startTime","oxutil","getTimeStamp","capabilities","environment","envVars","emit","onRunnerEnd","finalResult","fatalError","x","endTime","duration","_determineTestStatusBySuites","Status","FAILED","failure","errorHelper","getFailureFromError","_getFirstFailure","type","location","toUpperCase","result","process","nextTick","resolve","hasFailedSuites","suites","some","hasWarningSuites","WARNING","allSuitesSkipped","every","SKIPPED","PASSED","onIterationStart","iteration","start","msg","onLogEntry","onIterationEnd","iterationNum","onSuiteStart","suiteId","suite","onSuiteEnd","suiteResult","onCaseStart","caseId","caseDef","case","onCaseEnd","caseResult","onStepStart","step","rootPath","framework","fullPath","path","onStepEnd","stepResult","toFixed","time","level","src","cases","steps","ungroupedResults","_groupResult","resultKey","suiteKey","groupedResult","Math","min","max","currentSuiteResult","groupKey","groupedSuiteResult","_suitesHash","c","groupedResultsList","keys","map","suiteGroupKey","firstFailedSuite","s","firstSuiteWithWarning","recalculateResultForStatus","validateResult","failed","uniqueSuitesIterationIds","includes","warn"],"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 * Report aggregator\r\n */\r\nimport { EventEmitter } from 'events';\r\nimport path from 'path';\r\nimport TestResult from '../model/test-result';\r\nimport oxutil from '../lib/util';\r\nimport { defer } from 'when';\r\n\r\n// import all built-in reporters\r\nimport JsonReporter from '../ox_reporters/reporter-json';\r\nimport JUnitReporter from '../ox_reporters/reporter-junit';\r\nimport HtmlReporter from '../ox_reporters/reporter-html';\r\nimport ExcelReporter from '../ox_reporters/reporter-excel';\r\nimport PdfReporter from '../ox_reporters/reporter-pdf';\r\nimport XmlReporter from '../ox_reporters/reporter-xml';\r\nimport errorHelper from '../errors/helper';\r\nimport Status from '../model/status';\r\n\r\nconst Reporters = {\r\n    json: JsonReporter,\r\n    junit: JUnitReporter,\r\n    html: HtmlReporter,\r\n    excel: ExcelReporter,\r\n    pdf: PdfReporter,\r\n    xml: XmlReporter\r\n};\r\n\r\nconst DEFAULT_TEST_NAME = 'Oxygen Test';\r\nconst DEFAULT_REPORTERS = [];\r\n\r\nexport default class ReportAggregator extends EventEmitter {\r\n    constructor(options) {\r\n        super();\r\n        // results hash table based on runner id key\r\n        this.results = [];\r\n        // a hash list of runnerEnd event promises, keyed by runner id\r\n        this.runnerEndPromises = {};\r\n        this.options = options;\r\n        this.instantiateReporters();\r\n    }\r\n\r\n    getExitCode() {\r\n        let exitCode = 0;\r\n\r\n        if (\r\n            this.results &&\r\n            Array.isArray(this.results) &&\r\n            this.results.length > 0\r\n        ) {\r\n            const testFailded = this.results.find((item) => item.status === 'failed');\r\n\r\n            if (testFailded) {\r\n                exitCode = -1;\r\n            }\r\n        } else {\r\n            // something broken ?\r\n            exitCode = -1;\r\n        }\r\n\r\n        return exitCode;\r\n    }\r\n\r\n    instantiateReporters() {\r\n        this.reporters = [];\r\n        const generalReportingOpts = this.options.reporting || {};\r\n        for (let reporter of generalReportingOpts.reporters || DEFAULT_REPORTERS) {\r\n            if (typeof reporter !== 'string' && !Object.prototype.hasOwnProperty.call(reporter, 'name')) {\r\n                // ignore reporters that do not have 'name' property as it's essential to load the corresponding Reporter class\r\n                continue;\r\n            }\r\n\r\n            const reporterName = typeof reporter === 'string' ? reporter : reporter.name;\r\n            const reporterOpts = typeof reporter === 'object' ? reporter : generalReportingOpts;\r\n\r\n            if (Object.prototype.hasOwnProperty.call(Reporters, reporterName)) {\r\n                this.reporters.push(new Reporters[reporterName](this.options, reporterOpts));\r\n            }\r\n        }\r\n    }\r\n\r\n    getResults() {\r\n        return this.results;\r\n    }\r\n\r\n    generateReports() {\r\n        if (!Array.isArray(this.reporters) || this.reporters.length == 0) {\r\n            return false;\r\n        }\r\n        const groupedResults = this.groupResults();\r\n        for (let reporter of this.reporters) {\r\n            const reportPath = reporter.generate(groupedResults);\r\n            console.log(`Your report is ready: ${reportPath}`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    async waitForResult(rid) {\r\n        if (!rid || !this.runnerEndPromises[rid]) {\r\n            return null;\r\n        }\r\n        return this.runnerEndPromises[rid];\r\n    }\r\n\r\n    async waitForResults() {\r\n        if (this.runnerEndPromises && this.runnerEndPromises.length) {\r\n            return Promise.all(this.runnerEndPromises);\r\n        }\r\n    }\r\n\r\n    onRunnerStart(rid, opts, caps) {\r\n        if (!rid) {\r\n            throw new Error('\"rid\" cannot be empty.');\r\n        }\r\n        const testResult = new TestResult();\r\n        testResult.rid = rid;\r\n        testResult.name = opts.name || DEFAULT_TEST_NAME;\r\n        testResult.startTime = oxutil.getTimeStamp();\r\n        testResult.capabilities = caps;\r\n        testResult.environment = opts.envVars || {};\r\n        testResult.options = opts;\r\n        this.results.push(testResult);\r\n        // create a new promise for later to be resolved on runner:end event\r\n        this.runnerEndPromises[rid] = defer();\r\n        console.log(`Test ${rid} has started...`);\r\n        this.emit('runner:start', {\r\n            rid,\r\n            opts,\r\n            caps\r\n        });\r\n    }\r\n\r\n    onRunnerEnd(rid, finalResult, fatalError) {\r\n        const testResult = this.results.find(x => x.rid === rid);\r\n        if (testResult) {\r\n            testResult.endTime = oxutil.getTimeStamp();\r\n            testResult.duration = testResult.endTime - testResult.startTime;\r\n            // determine test status based on suites statuses\r\n            testResult.status = this._determineTestStatusBySuites(testResult, fatalError);\r\n            // testResult.status = fatalError ? Status.FAILED : (testResult.suites.some(x => x.status === Status.FAILED)) ? Status.FAILED : Status.PASSED;\r\n            if (testResult.status === Status.FAILED) {\r\n                if (fatalError) {\r\n                    // assume that if fatalError is not inherited from Error class then we already got Oxygen Failure object\r\n                    testResult.failure = fatalError instanceof Error ? errorHelper.getFailureFromError(fatalError) : fatalError;\r\n                }\r\n                else {\r\n                    testResult.failure = this._getFirstFailure(testResult);\r\n                }\r\n            }\r\n            if (finalResult && finalResult.capabilities) {\r\n                testResult.capabilities = finalResult.capabilities;\r\n            }\r\n            if (testResult.failure) {\r\n                if (testResult.failure.type && testResult.failure.location) {\r\n                    console.log(`Error: ${testResult.failure.type} at ${testResult.failure.location}.`);\r\n                } else if (testResult.failure.type) {\r\n                    console.log(`Error: ${testResult.failure.type}`);\r\n                } else if (typeof testResult.failure === 'string') {\r\n                    console.log(`Error: ${testResult.failure}`);\r\n                }\r\n            }\r\n            console.log(`Test ${rid} has finished with status: ${testResult.status.toUpperCase()}.`);\r\n        }\r\n        this.emit('runner:end', {\r\n            rid,\r\n            result: testResult,\r\n        });\r\n        if (this.runnerEndPromises[rid]) {\r\n            // calling nextTick() will help us to insure that we resolve the promise after emit('runner:end') has completed\r\n            process.nextTick(() => {\r\n                this.runnerEndPromises[rid].resolve(testResult);\r\n            });\r\n        }\r\n    }\r\n\r\n    _determineTestStatusBySuites(testResult, fatalError) {\r\n        if (fatalError) {\r\n            return Status.FAILED;\r\n        }\r\n        const hasFailedSuites = testResult.suites.some(x => x.status === Status.FAILED);\r\n        if (hasFailedSuites) {\r\n            return Status.FAILED;\r\n        }\r\n        const hasWarningSuites = testResult.suites.some(x => x.status === Status.WARNING);\r\n        if (hasWarningSuites) {\r\n            return Status.WARNING;\r\n        }\r\n        const allSuitesSkipped = testResult.suites.every(x => x.status === Status.SKIPPED);\r\n        if (allSuitesSkipped) {\r\n            return Status.SKIPPED;\r\n        }\r\n        return Status.PASSED;\r\n    }\r\n\r\n    onIterationStart(rid, iteration, start) {\r\n        if (iteration) {\r\n            const msg = `${start} Iteration #${iteration} started...`;\r\n            console.log(msg);\r\n            this.onLogEntry(null, 'INFO', msg, 'user');\r\n        }\r\n    }\r\n\r\n    onIterationEnd(rid, result, start) {\r\n        if (result && result.iterationNum && result.status && result.status.toUpperCase) {\r\n            const msg = `${start} Iteration #${result.iterationNum} ended with status: ${result.status.toUpperCase()}.`;\r\n            console.log(msg);\r\n            this.onLogEntry(null, 'INFO', msg, 'user');\r\n        }\r\n    }\r\n\r\n    onSuiteStart(rid, suiteId, suite) {\r\n        console.log(`Suite \"${suite.name}\" has started...`);\r\n        this.emit('suite:start', {\r\n            rid,\r\n            suiteId: suiteId,\r\n            suite: suite,\r\n        });\r\n    }\r\n\r\n    onSuiteEnd(rid, suiteId, suiteResult) {\r\n        const testResult = this.results.find(x => x.rid === rid);\r\n        if (!testResult) {\r\n            return;\r\n        }\r\n        testResult.suites.push(suiteResult);\r\n        console.log(`Suite \"${suiteResult.name}\" has ended with status: ${suiteResult.status.toUpperCase()}.`);\r\n        this.emit('suite:end', {\r\n            rid,\r\n            suiteId,\r\n            result: suiteResult,\r\n        });\r\n    }\r\n\r\n    onCaseStart(rid, suiteId, caseId, caseDef) {\r\n        console.log(`- Case \"${caseDef.name}\" has started...`);\r\n        this.emit('case:start', {\r\n            rid,\r\n            suiteId,\r\n            caseId,\r\n            case: caseDef,\r\n        });\r\n    }\r\n\r\n    onCaseEnd(rid, suiteId, caseId, caseResult) {\r\n        console.log(`- Case \"${caseResult.name}\" has ended with status: ${caseResult.status.toUpperCase()}.`);\r\n        this.emit('case:end', {\r\n            rid,\r\n            suiteId,\r\n            caseId,\r\n            result: caseResult,\r\n        });\r\n    }\r\n\r\n    onStepStart(rid, step) {\r\n        console.log(`  - Step \"${step.name}\" has started...`);\r\n\r\n        if (this.options && this.options.rootPath && this.options.framework && this.options.framework === 'cucumber') {\r\n            const fullPath = path.resolve(this.options.rootPath, step.location);\r\n            step.location = fullPath+':1';\r\n        }\r\n\r\n        this.emit('step:start', {\r\n            rid,\r\n            step: step,\r\n        });\r\n    }\r\n\r\n    onStepEnd(rid, stepResult) {\r\n        const status = stepResult.status.toUpperCase();\r\n        const duration = stepResult.duration ? (stepResult.duration / 1000).toFixed(2) : 0;\r\n        console.log(`  - Step \"${stepResult.name}\" has ended in ${duration}s with status: ${status}.`);\r\n        this.emit('step:end', {\r\n            rid,\r\n            step: stepResult,\r\n        });\r\n    }\r\n\r\n    onLogEntry(time, level, msg, src = null) {\r\n        this.emit('log', {\r\n            level, msg, time, src\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Returns the first failure object in one of test result's entities. \r\n     * @param {TestResult} testResult \r\n     */\r\n    _getFirstFailure(testResult) {\r\n        if (testResult.status === Status.FAILED) {\r\n            if (testResult.failure) {\r\n                return testResult.failure;\r\n            }\r\n            for (let suiteResult of testResult.suites) {\r\n                if (suiteResult.status !== Status.FAILED) {\r\n                    continue;\r\n                }\r\n                if (suiteResult.failure) {\r\n                    return suiteResult.failure;\r\n                }\r\n                for (let caseResult of suiteResult.cases) {\r\n                    if (suiteResult.status !== Status.FAILED) {\r\n                        continue;\r\n                    }\r\n                    if (caseResult.failure) {\r\n                        return caseResult.failure;\r\n                    }\r\n                    for (let stepResult of caseResult.steps) {\r\n                        if (stepResult.status !== Status.FAILED) {\r\n                            continue;\r\n                        }\r\n                        return stepResult.failure || null;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return null;\r\n    }\r\n\r\n    groupResults() {\r\n        const groupedResults = {};\r\n        const ungroupedResults = [];\r\n        if (!Array.isArray(this.results) || this.results.length == 0) {\r\n            return false;\r\n        }\r\n        for (let result of this.results) {\r\n            if (!result.options._groupResult || !result.options._groupResult.resultKey) {\r\n                ungroupedResults.push(result);\r\n                continue;\r\n            }\r\n            const resultKey = result.options._groupResult.resultKey;\r\n            const suiteKey = result.options._groupResult.suiteKey;\r\n            let groupedResult = groupedResults[resultKey];\r\n            if (!groupedResult) {\r\n                groupedResult = groupedResults[resultKey] = {\r\n                    ...result,\r\n                    suites: [],\r\n                };\r\n                if (suiteKey) {\r\n                    groupedResult['_suitesHash'] = {};\r\n                }\r\n            }\r\n            else {\r\n                groupedResult.startTime = Math.min(groupedResult.startTime, result.startTime);\r\n                groupedResult.endTime = Math.max(groupedResult.endTime, result.endTime);\r\n                groupedResult.duration = groupedResult.endTime - groupedResult.startTime;\r\n            }\r\n            // if grouping is by result only, then just append current result's suites to the group's suites\r\n            if (!suiteKey) {\r\n                groupedResult.suites = [\r\n                    ...groupedResult.suites,\r\n                    ...result.suites\r\n                ];\r\n            }\r\n            else {\r\n                for (const currentSuiteResult of result.suites) {\r\n                    const groupKey = `${suiteKey}-${currentSuiteResult.iterationNum}`;\r\n                    const groupedSuiteResult = groupedResult._suitesHash[groupKey];\r\n                    if (!groupedSuiteResult) {\r\n                        groupedResult._suitesHash[groupKey] = { ...currentSuiteResult };\r\n                    }\r\n                    else {\r\n                        groupedSuiteResult.startTime = Math.min(groupedSuiteResult.startTime, currentSuiteResult.startTime);\r\n                        groupedSuiteResult.endTime = Math.max(groupedSuiteResult.endTime, currentSuiteResult.endTime);\r\n                        groupedSuiteResult.duration = groupedSuiteResult.endTime - groupedSuiteResult.startTime;\r\n                        groupedSuiteResult.cases = [\r\n                            ...groupedSuiteResult.cases,\r\n                            ...currentSuiteResult.cases\r\n                        ];\r\n                        if (currentSuiteResult.cases.some(c => c.status === Status.FAILED)) {\r\n                            groupedSuiteResult.status = Status.FAILED;\r\n                        }\r\n                        else if (currentSuiteResult.cases.some(c => c.status === Status.WARNING)) {\r\n                            groupedSuiteResult.status = Status.WARNING;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        // convert grouped results hash to an array\r\n        const groupedResultsList = Object.keys(groupedResults).map(\r\n            groupKey => {\r\n                const groupedResult = groupedResults[groupKey];\r\n                if (!groupedResult._suitesHash) {\r\n                    return groupedResult;\r\n                }\r\n                groupedResult.suites = [\r\n                    ...groupedResult.suites,\r\n                    ...Object.keys(groupedResult._suitesHash).map(suiteGroupKey => groupedResult._suitesHash[suiteGroupKey])\r\n                ];\r\n                const firstFailedSuite = groupedResult.suites.find(s => s.status === Status.FAILED);\r\n                if (firstFailedSuite) {\r\n                    groupedResult.status = Status.FAILED;\r\n                    groupedResult.failure = firstFailedSuite.failure || groupedResult.failure;\r\n                }\r\n                else {\r\n                    const firstSuiteWithWarning = groupedResult.suites.find(s => s.status === Status.WARNING);\r\n                    if (firstSuiteWithWarning) {\r\n                        groupedResult.status = Status.WARNING;\r\n                        groupedResult.failure = firstSuiteWithWarning.failure || groupedResult.failure;\r\n                    }\r\n                }\r\n                delete groupedResult['_suitesHash'];\r\n                return groupedResult;\r\n            }\r\n        );\r\n        let results = [...groupedResultsList, ...ungroupedResults];\r\n        // change results status to faided if failed suites are finded\r\n        results = this.recalculateResultForStatus(results);\r\n\r\n        this.validateResult(results);\r\n        return results;\r\n    }\r\n\r\n    recalculateResultForStatus(results) {\r\n        return results.map((result) => {\r\n            if (\r\n                result &&\r\n                result.suites &&\r\n                Array.isArray(result.suites) &&\r\n                result.suites.length > 0\r\n            ) {\r\n                const failed = result.suites.find((suite) => suite.status === Status.FAILED);\r\n                if (failed) {\r\n                    result.status = Status.FAILED;\r\n                }\r\n                else if (result.suites.find((suite) => suite.status === Status.WARNING)) {\r\n                    result.status = Status.WARNING;\r\n                }\r\n            }\r\n\r\n            return result;\r\n        });\r\n    }\r\n\r\n    validateResult(results) {\r\n        const uniqueSuitesIterationIds = [];\r\n\r\n        results.map((result) => {\r\n            result.suites.map((suite) => {\r\n                if (uniqueSuitesIterationIds.includes(suite.iterationNum)) {\r\n                    console.warn('suite.iterationNum', suite.iterationNum, ' not unique');\r\n                } else {\r\n                    uniqueSuitesIterationIds.push(suite.iterationNum);\r\n                }\r\n            });\r\n        });\r\n    }\r\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "oxygen-cli",
3
- "version": "1.29.1",
3
+ "version": "1.30.1",
4
4
  "description": "Automation framework for testing modern applications",
5
5
  "main": "./build/index.js",
6
6
  "bin": {