oxygen-cli 1.30.0 → 1.30.2

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.2 (2023-08-31)
4
+
5
+ #### :beetle: Bug Fix
6
+ * Fix parallel case execution inside suites.
7
+
8
+ ## v1.30.1 (2023-08-29)
9
+
10
+ #### :beetle: Bug Fix
11
+ * Fix step's Warning status not being properly processed.
12
+ * Improve the way test result status for suites with Skipped and Warning statuses is determined.
13
+
3
14
  ## v1.30.0 (2023-08-15)
4
15
 
5
16
  #### :tada: New Feature
@@ -38,11 +38,11 @@ class ParallelLauncher {
38
38
  }
39
39
 
40
40
  if (!this._config.parallel.mode) {
41
- this._config.parallel.mode = 'suite';
41
+ this._config.parallel.mode = 'case';
42
42
  }
43
43
 
44
44
  const workersCount = !isNaN(this._config.parallel.workers) ? this._config.parallel.workers : 1;
45
- const mode = this._config.parallel.mode === 'iteration' ? 'iteration' : this._config.parallel.mode === 'case' ? 'case' : 'suite';
45
+ const mode = this._config.parallel.mode === 'iteration' ? 'iteration' : this._config.parallel.mode === 'suite' ? 'suite' : 'case';
46
46
  const suites = this._config.suites;
47
47
  const resultName = this._config.name || '';
48
48
 
@@ -129,7 +129,6 @@ class ParallelLauncher {
129
129
 
130
130
  suiteIndex++;
131
131
  });
132
- console.log('Collections length', collection.length);
133
132
  const start = new Date();
134
133
  await (0, _parallelLimit.default)(collection, workersCount);
135
134
  let total = 0;
@@ -252,4 +251,4 @@ class ParamManagerMock {
252
251
  }
253
252
 
254
253
  }
255
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/parallel-launcher.js"],"names":["Duration","require","hash","ParallelLauncher","constructor","config","reporter","_config","_queue","runners","createdRunnersStat","run","capsSet","collection","parallel","Error","mode","workersCount","isNaN","workers","suites","resultName","name","Array","isArray","testCaps","resultHash","resultKey","suiteIndex","forEach","suiteDef","suiteKey","key","id","i","iterationCount","mockedParamManager","undefined","paramManager","ParamManagerMock","getValues","readNext","workerId","suiteCopy","testConfig","_groupResult","workerConfig","startupDelay","push","callback","_launchWorkerFunc","cases","caseIndex","caseDef","caseKey","console","log","length","start","Date","total","runnersIds","Object","keys","map","item","cazes","end","duration","toString","cb","error","_launchTest","then","result","catch","_instantiateRunner","framework","prototype","hasOwnProperty","call","Runners","oxygen","_sleep","runner","_id","init","dispose","status","e","kill","errMsg","err","type","message","Promise","resolve","setTimeout","values","getMode","readPrev","rows"],"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// import _ from 'lodash';\r\nimport * as Runners from '../runners';\r\nimport parallelLimit from 'async/parallelLimit';\r\nconst Duration = require('duration');\r\nconst hash = require('object-hash');\r\n\r\nexport default class ParallelLauncher {\r\n    constructor(config, reporter) {\r\n        this._config = config;\r\n        this.reporter = reporter;\r\n        this._queue = null;\r\n        this.runners = [];\r\n        this.createdRunnersStat = [];\r\n    }\r\n\r\n    async run(capsSet) {\r\n        const collection = [];\r\n\r\n        if (!this._config.parallel) {\r\n            throw new Error('Cannot start the parallel testing - \"parallel\" settings are missing.');\r\n        }\r\n\r\n        if (!this._config.parallel.mode) {\r\n            this._config.parallel.mode = 'suite';\r\n        }\r\n\r\n        const workersCount = !isNaN(this._config.parallel.workers) ? this._config.parallel.workers : 1;\r\n        const mode = this._config.parallel.mode === 'iteration'\r\n            ? 'iteration' : this._config.parallel.mode === 'case'\r\n                ? 'case' : 'suite';\r\n        // flatten all suites and create one unified array of all the test cases\r\n        const suites = this._config.suites;\r\n        const resultName = this._config.name || '';\r\n        if (!suites || !Array.isArray(suites)) {\r\n            throw new Error('Cannot start the parallel testing - no suites are defined.');\r\n        }\r\n        // if no capabilities are specified, run single instance with default arguments\r\n        // alternatively, pick the first capabilities set (load test is limited to a single browser type)\r\n        const testCaps = capsSet ? (Array.isArray(capsSet) ? capsSet[0] : capsSet) : null;\r\n        const resultHash = testCaps ? hash(testCaps) : '';\r\n        const resultKey = `${resultName}-${resultHash}`;\r\n        // if 'workers' set to max and parameter file is defined, \r\n        // then run as many parallel tests as rows in the file\r\n        let suiteIndex = 0;\r\n        suites.forEach(suiteDef => {\r\n            const suiteKey = suiteDef.key || suiteDef.id || suiteDef.name;\r\n            if (mode === 'iteration') {\r\n                for (let i = 1; i<= suiteDef.iterationCount; i++) {\r\n                    let mockedParamManager = undefined;\r\n                    if (suiteDef.paramManager) {\r\n                        mockedParamManager = new ParamManagerMock(suiteDef.paramManager.getValues());\r\n                        suiteDef.paramManager.readNext();\r\n                    }\r\n                    const workerId = `${suiteKey}-${suiteIndex}/${i}`;\r\n                    const suiteCopy = { ...suiteDef, iterationCount: 1, paramManager: mockedParamManager };\r\n                    const testConfig = {\r\n                        ...this._config, suites: [ suiteCopy ],\r\n                        _groupResult: {\r\n                            resultKey,\r\n                        }\r\n                    };\r\n                    const workerConfig = { workerId, testConfig, testCaps, startupDelay: 200 };\r\n                    collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n                }\r\n            }\r\n            // check if any of cases have param file attached\r\n            else if (mode === 'case' && Array.isArray(suiteDef.cases)) {\r\n                let caseIndex = 0;\r\n                suiteDef.cases.forEach(caseDef => {\r\n                    const caseKey = caseDef.key || caseDef.id || caseDef.name;\r\n                    const workerId = `${caseKey}-${suiteIndex}/${caseIndex}`;\r\n                    const suiteCopy = { ...suiteDef, cases: [ caseDef ]};\r\n                    const testConfig = {\r\n                        ...this._config,\r\n                        suites: [ suiteCopy ],\r\n                        _groupResult: {\r\n                            resultKey,\r\n                            suiteKey,\r\n                        }\r\n                    };\r\n                    const workerConfig = { workerId, testConfig, testCaps, startupDelay: 0 };\r\n                    collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n                    caseIndex++;\r\n                });\r\n            }\r\n            else {\r\n                const suiteKey = suiteDef.key || suiteDef.id || suiteDef.name;\r\n                const workerId = `${suiteKey}-${suiteIndex}`;\r\n                const testConfig = {\r\n                    ...this._config,\r\n                    suites: [ suiteDef ],\r\n                    _groupResult: {\r\n                        resultKey,\r\n                    }\r\n                };\r\n                const workerConfig = { workerId, testConfig, testCaps, startupDelay: 0 };\r\n                collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n            }\r\n            suiteIndex++;\r\n        });\r\n        //this.reporter.onBeforeStart(collection.length);\r\n\r\n        console.log('Collections length', collection.length);\r\n\r\n        const start = new Date();\r\n        await parallelLimit(collection, workersCount);\r\n\r\n        let total = 0;\r\n        console.log('Created Runners Stat', this.createdRunnersStat);\r\n        const runnersIds = Object.keys(this.createdRunnersStat);\r\n        console.log('Created Runners count', runnersIds.length);\r\n\r\n        runnersIds.map((item) => {\r\n            const cazes = this.createdRunnersStat[item].length;\r\n            total += cazes;\r\n            console.log('Runner', item, ' run ', cazes, ' cases');\r\n        });\r\n\r\n        console.log('Parallel count', workersCount);\r\n        console.log('Total: ', total);\r\n        const end = new Date();\r\n        const duration = new Duration(start, end);\r\n        console.log('Duration: ', duration.toString(1));\r\n        //this.reporter.onAfterEnd();\r\n    }\r\n\r\n    /*********************************\r\n     * Private methods\r\n     *********************************/\r\n\r\n    _launchWorkerFunc(workerConfig, callback) {\r\n        const cb = (error) => {\r\n            if (error) {\r\n                callback(error, null);\r\n            }\r\n        };\r\n        this._launchTest(workerConfig, cb).then((result) => {\r\n            callback(null, result);\r\n        }).catch(error => {\r\n            callback(error, null);\r\n        });\r\n    }\r\n\r\n    _instantiateRunner() {\r\n        if (this._config.framework && typeof this._config.framework === 'string') {\r\n            if (Object.prototype.hasOwnProperty.call(Runners, this._config.framework)) {\r\n                return new Runners[this._config.framework]();\r\n            }\r\n            return null;\r\n        }\r\n        return new Runners.oxygen();\r\n    }\r\n\r\n    async _launchTest({ workerId, testConfig, testCaps, startupDelay }, callback) {\r\n        if (!callback) {\r\n            return;\r\n        }\r\n        await this._sleep(startupDelay);\r\n\r\n        let runner = this._instantiateRunner();\r\n        this.createdRunnersStat[runner._id] = [workerId];\r\n\r\n        if (!runner) {\r\n            const framework = this._config.framework;\r\n            callback(new Error(`Cannot find runner for the specified framework: ${framework}.`));\r\n            return;\r\n        }\r\n        try {\r\n            // generate firefox \"profile\" value if profile options are specified\r\n            // await oxutil.generateFirefoxOptionsProfile(testCaps);\r\n\r\n            // initialize oxygen\r\n            await runner.init(testConfig, testCaps, this.reporter);\r\n\r\n            // run Oxygen test \r\n            const result = await runner.run();\r\n            await runner.dispose(result.status || null);\r\n            callback();\r\n        }\r\n        catch (e) {\r\n            console.error('Failed to launch the test:', e);\r\n            // stop processing the queue\r\n            if (this._queue) {\r\n                this._queue.kill();\r\n            }\r\n            // if this is custom error message\r\n            if (e.error) {\r\n                var errMsg = '';\r\n                var err = e.error;\r\n                if (err.type)\r\n                    errMsg += err.type + ' - ';\r\n                if (err.message)\r\n                    errMsg += err.message;\r\n                else\r\n                    errMsg = err.toString();\r\n                callback(new Error(errMsg));\r\n            }\r\n            else {\r\n                callback(e);    // call back with the original exception\r\n            }\r\n        }\r\n\r\n        this.runners.push(runner);\r\n    }\r\n\r\n    _sleep(duration) {\r\n        return new Promise((resolve) => setTimeout(resolve, duration));\r\n    }\r\n}\r\n\r\nclass ParamManagerMock {\r\n    constructor(values) {\r\n        this.values = values;\r\n    }\r\n\r\n    init() {\r\n\r\n    }\r\n\r\n    getMode() {\r\n\r\n    }\r\n\r\n    readNext() {\r\n\r\n    }\r\n\r\n    readPrev() {\r\n\r\n    }\r\n\r\n    getValues() {\r\n        return this.values;\r\n    }\r\n\r\n    get rows() {\r\n        return 1;\r\n    }\r\n}\r\n"]}
254
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/parallel-launcher.js"],"names":["Duration","require","hash","ParallelLauncher","constructor","config","reporter","_config","_queue","runners","createdRunnersStat","run","capsSet","collection","parallel","Error","mode","workersCount","isNaN","workers","suites","resultName","name","Array","isArray","testCaps","resultHash","resultKey","suiteIndex","forEach","suiteDef","suiteKey","key","id","i","iterationCount","mockedParamManager","undefined","paramManager","ParamManagerMock","getValues","readNext","workerId","suiteCopy","testConfig","_groupResult","workerConfig","startupDelay","push","callback","_launchWorkerFunc","cases","caseIndex","caseDef","caseKey","start","Date","total","console","log","runnersIds","Object","keys","length","map","item","cazes","end","duration","toString","cb","error","_launchTest","then","result","catch","_instantiateRunner","framework","prototype","hasOwnProperty","call","Runners","oxygen","_sleep","runner","_id","init","dispose","status","e","kill","errMsg","err","type","message","Promise","resolve","setTimeout","values","getMode","readPrev","rows"],"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// import _ from 'lodash';\r\nimport * as Runners from '../runners';\r\nimport parallelLimit from 'async/parallelLimit';\r\nconst Duration = require('duration');\r\nconst hash = require('object-hash');\r\n\r\nexport default class ParallelLauncher {\r\n    constructor(config, reporter) {\r\n        this._config = config;\r\n        this.reporter = reporter;\r\n        this._queue = null;\r\n        this.runners = [];\r\n        this.createdRunnersStat = [];\r\n    }\r\n\r\n    async run(capsSet) {\r\n        const collection = [];\r\n\r\n        if (!this._config.parallel) {\r\n            throw new Error('Cannot start the parallel testing - \"parallel\" settings are missing.');\r\n        }\r\n\r\n        if (!this._config.parallel.mode) {\r\n            this._config.parallel.mode = 'case';\r\n        }\r\n\r\n        const workersCount = !isNaN(this._config.parallel.workers) ? this._config.parallel.workers : 1;\r\n        const mode = this._config.parallel.mode === 'iteration'\r\n            ? 'iteration' : this._config.parallel.mode === 'suite'\r\n                ? 'suite' : 'case';\r\n        // flatten all suites and create one unified array of all the test cases\r\n        const suites = this._config.suites;\r\n        const resultName = this._config.name || '';\r\n        if (!suites || !Array.isArray(suites)) {\r\n            throw new Error('Cannot start the parallel testing - no suites are defined.');\r\n        }\r\n        // if no capabilities are specified, run single instance with default arguments\r\n        // alternatively, pick the first capabilities set (load test is limited to a single browser type)\r\n        const testCaps = capsSet ? (Array.isArray(capsSet) ? capsSet[0] : capsSet) : null;\r\n        const resultHash = testCaps ? hash(testCaps) : '';\r\n        const resultKey = `${resultName}-${resultHash}`;\r\n        // if 'workers' set to max and parameter file is defined, \r\n        // then run as many parallel tests as rows in the file\r\n        let suiteIndex = 0;\r\n\r\n        suites.forEach(suiteDef => {\r\n            const suiteKey = suiteDef.key || suiteDef.id || suiteDef.name;\r\n            if (mode === 'iteration') {\r\n                for (let i = 1; i<= suiteDef.iterationCount; i++) {\r\n                    let mockedParamManager = undefined;\r\n                    if (suiteDef.paramManager) {\r\n                        mockedParamManager = new ParamManagerMock(suiteDef.paramManager.getValues());\r\n                        suiteDef.paramManager.readNext();\r\n                    }\r\n                    const workerId = `${suiteKey}-${suiteIndex}/${i}`;\r\n                    const suiteCopy = { ...suiteDef, iterationCount: 1, paramManager: mockedParamManager };\r\n                    const testConfig = {\r\n                        ...this._config, suites: [ suiteCopy ],\r\n                        _groupResult: {\r\n                            resultKey,\r\n                        }\r\n                    };\r\n                    const workerConfig = { workerId, testConfig, testCaps, startupDelay: 200 };\r\n                    collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n                }\r\n            }\r\n            // check if any of cases have param file attached\r\n            else if (mode === 'case' && Array.isArray(suiteDef.cases)) {\r\n                let caseIndex = 0;\r\n                suiteDef.cases.forEach(caseDef => {\r\n                    const caseKey = caseDef.key || caseDef.id || caseDef.name;\r\n                    const workerId = `${caseKey}-${suiteIndex}/${caseIndex}`;\r\n                    const suiteCopy = { ...suiteDef, cases: [ caseDef ]};\r\n                    const testConfig = {\r\n                        ...this._config,\r\n                        suites: [ suiteCopy ],\r\n                        _groupResult: {\r\n                            resultKey,\r\n                            suiteKey,\r\n                        }\r\n                    };\r\n                    const workerConfig = { workerId, testConfig, testCaps, startupDelay: 0 };\r\n                    collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n                    caseIndex++;\r\n                });\r\n            }\r\n            else {\r\n                const suiteKey = suiteDef.key || suiteDef.id || suiteDef.name;\r\n                const workerId = `${suiteKey}-${suiteIndex}`;\r\n                const testConfig = {\r\n                    ...this._config,\r\n                    suites: [ suiteDef ],\r\n                    _groupResult: {\r\n                        resultKey,\r\n                    }\r\n                };\r\n                const workerConfig = { workerId, testConfig, testCaps, startupDelay: 0 };\r\n                collection.push((callback) => this._launchWorkerFunc(workerConfig, callback));\r\n            }\r\n            suiteIndex++;\r\n        });\r\n        const start = new Date();\r\n        await parallelLimit(collection, workersCount);\r\n\r\n        let total = 0;\r\n        console.log('Created Runners Stat', this.createdRunnersStat);\r\n        const runnersIds = Object.keys(this.createdRunnersStat);\r\n        console.log('Created Runners count', runnersIds.length);\r\n\r\n        runnersIds.map((item) => {\r\n            const cazes = this.createdRunnersStat[item].length;\r\n            total += cazes;\r\n            console.log('Runner', item, ' run ', cazes, ' cases');\r\n        });\r\n\r\n        console.log('Parallel count', workersCount);\r\n        console.log('Total: ', total);\r\n        const end = new Date();\r\n        const duration = new Duration(start, end);\r\n        console.log('Duration: ', duration.toString(1));\r\n        //this.reporter.onAfterEnd();\r\n    }\r\n\r\n    /*********************************\r\n     * Private methods\r\n     *********************************/\r\n\r\n    _launchWorkerFunc(workerConfig, callback) {\r\n        const cb = (error) => {\r\n            if (error) {\r\n                callback(error, null);\r\n            }\r\n        };\r\n        this._launchTest(workerConfig, cb).then((result) => {\r\n            callback(null, result);\r\n        }).catch(error => {\r\n            callback(error, null);\r\n        });\r\n    }\r\n\r\n    _instantiateRunner() {\r\n        if (this._config.framework && typeof this._config.framework === 'string') {\r\n            if (Object.prototype.hasOwnProperty.call(Runners, this._config.framework)) {\r\n                return new Runners[this._config.framework]();\r\n            }\r\n            return null;\r\n        }\r\n        return new Runners.oxygen();\r\n    }\r\n\r\n    async _launchTest({ workerId, testConfig, testCaps, startupDelay }, callback) {\r\n        if (!callback) {\r\n            return;\r\n        }\r\n        await this._sleep(startupDelay);\r\n\r\n        let runner = this._instantiateRunner();\r\n        this.createdRunnersStat[runner._id] = [workerId];\r\n\r\n        if (!runner) {\r\n            const framework = this._config.framework;\r\n            callback(new Error(`Cannot find runner for the specified framework: ${framework}.`));\r\n            return;\r\n        }\r\n        try {\r\n            // generate firefox \"profile\" value if profile options are specified\r\n            // await oxutil.generateFirefoxOptionsProfile(testCaps);\r\n\r\n            // initialize oxygen\r\n            await runner.init(testConfig, testCaps, this.reporter);\r\n\r\n            // run Oxygen test \r\n            const result = await runner.run();\r\n            await runner.dispose(result.status || null);\r\n            callback();\r\n        }\r\n        catch (e) {\r\n            console.error('Failed to launch the test:', e);\r\n            // stop processing the queue\r\n            if (this._queue) {\r\n                this._queue.kill();\r\n            }\r\n            // if this is custom error message\r\n            if (e.error) {\r\n                var errMsg = '';\r\n                var err = e.error;\r\n                if (err.type)\r\n                    errMsg += err.type + ' - ';\r\n                if (err.message)\r\n                    errMsg += err.message;\r\n                else\r\n                    errMsg = err.toString();\r\n                callback(new Error(errMsg));\r\n            }\r\n            else {\r\n                callback(e);    // call back with the original exception\r\n            }\r\n        }\r\n\r\n        this.runners.push(runner);\r\n    }\r\n\r\n    _sleep(duration) {\r\n        return new Promise((resolve) => setTimeout(resolve, duration));\r\n    }\r\n}\r\n\r\nclass ParamManagerMock {\r\n    constructor(values) {\r\n        this.values = values;\r\n    }\r\n\r\n    init() {\r\n\r\n    }\r\n\r\n    getMode() {\r\n\r\n    }\r\n\r\n    readNext() {\r\n\r\n    }\r\n\r\n    readPrev() {\r\n\r\n    }\r\n\r\n    getValues() {\r\n        return this.values;\r\n    }\r\n\r\n    get rows() {\r\n        return 1;\r\n    }\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.30.0",
3
+ "version": "1.30.2",
4
4
  "description": "Automation framework for testing modern applications",
5
5
  "main": "./build/index.js",
6
6
  "bin": {