oxygen-cli 1.33.3 → 1.33.5

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,19 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## v1.33.5 (2024-05-29)
4
+
5
+ #### :beetle: Bug Fix
6
+ * Fix `web.waitForAngular` when running inside an iframe.
7
+
8
+ ## v1.33.4 (2024-05-10)
9
+
10
+ #### :beetle: Bug Fix
11
+ * Fix incorrect processing of parameters.
12
+ * Better handle situations when taking screenshots fails.
13
+
14
+ #### :house: Internal
15
+ * Bump webdriverio dependencies.
16
+
3
17
  ## v1.33.2 (2024-05-24)
4
18
 
5
19
  #### :house: Internal
@@ -53,8 +53,15 @@ async function waitForAngular(rootSelector, softWait = false, timeout = 60 * 100
53
53
  return testable;
54
54
  } else {
55
55
  const stable = await this.driver.execute(() => {
56
- // following way of obtaining testability is the same as using: var testability = window.getAllAngularTestabilities()[0];
57
56
  // eslint-disable-next-line no-undef
57
+ if (!window.getAllAngularRootElements && window !== window.parent) {
58
+ // if we are running inside iframe where getAllAngularRootElements is not unavailable
59
+ // we return true
60
+ return true;
61
+ } // following way of obtaining testability is the same as using: var testability = window.getAllAngularTestabilities()[0];
62
+ // eslint-disable-next-line no-undef
63
+
64
+
58
65
  const rootElement = window.getAllAngularRootElements()[0]; // eslint-disable-next-line no-undef
59
66
 
60
67
  const testability = window.getAngularTestability(rootElement); // use isStable instead of whenStable due to this issue:
@@ -62,19 +69,11 @@ async function waitForAngular(rootSelector, softWait = false, timeout = 60 * 100
62
69
 
63
70
  return testability.isStable();
64
71
  });
65
- const version = await this.driver.execute(() => {
66
- // eslint-disable-next-line no-undef
67
- const el = document.querySelector('[ng-version]');
68
-
69
- if (!el) {
70
- return null;
71
- }
72
-
73
- return el.getAttribute('ng-version');
74
- });
75
- return version && stable;
72
+ return stable;
76
73
  }
77
- } catch (err) {// if we got here then it's executeAsync timeout.
74
+ } catch (err) {
75
+ // if we got here then it's executeAsync timeout
76
+ console.log('executeAsync err', err);
78
77
  }
79
78
  }, {
80
79
  timeout: timeout,
@@ -86,4 +85,4 @@ async function waitForAngular(rootSelector, softWait = false, timeout = 60 * 100
86
85
  }
87
86
  }
88
87
  }
89
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/ox_modules/module-web/commands/waitForAngular.js"],"names":["waitForAngular","rootSelector","softWait","timeout","helpers","assertArgumentTimeout","driver","waitUntil","angular1","execute","window","angular","assertArgumentString","testable","rootElement","element","testability","getTestability","isStable","stable","getAllAngularRootElements","getAngularTestability","version","el","document","querySelector","getAttribute","err","timeoutMsg","e","OxError","errHelper","errorCode","TIMEOUT","message"],"mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEO,eAAeA,cAAf,CAA8BC,YAA9B,EAA4CC,QAAQ,GAAG,KAAvD,EAA8DC,OAAO,GAAG,KAAG,IAA3E,EAAiF;AACpF,OAAKC,OAAL,CAAaC,qBAAb,CAAmCF,OAAnC,EAA4C,SAA5C;;AAEA,MAAI;AACA,UAAM,KAAKG,MAAL,CAAYC,SAAZ,CAAsB,YAAY;AACpC,UAAI;AAEA;AACA;AACA,cAAMC,QAAQ,GAAG,MAAM,KAAKF,MAAL,CAAYG,OAAZ,CAAoB,MAAM;AAC7C;AACA,iBAAO,CAAC,CAACC,MAAM,CAACC,OAAhB;AACH,SAHsB,CAAvB;;AAKA,YAAIH,QAAJ,EAAc;AACV,eAAKJ,OAAL,CAAaQ,oBAAb,CAAkCX,YAAlC,EAAgD,cAAhD;AACA,gBAAMY,QAAQ,GAAG,MAAM,KAAKP,MAAL,CAAYG,OAAZ,CAAqBR,YAAD,IAAkB;AACzD;AACA,kBAAMa,WAAW,GAAGJ,MAAM,CAACC,OAAP,CAAeI,OAAf,CAAuBd,YAAvB,CAApB,CAFyD,CAGzD;;AACA,kBAAMe,WAAW,GAAGN,MAAM,CAACC,OAAP,CAAeM,cAAf,CAA8BH,WAA9B,CAApB;AACA,mBAAOE,WAAW,CAACE,QAAZ,EAAP;AACH,WANsB,EAMpBjB,YANoB,CAAvB;AAQA,iBAAOY,QAAP;AACH,SAXD,MAWO;AACH,gBAAMM,MAAM,GAAG,MAAM,KAAKb,MAAL,CAAYG,OAAZ,CAAoB,MAAM;AAC3C;AACA;AACA,kBAAMK,WAAW,GAAGJ,MAAM,CAACU,yBAAP,GAAmC,CAAnC,CAApB,CAH2C,CAI1C;;AACD,kBAAMJ,WAAW,GAAGN,MAAM,CAACW,qBAAP,CAA6BP,WAA7B,CAApB,CAL2C,CAM3C;AACA;;AACA,mBAAOE,WAAW,CAACE,QAAZ,EAAP;AACH,WAToB,CAArB;AAWA,gBAAMI,OAAO,GAAG,MAAM,KAAKhB,MAAL,CAAYG,OAAZ,CAAoB,MAAM;AAC5C;AACA,kBAAMc,EAAE,GAAGC,QAAQ,CAACC,aAAT,CAAuB,cAAvB,CAAX;;AACA,gBAAI,CAACF,EAAL,EAAS;AACL,qBAAO,IAAP;AACH;;AACD,mBAAOA,EAAE,CAACG,YAAH,CAAgB,YAAhB,CAAP;AACH,WAPqB,CAAtB;AASA,iBAAQJ,OAAO,IAAIH,MAAnB;AACH;AACJ,OA3CD,CA2CE,OAAOQ,GAAP,EAAY,CACV;AACH;AACJ,KA/CK,EA+CJ;AACExB,MAAAA,OAAO,EAAEA,OADX;AAEEyB,MAAAA,UAAU,EAAG,qCAAoCzB,OAAQ;AAF3D,KA/CI,CAAN;AAmDH,GApDD,CAoDE,OAAO0B,CAAP,EAAU;AACR,QAAI,CAAC3B,QAAL,EAAe;AACX,YAAM,IAAI,KAAK4B,OAAT,CAAiB,KAAKC,SAAL,CAAeC,SAAf,CAAyBC,OAA1C,EAAmDJ,CAAC,CAACK,OAArD,CAAN;AACH;AACJ;AACJ","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 * @summary Wait for Angular based app will be loaded\r\n * @function waitForAngular\r\n * @param {String=} rootSelector - Selector for root element, needed only for AngularJS (v1). \r\n *                                 In Angular (v2) first available root node will be selected automatically.\r\n * @param {Boolean=} softWait - If true then do not produce error if stability cannot be attained. Default is false.\r\n * @param {Number=} timeout - Timeout in milliseconds. Default is 60 seconds.\r\n * @example <caption>[javascript] Usage example</caption>\r\n * web.init();\r\n * web.open(\"www.yourwebsite.com\");\r\n * web.waitForAngular();\r\n */\r\n\r\nexport async function waitForAngular(rootSelector, softWait = false, timeout = 60*1000) {\r\n    this.helpers.assertArgumentTimeout(timeout, 'timeout');\r\n\r\n    try {\r\n        await this.driver.waitUntil(async () => {\r\n            try {\r\n\r\n                // in AngularJS (v1) window.angular will be defined \r\n                // in Angular (v2) window.angular will be undefined\r\n                const angular1 = await this.driver.execute(() => {\r\n                    // eslint-disable-next-line no-undef\r\n                    return !!window.angular;\r\n                });\r\n\r\n                if (angular1) {\r\n                    this.helpers.assertArgumentString(rootSelector, 'rootSelector');\r\n                    const testable = await this.driver.execute((rootSelector) => {\r\n                        // eslint-disable-next-line no-undef\r\n                        const rootElement = window.angular.element(rootSelector);\r\n                        // eslint-disable-next-line no-undef\r\n                        const testability = window.angular.getTestability(rootElement);\r\n                        return testability.isStable();\r\n                    }, rootSelector);\r\n\r\n                    return testable;\r\n                } else {\r\n                    const stable = await this.driver.execute(() => {\r\n                        // following way of obtaining testability is the same as using: var testability = window.getAllAngularTestabilities()[0];\r\n                        // eslint-disable-next-line no-undef\r\n                        const rootElement = window.getAllAngularRootElements()[0];\r\n                         // eslint-disable-next-line no-undef\r\n                        const testability = window.getAngularTestability(rootElement);\r\n                        // use isStable instead of whenStable due to this issue:\r\n                        // https://stackoverflow.com/questions/54509647/testability-whenstable-returns-testability-isstable-returns-false\r\n                        return testability.isStable();\r\n                    });\r\n\r\n                    const version = await this.driver.execute(() => {\r\n                        // eslint-disable-next-line no-undef\r\n                        const el = document.querySelector('[ng-version]');\r\n                        if (!el) {\r\n                            return null;\r\n                        }\r\n                        return el.getAttribute('ng-version');\r\n                    });\r\n\r\n                    return (version && stable);\r\n                }\r\n            } catch (err) {\r\n                // if we got here then it's executeAsync timeout.\r\n            }\r\n        },{\r\n            timeout: timeout,\r\n            timeoutMsg: `Unable to attain stability within ${timeout}ms (or this is not an Angular application)`\r\n        });\r\n    } catch (e) {\r\n        if (!softWait) {\r\n            throw new this.OxError(this.errHelper.errorCode.TIMEOUT, e.message);\r\n        }\r\n    }\r\n}"]}
88
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/ox_modules/module-web/commands/waitForAngular.js"],"names":["waitForAngular","rootSelector","softWait","timeout","helpers","assertArgumentTimeout","driver","waitUntil","angular1","execute","window","angular","assertArgumentString","testable","rootElement","element","testability","getTestability","isStable","stable","getAllAngularRootElements","parent","getAngularTestability","err","console","log","timeoutMsg","e","OxError","errHelper","errorCode","TIMEOUT","message"],"mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEO,eAAeA,cAAf,CAA8BC,YAA9B,EAA4CC,QAAQ,GAAG,KAAvD,EAA8DC,OAAO,GAAG,KAAG,IAA3E,EAAiF;AACpF,OAAKC,OAAL,CAAaC,qBAAb,CAAmCF,OAAnC,EAA4C,SAA5C;;AAEA,MAAI;AACA,UAAM,KAAKG,MAAL,CAAYC,SAAZ,CAAsB,YAAY;AACpC,UAAI;AAEA;AACA;AACA,cAAMC,QAAQ,GAAG,MAAM,KAAKF,MAAL,CAAYG,OAAZ,CAAoB,MAAM;AAC7C;AACA,iBAAO,CAAC,CAACC,MAAM,CAACC,OAAhB;AACH,SAHsB,CAAvB;;AAKA,YAAIH,QAAJ,EAAc;AACV,eAAKJ,OAAL,CAAaQ,oBAAb,CAAkCX,YAAlC,EAAgD,cAAhD;AACA,gBAAMY,QAAQ,GAAG,MAAM,KAAKP,MAAL,CAAYG,OAAZ,CAAqBR,YAAD,IAAkB;AACzD;AACA,kBAAMa,WAAW,GAAGJ,MAAM,CAACC,OAAP,CAAeI,OAAf,CAAuBd,YAAvB,CAApB,CAFyD,CAGzD;;AACA,kBAAMe,WAAW,GAAGN,MAAM,CAACC,OAAP,CAAeM,cAAf,CAA8BH,WAA9B,CAApB;AACA,mBAAOE,WAAW,CAACE,QAAZ,EAAP;AACH,WANsB,EAMpBjB,YANoB,CAAvB;AAQA,iBAAOY,QAAP;AACH,SAXD,MAWO;AACH,gBAAMM,MAAM,GAAG,MAAM,KAAKb,MAAL,CAAYG,OAAZ,CAAoB,MAAM;AAC3C;AACA,gBAAI,CAACC,MAAM,CAACU,yBAAR,IAAqCV,MAAM,KAAKA,MAAM,CAACW,MAA3D,EAAmE;AACjE;AACA;AACE,qBAAO,IAAP;AACH,aAN0C,CAQ3C;AACA;;;AACA,kBAAMP,WAAW,GAAGJ,MAAM,CAACU,yBAAP,GAAmC,CAAnC,CAApB,CAV2C,CAW1C;;AACD,kBAAMJ,WAAW,GAAGN,MAAM,CAACY,qBAAP,CAA6BR,WAA7B,CAApB,CAZ2C,CAa3C;AACA;;AACA,mBAAOE,WAAW,CAACE,QAAZ,EAAP;AACH,WAhBoB,CAArB;AAkBA,iBAAOC,MAAP;AACH;AACJ,OAzCD,CAyCE,OAAOI,GAAP,EAAY;AACV;AACAC,QAAAA,OAAO,CAACC,GAAR,CAAY,kBAAZ,EAAgCF,GAAhC;AACH;AACJ,KA9CK,EA8CJ;AACEpB,MAAAA,OAAO,EAAEA,OADX;AAEEuB,MAAAA,UAAU,EAAG,qCAAoCvB,OAAQ;AAF3D,KA9CI,CAAN;AAkDH,GAnDD,CAmDE,OAAOwB,CAAP,EAAU;AACR,QAAI,CAACzB,QAAL,EAAe;AACX,YAAM,IAAI,KAAK0B,OAAT,CAAiB,KAAKC,SAAL,CAAeC,SAAf,CAAyBC,OAA1C,EAAmDJ,CAAC,CAACK,OAArD,CAAN;AACH;AACJ;AACJ","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 * @summary Wait for Angular based app will be loaded\r\n * @function waitForAngular\r\n * @param {String=} rootSelector - Selector for root element, needed only for AngularJS (v1). \r\n *                                 In Angular (v2) first available root node will be selected automatically.\r\n * @param {Boolean=} softWait - If true then do not produce error if stability cannot be attained. Default is false.\r\n * @param {Number=} timeout - Timeout in milliseconds. Default is 60 seconds.\r\n * @example <caption>[javascript] Usage example</caption>\r\n * web.init();\r\n * web.open(\"www.yourwebsite.com\");\r\n * web.waitForAngular();\r\n */\r\n\r\nexport async function waitForAngular(rootSelector, softWait = false, timeout = 60*1000) {\r\n    this.helpers.assertArgumentTimeout(timeout, 'timeout');\r\n\r\n    try {\r\n        await this.driver.waitUntil(async () => {\r\n            try {\r\n\r\n                // in AngularJS (v1) window.angular will be defined \r\n                // in Angular (v2) window.angular will be undefined\r\n                const angular1 = await this.driver.execute(() => {\r\n                    // eslint-disable-next-line no-undef\r\n                    return !!window.angular;\r\n                });\r\n\r\n                if (angular1) {\r\n                    this.helpers.assertArgumentString(rootSelector, 'rootSelector');\r\n                    const testable = await this.driver.execute((rootSelector) => {\r\n                        // eslint-disable-next-line no-undef\r\n                        const rootElement = window.angular.element(rootSelector);\r\n                        // eslint-disable-next-line no-undef\r\n                        const testability = window.angular.getTestability(rootElement);\r\n                        return testability.isStable();\r\n                    }, rootSelector);\r\n\r\n                    return testable;\r\n                } else {\r\n                    const stable = await this.driver.execute(() => {\r\n                        // eslint-disable-next-line no-undef\r\n                        if (!window.getAllAngularRootElements && window !== window.parent) {\r\n                          // if we are running inside iframe where getAllAngularRootElements is not unavailable\r\n                          // we return true\r\n                            return true;\r\n                        }\r\n\r\n                        // following way of obtaining testability is the same as using: var testability = window.getAllAngularTestabilities()[0];\r\n                        // eslint-disable-next-line no-undef\r\n                        const rootElement = window.getAllAngularRootElements()[0];\r\n                         // eslint-disable-next-line no-undef\r\n                        const testability = window.getAngularTestability(rootElement);\r\n                        // use isStable instead of whenStable due to this issue:\r\n                        // https://stackoverflow.com/questions/54509647/testability-whenstable-returns-testability-isstable-returns-false\r\n                        return testability.isStable();\r\n                    });\r\n\r\n                    return stable;\r\n                }\r\n            } catch (err) {\r\n                // if we got here then it's executeAsync timeout\r\n                console.log('executeAsync err', err);\r\n            }\r\n        },{\r\n            timeout: timeout,\r\n            timeoutMsg: `Unable to attain stability within ${timeout}ms (or this is not an Angular application)`\r\n        });\r\n    } catch (e) {\r\n        if (!softWait) {\r\n            throw new this.OxError(this.errHelper.errorCode.TIMEOUT, e.message);\r\n        }\r\n    }\r\n}"]}
@@ -570,71 +570,75 @@ class WebModule extends _WebDriverModule.default {
570
570
  let retval;
571
571
  this.driver.call(() => {
572
572
  return new Promise((resolve, reject) => {
573
- const waitUntilRetVal = this.driver.waitUntil(async () => {
574
- try {
575
- let images = []; // collect all (screenshot and title) images
573
+ try {
574
+ const waitUntilRetVal = this.driver.waitUntil(async () => {
575
+ try {
576
+ let images = []; // collect all (screenshot and title) images
576
577
 
577
- const handles = await this.driver.getWindowHandles();
578
+ const handles = await this.driver.getWindowHandles();
578
579
 
579
- if (handles && Array.isArray(handles) && handles.length > 0) {
580
- for (const handle of handles) {
581
- await this.driver.switchToWindow(handle);
582
- const image = await this.driver.takeScreenshot();
583
- const title = await this.driver.getTitle();
580
+ if (Array.isArray(handles) && handles.length > 0) {
581
+ for (const handle of handles) {
582
+ await this.driver.switchToWindow(handle);
583
+ const image = await this.driver.takeScreenshot();
584
+ const title = await this.driver.getTitle();
584
585
 
585
- if (title) {
586
- const textToImage = require('../lib/text-to-image');
586
+ if (title) {
587
+ const textToImage = require('../lib/text-to-image');
587
588
 
588
- let titleImage = await textToImage.generate(title);
589
+ let titleImage = await textToImage.generate(title);
589
590
 
590
- if (titleImage && typeof titleImage === 'string') {
591
- titleImage = titleImage.replace('data:image/png;base64,', '');
592
- images.push(titleImage);
591
+ if (titleImage && typeof titleImage === 'string') {
592
+ titleImage = titleImage.replace('data:image/png;base64,', '');
593
+ images.push(titleImage);
594
+ }
593
595
  }
596
+
597
+ images.push(image);
594
598
  }
599
+ } // merge all images into one
595
600
 
596
- images.push(image);
597
- }
598
- } // merge all images into one
599
601
 
602
+ const mergedImage = await (0, _imgMerge.default)(images, {
603
+ direction: true
604
+ });
600
605
 
601
- const mergedImage = await (0, _imgMerge.default)(images, {
602
- direction: true
603
- });
606
+ if (mergedImage && typeof mergedImage === 'string') {
607
+ retval = mergedImage.replace('data:image/jpeg;base64,', '');
608
+ }
604
609
 
605
- if (mergedImage && typeof mergedImage === 'string') {
606
- retval = mergedImage.replace('data:image/jpeg;base64,', '');
610
+ return true;
611
+ } catch (e) {
612
+ error = e;
613
+ return false;
607
614
  }
615
+ }, {
616
+ timeout: 30 * 1000
617
+ });
608
618
 
609
- return true;
610
- } catch (e) {
611
- error = e;
612
- return false;
613
- }
614
- }, {
615
- timeout: 30 * 1000
616
- });
617
-
618
- if (waitUntilRetVal && waitUntilRetVal.then) {
619
- waitUntilRetVal.then(() => {
619
+ if (waitUntilRetVal && waitUntilRetVal.then) {
620
+ waitUntilRetVal.then(() => {
621
+ resolve();
622
+ }).catch(err => {
623
+ reject(err);
624
+ });
625
+ } else {
620
626
  resolve();
621
- }).catch(err => {
622
- reject(err);
623
- });
624
- } else {
625
- resolve();
627
+ }
628
+ } catch (ew) {
629
+ this.logger.error('Cannot get screenshot (1)', error);
626
630
  }
627
631
  });
628
632
  });
629
633
 
630
634
  if (error) {
631
- this.logger.error('Cannot get screenshot', error);
635
+ this.logger.error('Cannot get screenshot (2)', error);
632
636
  }
633
637
 
634
638
  return retval;
635
639
  }
636
640
  } catch (e) {
637
- this.logger.error('Cannot get screenshot', e);
641
+ this.logger.error('Cannot get screenshot (3)', e);
638
642
 
639
643
  if (error) {
640
644
  this.logger.error('Cannot get screenshot inner error', error);
@@ -972,4 +976,4 @@ class WebModule extends _WebDriverModule.default {
972
976
  }
973
977
 
974
978
  exports.default = WebModule;
975
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-web.js"],"names":["MODULE_NAME","DEFAULT_SELENIUM_URL","DEFAULT_BROWSER_NAME","DEFAULT_MOBILE_BROWSER","NO_SCREENSHOT_COMMANDS","ACTION_COMMANDS","DEFAULT_WAIT_TIMEOUT","WebModule","WebDriverModule","constructor","options","context","rs","logger","modules","services","transactions","lastNavigationStartTime","helpers","_loadHelperFunctions","OxError","errHelper","waitForTimeout","name","getDriver","getCapabilities","caps","init","seleniumUrl","isInitialized","appiumUrl","startsWith","ctx","defaultBrowser","browserName","errorCode","INVALID_CAPABILITIES","toLowerCase","recordHAR","browser","performance","url","URL","parse","protocol","replace","host","hostname","port","parseInt","path","pathname","auth","split","wdioOpts","user","key","seleniumUrlBase","isRunningOnSelenoid","_isSelenoidHub","enableVideo","undefined","videoFrameRate","capabilities","logLevel","runner","waitforTimeout","connectionRetryTimeout","connectionRetryCount","initError","_this","provider","modUtils","determineProvider","PERFECTO","openDeviceTimeout","driver","wdio","remote","sessionId","seleniumBrowserTimeout","seleniumTimeout","perfectoExecutionContext","perfectoReporting","Perfecto","PerfectoExecutionContext","webdriver","executeScript","command","params","execute","reportingClient","PerfectoReportingClient","testStart","e","getSeleniumInitError","collectBrowserLogs","getBrowserLogs","error","LAMBDATEST","BROWSERSTACK","includes","maximizeWindow","setTimeout","err","UNKNOWN_ERROR","message","util","inspect","dispose","status","_whenWebModuleDispose","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","SAUCELABS","username","accessKey","passed","id","body","myAccount","SauceLabs","updateJob","stopJob","_sendResultStatusToLambdaTest","deleteSession","TESTINGBOT","_sendResultStatusToTestingBot","testStop","Constants","results","failed","_sendResultStatusToBrowserstack","closeBrowserWindows","disposeContinue","warn","promise","seleniumSessionTimeout","seleniumPid","process","platform","stdio","pgrepResult","toString","resolve","_iterationStart","global","_lastTransactionName","_iterationEnd","type","errorHelper","SELENIUM_SESSION_TIMEOUT","logs","log","push","_adjustBrowserLog","_getHAR","har","hasFailed","_addSelenoidVideoAsTestAttachment","_isAction","_takeScreenshotSilent","takeScreenshot","retval","call","Promise","reject","waitUntilRetVal","waitUntil","images","handles","getWindowHandles","handle","switchToWindow","image","title","getTitle","textToImage","require","titleImage","generate","mergedImage","direction","timeout","then","catch","time","timestamp","msg","level","src","_getStats","commandName","fetchStats","navigationStart","domContentLoaded","load","samePage","lastError","timings","window","timing","domContentLoadedEventStart","loadEventStart","executeError","console","DomContentLoadedEvent","LoadEvent","transaction","counter","Object","keys","filter","getWdioLocator","matchPattern","getElement","getElements","getChildElement","getChildElements","setTimeoutImplicit","restoreTimeoutImplicit","assertArgument","assertArgumentNonEmptyString","assertArgumentNumber","assertArgumentNumberNonNegative","assertArgumentBool","assertArgumentBoolOptional","assertArgumentTimeout","assertArgumentString","types","getLogTypes","getLogs","Symbol","iterator","JSON","stringify","events","msgObj","checkWaitForAngular","autoWaitForAngular","waitForAngular","autoWaitForAngularRootSelector","autoWaitForAngularSoftWait","autoWaitForAngularTimeout","lambdaCredentials","lambdaAutomationClient","lambdaRestClient","AutomationClient","requestBody","status_ind","updateSessionById","tb","TestingBot","api_key","api_secret","testData","updateTest","testDetails","method","json","rejectUnauthorized","res","indexOf","recordVideo","videoFileUrl","fileName","attachments","newVideoAttachment"],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars */\r\n/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\n'use strict';\r\n/**\r\n * @name web\r\n * @description Provides methods for browser automation.\r\n * @sample **Notes:**  \r\n *   \r\n * Commands which operate on elements such as click, assert, waitFor, type, select, and others will automatically wait for a period of time for the element to appear in DOM and become visible. By default this period equals to 60 seconds, but can be changed using the `setTimeout`command.\r\n *   \r\n * **String matching patterns:** \r\n * \r\n *  Commands which expect a string matching pattern in their arguments, support following patterns unless specified otherwise:\r\n * \r\n *  * `regex:PATTERN` - Match using regular expression.\r\n *  * `regexi:PATTERN` - Match using case-insensitive regular expression.\r\n *  * `exact:STRING` - Match the string verbatim.\r\n *  * `glob:PATTERN` - Match using case-insensitive glob pattern. `?` will match any single character except new line \\(\\n\\). `*` will match any sequence \\(0 or more\\) of characters except new line. Empty     PATTERN will match only other empty strings.\r\n *  * `PATTERN` - Same as glob matching.  \r\n *\r\n * **Locators:** \r\n * \r\n *  Commands which expect an element locator in their arguments, support following locator types unless specified otherwise:\r\n * \r\n *  * `id=ID` - Locates element by its ID attribute.\r\n *  * `css=CSS_SELECTOR` - Locates element using a CSS selector.\r\n *  * `link=TEXT` - Locates link element whose visible text matches the given string.\r\n *  * `link-contains=TEXT` - Locates link element whose visible text contains the given string.\r\n *  * `name=NAME` - Locates element by its NAME attribute.\r\n *  * `tag=NAME` - Locates element by its tag name.\r\n *  * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n *  * `(XPATH)[]` - Locates element using an XPath 1.0 expression.\r\n */\r\n\r\n/* eslint-disable quotes */\r\nimport { harFromMessages } from 'chrome-har';\r\nimport URL from 'url';\r\nimport * as wdio from 'webdriverio';\r\nimport WebDriverModule from '../core/WebDriverModule';\r\nimport { defer } from 'when';\r\nimport modUtils from './utils';\r\nimport errHelper from '../errors/helper';\r\nimport OxError from '../errors/OxygenError';\r\nimport util from 'util';\r\nimport SauceLabs from 'saucelabs';\r\nimport lambdaRestClient from '@lambdatest/node-rest-client';\r\nimport TestingBot from 'testingbot-api';\r\nimport { execSync } from 'child_process';\r\nimport perfectoReporting from 'perfecto-reporting';\r\nimport request from 'request';\r\nimport mergeImages from '../lib/img-merge';\r\nimport errorHelper from '../errors/helper';\r\n\r\nconst MODULE_NAME = 'web';\r\nconst DEFAULT_SELENIUM_URL = 'http://localhost:4444/wd/hub';\r\nconst DEFAULT_BROWSER_NAME = 'chrome';\r\nconst DEFAULT_MOBILE_BROWSER = 'default';\r\nconst NO_SCREENSHOT_COMMANDS = ['init', 'assertAlert'];\r\nconst ACTION_COMMANDS = ['open', 'click'];\r\nconst DEFAULT_WAIT_TIMEOUT = 60 * 1000;            // default 60s wait timeout\r\n\r\nexport default class WebModule extends WebDriverModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this.transactions = {};                      // transaction->har dictionary\r\n        this.lastNavigationStartTime = null;\r\n        this.helpers = {};\r\n        this._loadHelperFunctions();\r\n        // support backward compatibility (some module commands might refer to this.OxError and this.errHelper)\r\n        this.OxError = OxError;\r\n        this.errHelper = errHelper;\r\n        // holds element operation timeout value\r\n        this.waitForTimeout = DEFAULT_WAIT_TIMEOUT;\r\n    }\r\n\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @function getDriver\r\n     * @summary Returns the underlying WDIO driver.\r\n     * @return {Object} WDIO driver.\r\n     */\r\n    getDriver() {\r\n        return super.getDriver();\r\n    }\r\n\r\n    /**\r\n     * @function getCapabilities\r\n     * @summary Returns currently defined capabilities.\r\n     * @return {Object} Current capabilities object.\r\n     */\r\n    getCapabilities() {\r\n        return this.caps || super.getCapabilities();\r\n    }\r\n\r\n    /**\r\n     * @function init\r\n     * @summary Initializes new Selenium session.\r\n     * @param {String=} caps - Desired capabilities. If not specified capabilities will be taken from suite definition.\r\n     * @param {String=} seleniumUrl - Remote server URL (default: http://localhost:4444/wd/hub).\r\n     */\r\n    async init(caps, seleniumUrl) {\r\n        if (this.isInitialized) {\r\n            return;\r\n        }\r\n\r\n        if (!seleniumUrl) {\r\n            // if appiumUrl points to an external execution grid (such as BS)\r\n            if (this.options.appiumUrl && !this.options.appiumUrl.startsWith('http://localhost')) {\r\n                seleniumUrl = this.options.appiumUrl;\r\n            }\r\n            else {\r\n                seleniumUrl = this.options.seleniumUrl || DEFAULT_SELENIUM_URL;\r\n            }\r\n        }\r\n\r\n        // take capabilities either from init method argument or from context parameters passed in the constructor\r\n        // merge capabilities from context and from init function argument, give preference to context-passed capabilities\r\n        this.caps = {};\r\n        if (this.ctx.caps) {\r\n            this.caps = { ...this.ctx.caps };\r\n        }\r\n        if (caps) {\r\n            this.caps = { ...this.caps, ...caps };\r\n        }\r\n\r\n        // populate browserName caps from options. FIXME: why is this even needed?\r\n        let defaultBrowser = false;\r\n        if (!this.caps.browserName) {\r\n            this.caps.browserName = this.options.browserName || DEFAULT_BROWSER_NAME;\r\n            defaultBrowser = true;\r\n        }\r\n        // FIXME: shall we throw an exception if browserName is not specified, neither in caps nor in options?!\r\n        if (!this.caps.browserName) {\r\n            throw new OxError(errHelper.errorCode.INVALID_CAPABILITIES,\r\n                'Failed to initialize `web` module - browserName must be specified.');\r\n        }\r\n\r\n        // adjust browserName-s\r\n        if (this.caps.browserName.toLowerCase() === 'ie') {\r\n            // IE is specified as 'ie' through the command line and possibly suites\r\n            // but selenium standalone server expects 'internet explorer'\r\n            this.caps.browserName = 'internet explorer';\r\n        } else if (this.caps['lambda:options']) {\r\n            // lambdatest expects original case names\r\n        } else if (this.caps['perfectoMobile:options']) {\r\n            // perfectoMobile expects original case names\r\n        } else if (this.caps.browserName !== 'MicrosoftEdge') {\r\n            // selenium standalone server expects all browserNames to be lowercase\r\n            // except \"MicrosoftEdge\"\r\n            this.caps.browserName = this.caps.browserName.toLowerCase();\r\n        }\r\n\r\n        // adjust capabilities to enable collecting browser and performance stats in Chrome \r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            this.caps['goog:loggingPrefs'] = {     // for ChromeDriver >= 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n            /*\r\n            // specifying this leads Chrome 77+ to refuse loading\r\n            this.caps.loggingPrefs = {             // for ChromeDriver < 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n            this.caps.chromeOptions = {\r\n                perfLoggingPrefs: {\r\n                    enableNetwork: true,\r\n                    enablePage: false\r\n                }\r\n            };\r\n            */\r\n        }\r\n\r\n        // populate WDIO options\r\n        const url = URL.parse(seleniumUrl || DEFAULT_SELENIUM_URL);\r\n        const protocol = url.protocol.replace(/:$/, '');\r\n        const host = url.hostname;\r\n        const port = parseInt(url.port || (protocol === 'https' ? 443 : 80));\r\n        const path = url.pathname;\r\n\r\n        // auth is needed mostly for cloud providers such as LambdaTest\r\n        if (url.auth) {\r\n            const auth = url.auth.split(':');\r\n            this.options.wdioOpts = {\r\n                user: auth[0],\r\n                key: auth[1]\r\n            };\r\n        }\r\n        this.seleniumUrlBase = `${protocol}://${host}:${port}`;\r\n        // check if selenium hub is based on Selenoid, then enable video recording\r\n        this.isRunningOnSelenoid = await this._isSelenoidHub(this.seleniumUrlBase);\r\n        if (this.isRunningOnSelenoid) {\r\n            if (!this.caps['selenoid:options']) {\r\n                this.caps['selenoid:options'] = {};\r\n            }\r\n            if (this.caps['selenoid:options'].enableVideo === undefined) {\r\n                this.caps['selenoid:options'].enableVideo = true;\r\n                this.caps['selenoid:options'].videoFrameRate = 4;\r\n            }\r\n        }\r\n        // generate Webdriver.io options\r\n        const wdioOpts = {\r\n            ...this.options.wdioOpts || {},\r\n            protocol: protocol,\r\n            hostname: host,\r\n            port: port,\r\n            path: path,\r\n            capabilities: this.caps,\r\n            logLevel: 'silent',\r\n            runner: 'repl',\r\n            waitforTimeout: 5000, // increase the default 3000\r\n            connectionRetryTimeout: 310*1000,\r\n            connectionRetryCount: 1\r\n        };\r\n\r\n        let initError = null;\r\n        const _this = this;\r\n        const provider = modUtils.determineProvider(wdioOpts);\r\n\r\n        if (provider === modUtils.provider.PERFECTO) {\r\n            wdioOpts.path = '/nexperience/perfectomobile/wd/hub';\r\n            wdioOpts.port = 80;\r\n            wdioOpts.protocol = 'http';\r\n            wdioOpts.openDeviceTimeout = 15;\r\n        }\r\n\r\n        let name = 'name';\r\n        if (wdioOpts.capabilities['perfectoMobile:options'] && wdioOpts.capabilities['perfectoMobile:options']['name']) {\r\n            name = wdioOpts.capabilities['perfectoMobile:options']['name'];\r\n            delete wdioOpts.capabilities['perfectoMobile:options'];\r\n        }\r\n        if (wdioOpts.capabilities['lambda:options'] && wdioOpts.capabilities['lambda:options']['name']) {\r\n            name = wdioOpts.capabilities['lambda:options']['name'];\r\n            delete wdioOpts.capabilities['lambda:options'];\r\n        }\r\n        if (wdioOpts.capabilities['testingBot:options'] && wdioOpts.capabilities['testingBot:options']['name']) {\r\n            name = wdioOpts.capabilities['testingBot:options']['name'];\r\n            delete wdioOpts.capabilities['testingBot:options'];\r\n        }\r\n        if (wdioOpts.capabilities['bstack:options'] && wdioOpts.capabilities['bstack:options']['name']) {\r\n            name = wdioOpts.capabilities['bstack:options']['name'];\r\n            delete wdioOpts.capabilities['bstack:options'];\r\n        }\r\n        // set default browser for mobile web tests, if executed against remote devices of a cloud provider\r\n        if (defaultBrowser && provider) {\r\n            this.caps.browserName = wdioOpts.capabilities.browserName = DEFAULT_MOBILE_BROWSER;\r\n        }\r\n        this.wdioOpts = wdioOpts;\r\n        try {\r\n            this.driver = await wdio.remote(wdioOpts);\r\n            this.sessionId = this.driver.sessionId;\r\n            this.driver.provider = provider;\r\n\r\n            if (this.options.seleniumBrowserTimeout) {\r\n                this.driver.seleniumBrowserTimeout = this.options.seleniumBrowserTimeout;\r\n            }\r\n\r\n            if (this.options.seleniumTimeout) {\r\n                this.driver.seleniumTimeout = this.options.seleniumTimeout;\r\n            }\r\n\r\n            if (provider === modUtils.provider.PERFECTO) {\r\n                const perfectoExecutionContext = await new perfectoReporting.Perfecto.PerfectoExecutionContext({\r\n                    webdriver: {\r\n                        executeScript: async (command, params) => {\r\n                            return await this.driver.execute(command, params);\r\n                        }\r\n                    }\r\n                });\r\n                this.reportingClient = new perfectoReporting.Perfecto.PerfectoReportingClient(perfectoExecutionContext);\r\n                await this.reportingClient.testStart(name);\r\n            }\r\n        }\r\n        catch (e) {\r\n            throw errHelper.getSeleniumInitError(e);\r\n        }\r\n\r\n        // reset browser logs if auto collect logs option is enabled\r\n        if (this.options.collectBrowserLogs && this.caps.browserName === 'chrome') {\r\n            try {\r\n                // simply call this to clear the previous logs and start the test with the clean logs\r\n                await this.getBrowserLogs();\r\n            } catch (e) {\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n\r\n        try {\r\n            if (\r\n                [modUtils.provider.LAMBDATEST, modUtils.provider.BROWSERSTACK, modUtils.provider.PERFECTO].includes(this.driver.provider)\r\n                //['MicrosoftEdge', 'msedge', 'Edge', 'Internet Explorer'].includes(this.driver.capabilities.browserName)\r\n            ) {\r\n                // do not maximize window if the test is executed against external cloud provider infrastructure\r\n                // as most of cloud providers do not support this functionality\r\n            } else {\r\n                // maximize browser window\r\n                await this.driver.maximizeWindow();\r\n                // set initial Timeout\r\n                await this.driver.setTimeout({\r\n                    'implicit': this.waitForTimeout,\r\n                    'pageLoad': this.waitForTimeout\r\n                });\r\n            }\r\n\r\n        } catch (err) {\r\n            throw new OxError(errHelper.errorCode.UNKNOWN_ERROR, err.message, util.inspect(err));\r\n        }\r\n        super.init(this.driver);\r\n    }\r\n\r\n    /**\r\n     * @function dispose\r\n     * @summary Ends the current session.\r\n     * @param {String=} status - Test status, either `passed` or `failed`.\r\n     */\r\n    async dispose(status) {\r\n        this.transactions = {};\r\n        this._whenWebModuleDispose = defer();\r\n\r\n        if (!status) {\r\n            status = 'passed';\r\n\r\n            if (this.rs.steps && Array.isArray(this.rs.steps) && this.rs.steps.length > 0) {\r\n                const failedFinded = this.rs.steps.find((item) => item.status === 'failed');\r\n                if (failedFinded) {\r\n                    status = 'failed';\r\n                }\r\n            }\r\n        }\r\n\r\n        if (this.driver && this.isInitialized) {\r\n            try {\r\n                status = status.toUpperCase();\r\n\r\n                if (this.driver.provider === modUtils.provider.SAUCELABS) {\r\n                    const username = this.wdioOpts.capabilities['sauce:options']['username'];\r\n                    const accessKey = this.wdioOpts.capabilities['sauce:options']['accessKey'];\r\n                    const passed = status === 'PASSED';\r\n                    const id = this.driver.sessionId;\r\n                    const body = \"{\\\"passed\\\":\"+passed+\"}\";\r\n\r\n                    const myAccount = new SauceLabs({ user: username, key: accessKey});\r\n                    await myAccount.updateJob(username, id, body);\r\n                    await myAccount.stopJob(username, id);\r\n                } else if (this.driver.provider === modUtils.provider.LAMBDATEST) {\r\n                    await this._sendResultStatusToLambdaTest(status);\r\n                    await this.deleteSession();\r\n                } else if (this.driver.provider === modUtils.provider.TESTINGBOT) {\r\n                    await this._sendResultStatusToTestingBot(status);\r\n                    await this.deleteSession();\r\n                } else if (this.driver.provider === modUtils.provider.PERFECTO) {\r\n                    await this.reportingClient.testStop({\r\n                        status: status === 'PASSED' ?\r\n                                    perfectoReporting.Constants.results.passed :\r\n                                    perfectoReporting.Constants.results.failed\r\n                    });\r\n                } else if (this.driver.provider === modUtils.provider.BROWSERSTACK) {\r\n                    await this._sendResultStatusToBrowserstack(status);\r\n                    await this.deleteSession();\r\n                }\r\n\r\n                if (this.driver.provider === null && ['PASSED','FAILED'].includes(status)) {\r\n                    await this.closeBrowserWindows(status);\r\n                } else {\r\n                    // canceled or other status\r\n                    this.disposeContinue();\r\n                }\r\n            } catch (e) {\r\n                this.logger.warn('Error disposing driver: ', e);    // ignore any errors at disposal stage\r\n            }\r\n        } else {\r\n            this.disposeContinue();\r\n        }\r\n\r\n        return this._whenWebModuleDispose.promise;\r\n    }\r\n\r\n    async deleteSession() {\r\n        try {\r\n            if (this.driver && this.driver.deleteSession) {\r\n                if (this.seleniumSessionTimeout) {\r\n                    // ignore\r\n                    // deleteSession will take 5 min to call\r\n                } else {\r\n                    await this.driver.deleteSession();\r\n                }\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('deleteSession error', e);\r\n        }\r\n    }\r\n\r\n    async closeBrowserWindows(status) {\r\n        if (status && 'FAILED' === status.toUpperCase() && this.options && this.options.seleniumPid) {\r\n            this.disposeContinue(status);\r\n        } else {\r\n            await this.deleteSession();\r\n            this.disposeContinue();\r\n        }\r\n    }\r\n\r\n    disposeContinue(status) {\r\n        this.driver = null;\r\n        this.lastNavigationStartTime = null;\r\n        super.dispose();\r\n\r\n        // cleanup chromedriver's only when running from within the IDE and test did not fail\r\n        if (this.options && this.options.seleniumPid && (!status || 'FAILED' !== status.toUpperCase())) {\r\n            try {\r\n                if (process.platform === 'win32') {\r\n                    execSync('taskkill /IM chromedriver.exe /F', { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                } else {\r\n                    let pgrepResult = execSync(\"pgrep -d' ' chromedriver\");\r\n                    if (pgrepResult && pgrepResult.toString) {\r\n                        pgrepResult = pgrepResult.toString();\r\n                        if (pgrepResult) {\r\n                            execSync('kill -9 ' + pgrepResult, { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                        }\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n            }\r\n        }\r\n\r\n        // cleanup edgedriver's only when running from within the IDE and test did not fail\r\n        if (this.options && this.options.seleniumPid && (!status || 'FAILED' !== status.toUpperCase())) {\r\n            try {\r\n                if (process.platform === 'win32') {\r\n                    // ignore for now\r\n                } else {\r\n                    let pgrepResult = execSync(\"pgrep -d' ' msedgedriver\");\r\n                    if (pgrepResult && pgrepResult.toString) {\r\n                        pgrepResult = pgrepResult.toString();\r\n                        if (pgrepResult) {\r\n                            execSync('kill -9 ' + pgrepResult, { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                        }\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n            }\r\n        }\r\n\r\n        this._whenWebModuleDispose.resolve(null);\r\n    }\r\n\r\n    _iterationStart() {\r\n        // clear transaction name saved in previous iteration if any\r\n        global._lastTransactionName = null;\r\n    }\r\n\r\n    async _iterationEnd(error) {\r\n        if (error && error.type === errorHelper.errorCode.SELENIUM_SESSION_TIMEOUT) {\r\n            this.seleniumSessionTimeout = true;\r\n            return;\r\n        } else {\r\n            this.seleniumSessionTimeout = false;\r\n        }\r\n\r\n        if (!this.isInitialized) {\r\n            return;\r\n        }\r\n        // collect browser logs for this session\r\n        if (this.options.collectBrowserLogs === true && this.caps.browserName === 'chrome') {\r\n            try {\r\n                const logs = await this.getBrowserLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (var log of logs) {\r\n                        this.rs.logs.push(this._adjustBrowserLog(log));\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n        // TODO: should clear transactions to avoid duplicate names across iterations\r\n        // also should throw on duplicate names.\r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            // there might be no transactions set if test fails before web.transaction command\r\n            if (global._lastTransactionName) {\r\n                this.transactions[global._lastTransactionName] = await this._getHAR();\r\n            }\r\n        }\r\n\r\n        this.rs.har = this.transactions;\r\n        const hasFailed = error !== undefined && error !== null;\r\n        this._addSelenoidVideoAsTestAttachment(hasFailed);\r\n    }\r\n\r\n    _isAction(name) {\r\n        return ACTION_COMMANDS.includes(name);\r\n    }\r\n\r\n    _takeScreenshotSilent(name) {\r\n        if (!NO_SCREENSHOT_COMMANDS.includes(name)) {\r\n            let error;\r\n            try {\r\n                if (\r\n                    this.driver &&\r\n                    this.driver.takeScreenshot\r\n                ) {\r\n                    let retval;\r\n                    this.driver.call(() => {\r\n                        return new Promise((resolve, reject) => {\r\n                            const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                                try {\r\n                                    let images = [];\r\n\r\n                                    // collect all (screenshot and title) images\r\n                                    const handles = await this.driver.getWindowHandles();\r\n                                    if (\r\n                                        handles &&\r\n                                        Array.isArray(handles) &&\r\n                                        handles.length > 0\r\n                                    ) {\r\n                                        for (const handle of handles) {\r\n                                            await this.driver.switchToWindow(handle);\r\n                                            const image = await this.driver.takeScreenshot();\r\n                                            const title = await this.driver.getTitle();\r\n\r\n                                            if (title) {\r\n                                                const textToImage = require('../lib/text-to-image');\r\n                                                let titleImage = await textToImage.generate(title);\r\n                                                if (titleImage && typeof titleImage === 'string') {\r\n                                                    titleImage = titleImage.replace('data:image/png;base64,', '');\r\n                                                    images.push(titleImage);\r\n                                                }\r\n                                            }\r\n\r\n                                            images.push(image);\r\n                                        }\r\n                                    }\r\n\r\n                                    // merge all images into one\r\n                                    const mergedImage = await mergeImages(images, { direction: true });\r\n                                    if (mergedImage && typeof mergedImage === 'string') {\r\n                                        retval = mergedImage.replace('data:image/jpeg;base64,', '');\r\n                                    }\r\n\r\n                                    return true;\r\n                                } catch (e) {\r\n                                    error = e;\r\n                                    return false;\r\n                                }\r\n                            },\r\n                            { timeout: 30*1000 });\r\n\r\n                            if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                                waitUntilRetVal.then(() => {\r\n                                    resolve();\r\n                                }).catch((err) => {\r\n                                    reject(err);\r\n                                });\r\n                            } else {\r\n                                resolve();\r\n                            }\r\n                        });\r\n                    });\r\n\r\n                    if (error) {\r\n                        this.logger.error('Cannot get screenshot', error);\r\n                    }\r\n\r\n                    return retval;\r\n                }\r\n            } catch (e) {\r\n                this.logger.error('Cannot get screenshot', e);\r\n                if (error) {\r\n                    this.logger.error('Cannot get screenshot inner error', error);\r\n                }\r\n                // ignore\r\n            }\r\n        }\r\n    }\r\n\r\n    _adjustBrowserLog(log) {\r\n        if (!log || typeof log !== 'object') {\r\n            return null;\r\n        }\r\n        // TODO: convert log.timestamp from the browser time zone to the local one (so we can later correlate between steps and logs)\r\n        return {\r\n            time: log.timestamp,\r\n            msg: log.message,\r\n            // convert SEVERE log level to ERROR\r\n            level: log.level === 'SEVERE' ? 'ERROR' : log.level,\r\n            src: 'browser'\r\n        };\r\n    }\r\n\r\n    /*\r\n     * FIXME: There is a bug with IE. See the comment within function body.\r\n     *\r\n     *  domContentLoaded (aka First Visual Time)- Represents the difference between domContentLoadedEventStart and navigationStart.\r\n     *  load (aka Full Load Time)               - Represents the difference between loadEventStart and navigationStart.\r\n     *\r\n     * The processing model:\r\n     *\r\n     *  1. navigationStart              - The browser has requested the document.\r\n     *  2. ...                          - Not relevant to us. See http://www.w3.org/TR/navigation-timing/#process for more information.\r\n     *  3. domLoading                   - The browser starts parsing the document.\r\n     *  4. domInteractive               - The browser has finished parsing the document and the user can interact with the page.\r\n     *  5. domContentLoadedEventStart   - The document has been completely loaded and parsed and deferred scripts, if any, have executed. \r\n     *                                    Async scripts, if any, might or might not have executed.\r\n     *                                    Stylesheets[1], images, and subframes might or might not have finished loading.\r\n     *                                      [1] - Stylesheets /usually/ defer this event! - http://molily.de/weblog/domcontentloaded\r\n     *  6. domContentLoadedEventEnd     - The DOMContentLoaded event callback, if any, finished executing. E.g.\r\n     *                                      document.addEventListener(\"DOMContentLoaded\", function(event) {\r\n     *                                          console.log(\"DOM fully loaded and parsed\");\r\n     *                                      });\r\n     *  7. domComplete                  - The DOM tree is completely built. Async scripts, if any, have executed.\r\n     *  8. loadEventStart               - The browser have finished loading all the resources like images, swf, etc.\r\n     *  9. loadEventEnd                 - The load event callback, if any, finished executing.\r\n     */\r\n    _getStats(commandName) {\r\n        if (this.options.fetchStats && this.isInitialized && this._isAction(commandName)) {\r\n            var navigationStart;\r\n            var domContentLoaded = 0;\r\n            var load = 0;\r\n            var samePage = false;\r\n\r\n            // TODO: handle following situation:\r\n            // if navigateStart equals to the one we got from previous attempt (we need to save it)\r\n            // it means we are still on the same page and don't need to record load/domContentLoaded times\r\n            try {\r\n                this.driver.call(() => {\r\n                    return new Promise((resolve, reject) => {\r\n                        let lastError = false;\r\n                        const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                            try {\r\n                                /*global window*/\r\n                                var timings = await this.driver.execute(function() {\r\n                                    return {\r\n                                        navigationStart: window.performance.timing.navigationStart,\r\n                                        domContentLoadedEventStart: window.performance.timing.domContentLoadedEventStart,\r\n                                        loadEventStart: window.performance.timing.loadEventStart\r\n                                    };\r\n                                });\r\n                                lastError = false;\r\n\r\n                                if (timings.domContentLoadedEventStart > 0 && timings.loadEventStart > 0) {\r\n                                    samePage = this.lastNavigationStartTime && this.lastNavigationStartTime == timings.navigationStart;\r\n                                    navigationStart = this.lastNavigationStartTime = timings.navigationStart;\r\n                                    var domContentLoadedEventStart = timings.domContentLoadedEventStart;\r\n                                    var loadEventStart = timings.loadEventStart;\r\n\r\n                                    domContentLoaded = domContentLoadedEventStart - navigationStart;\r\n                                    load = loadEventStart - navigationStart;\r\n\r\n                                    return domContentLoadedEventStart > 0 && loadEventStart > 0;\r\n                                } else {\r\n                                    return false;\r\n                                }\r\n                            } catch (executeError) {\r\n                                // collect error inside driver.execute or driver.waitUntil\r\n                                lastError = executeError;\r\n                            }\r\n                        },\r\n                        { timeout: 30*1000 });\r\n\r\n                        if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                            waitUntilRetVal.then(() => {\r\n                                if (lastError) {\r\n                                    // print error from driver.execute or driver.waitUntil\r\n                                    console.log(lastError);\r\n                                }\r\n                                resolve();\r\n                            }).catch((err) => {\r\n                                if (lastError) {\r\n                                    // print error from driver.execute or driver.waitUntil\r\n                                    console.log(lastError);\r\n                                }\r\n                                reject(err);\r\n                            });\r\n                        } else {\r\n                            resolve();\r\n                        }\r\n                    });\r\n                });\r\n            } catch (e) {\r\n                return {};\r\n                // couldn't get timings.\r\n            }\r\n\r\n            this.lastNavigationStartTime = navigationStart;\r\n\r\n            return samePage ? {} : { DomContentLoadedEvent: domContentLoaded, LoadEvent: load };\r\n        }\r\n\r\n        return {};\r\n    }\r\n\r\n    /**\r\n     * @summary Opens new transaction.\r\n     * @description The transaction will persist till 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\r\n        if (global._lastTransactionName) {\r\n            this.transactions[global._lastTransactionName] = null;\r\n\r\n            if (this.options.recordHAR && this.isInitialized && this.caps.browserName === 'chrome') {\r\n                this.transactions[global._lastTransactionName] = await this._getHAR();\r\n            }\r\n        }\r\n\r\n        if (typeof this.transactions[name] !== 'undefined') {\r\n            const counter = Object.keys(this.transactions).filter((item) => item.startsWith(name)).length + 1;\r\n            global._lastTransactionName = name+' (#'+counter+')';\r\n        } else {\r\n            global._lastTransactionName = name;\r\n        }\r\n    }\r\n\r\n    _loadHelperFunctions() {\r\n        this.helpers.getWdioLocator = modUtils.getWdioLocator;\r\n        this.helpers.matchPattern = modUtils.matchPattern;\r\n        this.helpers.getElement = modUtils.getElement;\r\n        this.helpers.getElements = modUtils.getElements;\r\n        this.helpers.getChildElement = modUtils.getChildElement;\r\n        this.helpers.getChildElements = modUtils.getChildElements;\r\n        this.helpers.setTimeoutImplicit = modUtils.setTimeoutImplicit;\r\n        this.helpers.restoreTimeoutImplicit = modUtils.restoreTimeoutImplicit;\r\n        this.helpers.assertArgument = modUtils.assertArgument;\r\n        this.helpers.assertArgumentNonEmptyString = modUtils.assertArgumentNonEmptyString;\r\n        this.helpers.assertArgumentNumber = modUtils.assertArgumentNumber;\r\n        this.helpers.assertArgumentNumberNonNegative = modUtils.assertArgumentNumberNonNegative;\r\n        this.helpers.assertArgumentBool = modUtils.assertArgumentBool;\r\n        this.helpers.assertArgumentBoolOptional = modUtils.assertArgumentBoolOptional;\r\n        this.helpers.assertArgumentTimeout = modUtils.assertArgumentTimeout;\r\n        this.helpers.assertArgumentString = modUtils.assertArgumentString;\r\n    }\r\n\r\n    async _getHAR() {\r\n        try {\r\n            const types = await this.driver.getLogTypes();\r\n\r\n            if (types.includes('performance')) {\r\n                const logs = await this.driver.getLogs('performance');\r\n\r\n                // in one instance, logs was not iterable for some reason - hence the following check:\r\n                if (!logs || typeof logs[Symbol.iterator] !== 'function') {\r\n                    this.logger.error('getHAR: logs not iterable: ' + JSON.stringify(logs));\r\n                    return null;\r\n                }\r\n\r\n                const events = [];\r\n                for (let log of logs) {\r\n                    const msgObj = JSON.parse(log.message);   // returned as string\r\n                    events.push(msgObj.message);\r\n                }\r\n\r\n                const har = harFromMessages(events);\r\n                return JSON.stringify(har);\r\n            } else {\r\n                return null;\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('Unable to fetch HAR: ' + e.toString());\r\n            return null;\r\n        }\r\n    }\r\n\r\n    async checkWaitForAngular() {\r\n        if (this.autoWaitForAngular) {\r\n            await this.waitForAngular(this.autoWaitForAngularRootSelector, this.autoWaitForAngularSoftWait, this.autoWaitForAngularTimeout);\r\n        }\r\n    }\r\n\r\n    async _sendResultStatusToLambdaTest(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const lambdaCredentials = {\r\n                username: this.wdioOpts.user,\r\n                accessKey: this.wdioOpts.key\r\n            };\r\n            const sessionId = this.driver.sessionId;\r\n            const lambdaAutomationClient = lambdaRestClient.AutomationClient(\r\n                lambdaCredentials\r\n            );\r\n            const requestBody = {\r\n                status_ind: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n            try {\r\n                lambdaAutomationClient.updateSessionById(sessionId, requestBody, (error) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to LambdaTest: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _sendResultStatusToTestingBot(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const sessionId = this.driver.sessionId;\r\n            const tb = new TestingBot({\r\n                api_key: this.wdioOpts.user,\r\n                api_secret: this.wdioOpts.key\r\n            });\r\n            const testData = { \"test[success]\" : status === 'PASSED' ? \"1\" : \"0\" };\r\n            try {\r\n                tb.updateTest(testData, sessionId, function(error, testDetails) {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to TestingBot: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _sendResultStatusToBrowserstack(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const requestBody = {\r\n                status: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n\r\n            const options = {\r\n                url: `https://api.browserstack.com/automate/sessions/${this.driver.sessionId}.json`,\r\n                method: 'PUT',\r\n                json: true,\r\n                rejectUnauthorized: false,\r\n                body: requestBody,\r\n                'auth': {\r\n                    'user': this.wdioOpts.user,\r\n                    'pass': this.wdioOpts.key,\r\n                    'sendImmediately': false\r\n                },\r\n            };\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _isSelenoidHub(seleniumUrl) {\r\n        return new Promise((resolve, reject) => {\r\n            const options = {\r\n                url: `${seleniumUrl}`,\r\n                method: 'GET',\r\n                json: false,\r\n                rejectUnauthorized: false,\r\n            };\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    if (err) {\r\n                        reject(err);\r\n                    }\r\n                    else {\r\n                        if (body && body.length && body.indexOf('You are using Selenoid') > -1) {\r\n                            resolve(true);\r\n                        }\r\n                        else {\r\n                            resolve(false);\r\n                        }\r\n                    }\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    // if the test is running inside Selenoid, then download the video if test has failed\r\n    async _addSelenoidVideoAsTestAttachment(hasFailed = false) {\r\n        if (!this.isRunningOnSelenoid) {\r\n            return;\r\n        }\r\n        if (!this.options.recordVideo && !hasFailed) {\r\n            return;\r\n        }\r\n        const videoFileUrl = `${this.seleniumUrlBase}/video/${this.sessionId}.mp4`;\r\n        const fileName = `${this.sessionId}.mp4`;\r\n        this.rs.attachments.push(modUtils.newVideoAttachment(fileName, videoFileUrl));\r\n    }\r\n}\r\n\r\n"]}
979
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-web.js"],"names":["MODULE_NAME","DEFAULT_SELENIUM_URL","DEFAULT_BROWSER_NAME","DEFAULT_MOBILE_BROWSER","NO_SCREENSHOT_COMMANDS","ACTION_COMMANDS","DEFAULT_WAIT_TIMEOUT","WebModule","WebDriverModule","constructor","options","context","rs","logger","modules","services","transactions","lastNavigationStartTime","helpers","_loadHelperFunctions","OxError","errHelper","waitForTimeout","name","getDriver","getCapabilities","caps","init","seleniumUrl","isInitialized","appiumUrl","startsWith","ctx","defaultBrowser","browserName","errorCode","INVALID_CAPABILITIES","toLowerCase","recordHAR","browser","performance","url","URL","parse","protocol","replace","host","hostname","port","parseInt","path","pathname","auth","split","wdioOpts","user","key","seleniumUrlBase","isRunningOnSelenoid","_isSelenoidHub","enableVideo","undefined","videoFrameRate","capabilities","logLevel","runner","waitforTimeout","connectionRetryTimeout","connectionRetryCount","initError","_this","provider","modUtils","determineProvider","PERFECTO","openDeviceTimeout","driver","wdio","remote","sessionId","seleniumBrowserTimeout","seleniumTimeout","perfectoExecutionContext","perfectoReporting","Perfecto","PerfectoExecutionContext","webdriver","executeScript","command","params","execute","reportingClient","PerfectoReportingClient","testStart","e","getSeleniumInitError","collectBrowserLogs","getBrowserLogs","error","LAMBDATEST","BROWSERSTACK","includes","maximizeWindow","setTimeout","err","UNKNOWN_ERROR","message","util","inspect","dispose","status","_whenWebModuleDispose","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","SAUCELABS","username","accessKey","passed","id","body","myAccount","SauceLabs","updateJob","stopJob","_sendResultStatusToLambdaTest","deleteSession","TESTINGBOT","_sendResultStatusToTestingBot","testStop","Constants","results","failed","_sendResultStatusToBrowserstack","closeBrowserWindows","disposeContinue","warn","promise","seleniumSessionTimeout","seleniumPid","process","platform","stdio","pgrepResult","toString","resolve","_iterationStart","global","_lastTransactionName","_iterationEnd","type","errorHelper","SELENIUM_SESSION_TIMEOUT","logs","log","push","_adjustBrowserLog","_getHAR","har","hasFailed","_addSelenoidVideoAsTestAttachment","_isAction","_takeScreenshotSilent","takeScreenshot","retval","call","Promise","reject","waitUntilRetVal","waitUntil","images","handles","getWindowHandles","handle","switchToWindow","image","title","getTitle","textToImage","require","titleImage","generate","mergedImage","direction","timeout","then","catch","ew","time","timestamp","msg","level","src","_getStats","commandName","fetchStats","navigationStart","domContentLoaded","load","samePage","lastError","timings","window","timing","domContentLoadedEventStart","loadEventStart","executeError","console","DomContentLoadedEvent","LoadEvent","transaction","counter","Object","keys","filter","getWdioLocator","matchPattern","getElement","getElements","getChildElement","getChildElements","setTimeoutImplicit","restoreTimeoutImplicit","assertArgument","assertArgumentNonEmptyString","assertArgumentNumber","assertArgumentNumberNonNegative","assertArgumentBool","assertArgumentBoolOptional","assertArgumentTimeout","assertArgumentString","types","getLogTypes","getLogs","Symbol","iterator","JSON","stringify","events","msgObj","checkWaitForAngular","autoWaitForAngular","waitForAngular","autoWaitForAngularRootSelector","autoWaitForAngularSoftWait","autoWaitForAngularTimeout","lambdaCredentials","lambdaAutomationClient","lambdaRestClient","AutomationClient","requestBody","status_ind","updateSessionById","tb","TestingBot","api_key","api_secret","testData","updateTest","testDetails","method","json","rejectUnauthorized","res","indexOf","recordVideo","videoFileUrl","fileName","attachments","newVideoAttachment"],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars */\r\n/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\n'use strict';\r\n/**\r\n * @name web\r\n * @description Provides methods for browser automation.\r\n * @sample **Notes:**  \r\n *   \r\n * Commands which operate on elements such as click, assert, waitFor, type, select, and others will automatically wait for a period of time for the element to appear in DOM and become visible. By default this period equals to 60 seconds, but can be changed using the `setTimeout`command.\r\n *   \r\n * **String matching patterns:** \r\n * \r\n *  Commands which expect a string matching pattern in their arguments, support following patterns unless specified otherwise:\r\n * \r\n *  * `regex:PATTERN` - Match using regular expression.\r\n *  * `regexi:PATTERN` - Match using case-insensitive regular expression.\r\n *  * `exact:STRING` - Match the string verbatim.\r\n *  * `glob:PATTERN` - Match using case-insensitive glob pattern. `?` will match any single character except new line \\(\\n\\). `*` will match any sequence \\(0 or more\\) of characters except new line. Empty     PATTERN will match only other empty strings.\r\n *  * `PATTERN` - Same as glob matching.  \r\n *\r\n * **Locators:** \r\n * \r\n *  Commands which expect an element locator in their arguments, support following locator types unless specified otherwise:\r\n * \r\n *  * `id=ID` - Locates element by its ID attribute.\r\n *  * `css=CSS_SELECTOR` - Locates element using a CSS selector.\r\n *  * `link=TEXT` - Locates link element whose visible text matches the given string.\r\n *  * `link-contains=TEXT` - Locates link element whose visible text contains the given string.\r\n *  * `name=NAME` - Locates element by its NAME attribute.\r\n *  * `tag=NAME` - Locates element by its tag name.\r\n *  * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n *  * `(XPATH)[]` - Locates element using an XPath 1.0 expression.\r\n */\r\n\r\n/* eslint-disable quotes */\r\nimport { harFromMessages } from 'chrome-har';\r\nimport URL from 'url';\r\nimport * as wdio from 'webdriverio';\r\nimport WebDriverModule from '../core/WebDriverModule';\r\nimport { defer } from 'when';\r\nimport modUtils from './utils';\r\nimport errHelper from '../errors/helper';\r\nimport OxError from '../errors/OxygenError';\r\nimport util from 'util';\r\nimport SauceLabs from 'saucelabs';\r\nimport lambdaRestClient from '@lambdatest/node-rest-client';\r\nimport TestingBot from 'testingbot-api';\r\nimport { execSync } from 'child_process';\r\nimport perfectoReporting from 'perfecto-reporting';\r\nimport request from 'request';\r\nimport mergeImages from '../lib/img-merge';\r\nimport errorHelper from '../errors/helper';\r\n\r\nconst MODULE_NAME = 'web';\r\nconst DEFAULT_SELENIUM_URL = 'http://localhost:4444/wd/hub';\r\nconst DEFAULT_BROWSER_NAME = 'chrome';\r\nconst DEFAULT_MOBILE_BROWSER = 'default';\r\nconst NO_SCREENSHOT_COMMANDS = ['init', 'assertAlert'];\r\nconst ACTION_COMMANDS = ['open', 'click'];\r\nconst DEFAULT_WAIT_TIMEOUT = 60 * 1000;            // default 60s wait timeout\r\n\r\nexport default class WebModule extends WebDriverModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this.transactions = {};                      // transaction->har dictionary\r\n        this.lastNavigationStartTime = null;\r\n        this.helpers = {};\r\n        this._loadHelperFunctions();\r\n        // support backward compatibility (some module commands might refer to this.OxError and this.errHelper)\r\n        this.OxError = OxError;\r\n        this.errHelper = errHelper;\r\n        // holds element operation timeout value\r\n        this.waitForTimeout = DEFAULT_WAIT_TIMEOUT;\r\n    }\r\n\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @function getDriver\r\n     * @summary Returns the underlying WDIO driver.\r\n     * @return {Object} WDIO driver.\r\n     */\r\n    getDriver() {\r\n        return super.getDriver();\r\n    }\r\n\r\n    /**\r\n     * @function getCapabilities\r\n     * @summary Returns currently defined capabilities.\r\n     * @return {Object} Current capabilities object.\r\n     */\r\n    getCapabilities() {\r\n        return this.caps || super.getCapabilities();\r\n    }\r\n\r\n    /**\r\n     * @function init\r\n     * @summary Initializes new Selenium session.\r\n     * @param {String=} caps - Desired capabilities. If not specified capabilities will be taken from suite definition.\r\n     * @param {String=} seleniumUrl - Remote server URL (default: http://localhost:4444/wd/hub).\r\n     */\r\n    async init(caps, seleniumUrl) {\r\n        if (this.isInitialized) {\r\n            return;\r\n        }\r\n\r\n        if (!seleniumUrl) {\r\n            // if appiumUrl points to an external execution grid (such as BS)\r\n            if (this.options.appiumUrl && !this.options.appiumUrl.startsWith('http://localhost')) {\r\n                seleniumUrl = this.options.appiumUrl;\r\n            }\r\n            else {\r\n                seleniumUrl = this.options.seleniumUrl || DEFAULT_SELENIUM_URL;\r\n            }\r\n        }\r\n\r\n        // take capabilities either from init method argument or from context parameters passed in the constructor\r\n        // merge capabilities from context and from init function argument, give preference to context-passed capabilities\r\n        this.caps = {};\r\n        if (this.ctx.caps) {\r\n            this.caps = { ...this.ctx.caps };\r\n        }\r\n        if (caps) {\r\n            this.caps = { ...this.caps, ...caps };\r\n        }\r\n\r\n        // populate browserName caps from options. FIXME: why is this even needed?\r\n        let defaultBrowser = false;\r\n        if (!this.caps.browserName) {\r\n            this.caps.browserName = this.options.browserName || DEFAULT_BROWSER_NAME;\r\n            defaultBrowser = true;\r\n        }\r\n        // FIXME: shall we throw an exception if browserName is not specified, neither in caps nor in options?!\r\n        if (!this.caps.browserName) {\r\n            throw new OxError(errHelper.errorCode.INVALID_CAPABILITIES,\r\n                'Failed to initialize `web` module - browserName must be specified.');\r\n        }\r\n\r\n        // adjust browserName-s\r\n        if (this.caps.browserName.toLowerCase() === 'ie') {\r\n            // IE is specified as 'ie' through the command line and possibly suites\r\n            // but selenium standalone server expects 'internet explorer'\r\n            this.caps.browserName = 'internet explorer';\r\n        } else if (this.caps['lambda:options']) {\r\n            // lambdatest expects original case names\r\n        } else if (this.caps['perfectoMobile:options']) {\r\n            // perfectoMobile expects original case names\r\n        } else if (this.caps.browserName !== 'MicrosoftEdge') {\r\n            // selenium standalone server expects all browserNames to be lowercase\r\n            // except \"MicrosoftEdge\"\r\n            this.caps.browserName = this.caps.browserName.toLowerCase();\r\n        }\r\n\r\n        // adjust capabilities to enable collecting browser and performance stats in Chrome \r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            this.caps['goog:loggingPrefs'] = {     // for ChromeDriver >= 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n            /*\r\n            // specifying this leads Chrome 77+ to refuse loading\r\n            this.caps.loggingPrefs = {             // for ChromeDriver < 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n            this.caps.chromeOptions = {\r\n                perfLoggingPrefs: {\r\n                    enableNetwork: true,\r\n                    enablePage: false\r\n                }\r\n            };\r\n            */\r\n        }\r\n\r\n        // populate WDIO options\r\n        const url = URL.parse(seleniumUrl || DEFAULT_SELENIUM_URL);\r\n        const protocol = url.protocol.replace(/:$/, '');\r\n        const host = url.hostname;\r\n        const port = parseInt(url.port || (protocol === 'https' ? 443 : 80));\r\n        const path = url.pathname;\r\n\r\n        // auth is needed mostly for cloud providers such as LambdaTest\r\n        if (url.auth) {\r\n            const auth = url.auth.split(':');\r\n            this.options.wdioOpts = {\r\n                user: auth[0],\r\n                key: auth[1]\r\n            };\r\n        }\r\n        this.seleniumUrlBase = `${protocol}://${host}:${port}`;\r\n        // check if selenium hub is based on Selenoid, then enable video recording\r\n        this.isRunningOnSelenoid = await this._isSelenoidHub(this.seleniumUrlBase);\r\n        if (this.isRunningOnSelenoid) {\r\n            if (!this.caps['selenoid:options']) {\r\n                this.caps['selenoid:options'] = {};\r\n            }\r\n            if (this.caps['selenoid:options'].enableVideo === undefined) {\r\n                this.caps['selenoid:options'].enableVideo = true;\r\n                this.caps['selenoid:options'].videoFrameRate = 4;\r\n            }\r\n        }\r\n        // generate Webdriver.io options\r\n        const wdioOpts = {\r\n            ...this.options.wdioOpts || {},\r\n            protocol: protocol,\r\n            hostname: host,\r\n            port: port,\r\n            path: path,\r\n            capabilities: this.caps,\r\n            logLevel: 'silent',\r\n            runner: 'repl',\r\n            waitforTimeout: 5000, // increase the default 3000\r\n            connectionRetryTimeout: 310*1000,\r\n            connectionRetryCount: 1\r\n        };\r\n\r\n        let initError = null;\r\n        const _this = this;\r\n        const provider = modUtils.determineProvider(wdioOpts);\r\n\r\n        if (provider === modUtils.provider.PERFECTO) {\r\n            wdioOpts.path = '/nexperience/perfectomobile/wd/hub';\r\n            wdioOpts.port = 80;\r\n            wdioOpts.protocol = 'http';\r\n            wdioOpts.openDeviceTimeout = 15;\r\n        }\r\n\r\n        let name = 'name';\r\n        if (wdioOpts.capabilities['perfectoMobile:options'] && wdioOpts.capabilities['perfectoMobile:options']['name']) {\r\n            name = wdioOpts.capabilities['perfectoMobile:options']['name'];\r\n            delete wdioOpts.capabilities['perfectoMobile:options'];\r\n        }\r\n        if (wdioOpts.capabilities['lambda:options'] && wdioOpts.capabilities['lambda:options']['name']) {\r\n            name = wdioOpts.capabilities['lambda:options']['name'];\r\n            delete wdioOpts.capabilities['lambda:options'];\r\n        }\r\n        if (wdioOpts.capabilities['testingBot:options'] && wdioOpts.capabilities['testingBot:options']['name']) {\r\n            name = wdioOpts.capabilities['testingBot:options']['name'];\r\n            delete wdioOpts.capabilities['testingBot:options'];\r\n        }\r\n        if (wdioOpts.capabilities['bstack:options'] && wdioOpts.capabilities['bstack:options']['name']) {\r\n            name = wdioOpts.capabilities['bstack:options']['name'];\r\n            delete wdioOpts.capabilities['bstack:options'];\r\n        }\r\n        // set default browser for mobile web tests, if executed against remote devices of a cloud provider\r\n        if (defaultBrowser && provider) {\r\n            this.caps.browserName = wdioOpts.capabilities.browserName = DEFAULT_MOBILE_BROWSER;\r\n        }\r\n        this.wdioOpts = wdioOpts;\r\n        try {\r\n            this.driver = await wdio.remote(wdioOpts);\r\n            this.sessionId = this.driver.sessionId;\r\n            this.driver.provider = provider;\r\n\r\n            if (this.options.seleniumBrowserTimeout) {\r\n                this.driver.seleniumBrowserTimeout = this.options.seleniumBrowserTimeout;\r\n            }\r\n\r\n            if (this.options.seleniumTimeout) {\r\n                this.driver.seleniumTimeout = this.options.seleniumTimeout;\r\n            }\r\n\r\n            if (provider === modUtils.provider.PERFECTO) {\r\n                const perfectoExecutionContext = await new perfectoReporting.Perfecto.PerfectoExecutionContext({\r\n                    webdriver: {\r\n                        executeScript: async (command, params) => {\r\n                            return await this.driver.execute(command, params);\r\n                        }\r\n                    }\r\n                });\r\n                this.reportingClient = new perfectoReporting.Perfecto.PerfectoReportingClient(perfectoExecutionContext);\r\n                await this.reportingClient.testStart(name);\r\n            }\r\n        }\r\n        catch (e) {\r\n            throw errHelper.getSeleniumInitError(e);\r\n        }\r\n\r\n        // reset browser logs if auto collect logs option is enabled\r\n        if (this.options.collectBrowserLogs && this.caps.browserName === 'chrome') {\r\n            try {\r\n                // simply call this to clear the previous logs and start the test with the clean logs\r\n                await this.getBrowserLogs();\r\n            } catch (e) {\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n\r\n        try {\r\n            if (\r\n                [modUtils.provider.LAMBDATEST, modUtils.provider.BROWSERSTACK, modUtils.provider.PERFECTO].includes(this.driver.provider)\r\n                //['MicrosoftEdge', 'msedge', 'Edge', 'Internet Explorer'].includes(this.driver.capabilities.browserName)\r\n            ) {\r\n                // do not maximize window if the test is executed against external cloud provider infrastructure\r\n                // as most of cloud providers do not support this functionality\r\n            } else {\r\n                // maximize browser window\r\n                await this.driver.maximizeWindow();\r\n                // set initial Timeout\r\n                await this.driver.setTimeout({\r\n                    'implicit': this.waitForTimeout,\r\n                    'pageLoad': this.waitForTimeout\r\n                });\r\n            }\r\n\r\n        } catch (err) {\r\n            throw new OxError(errHelper.errorCode.UNKNOWN_ERROR, err.message, util.inspect(err));\r\n        }\r\n        super.init(this.driver);\r\n    }\r\n\r\n    /**\r\n     * @function dispose\r\n     * @summary Ends the current session.\r\n     * @param {String=} status - Test status, either `passed` or `failed`.\r\n     */\r\n    async dispose(status) {\r\n        this.transactions = {};\r\n        this._whenWebModuleDispose = defer();\r\n\r\n        if (!status) {\r\n            status = 'passed';\r\n\r\n            if (this.rs.steps && Array.isArray(this.rs.steps) && this.rs.steps.length > 0) {\r\n                const failedFinded = this.rs.steps.find((item) => item.status === 'failed');\r\n                if (failedFinded) {\r\n                    status = 'failed';\r\n                }\r\n            }\r\n        }\r\n\r\n        if (this.driver && this.isInitialized) {\r\n            try {\r\n                status = status.toUpperCase();\r\n\r\n                if (this.driver.provider === modUtils.provider.SAUCELABS) {\r\n                    const username = this.wdioOpts.capabilities['sauce:options']['username'];\r\n                    const accessKey = this.wdioOpts.capabilities['sauce:options']['accessKey'];\r\n                    const passed = status === 'PASSED';\r\n                    const id = this.driver.sessionId;\r\n                    const body = \"{\\\"passed\\\":\"+passed+\"}\";\r\n\r\n                    const myAccount = new SauceLabs({ user: username, key: accessKey});\r\n                    await myAccount.updateJob(username, id, body);\r\n                    await myAccount.stopJob(username, id);\r\n                } else if (this.driver.provider === modUtils.provider.LAMBDATEST) {\r\n                    await this._sendResultStatusToLambdaTest(status);\r\n                    await this.deleteSession();\r\n                } else if (this.driver.provider === modUtils.provider.TESTINGBOT) {\r\n                    await this._sendResultStatusToTestingBot(status);\r\n                    await this.deleteSession();\r\n                } else if (this.driver.provider === modUtils.provider.PERFECTO) {\r\n                    await this.reportingClient.testStop({\r\n                        status: status === 'PASSED' ?\r\n                                    perfectoReporting.Constants.results.passed :\r\n                                    perfectoReporting.Constants.results.failed\r\n                    });\r\n                } else if (this.driver.provider === modUtils.provider.BROWSERSTACK) {\r\n                    await this._sendResultStatusToBrowserstack(status);\r\n                    await this.deleteSession();\r\n                }\r\n\r\n                if (this.driver.provider === null && ['PASSED','FAILED'].includes(status)) {\r\n                    await this.closeBrowserWindows(status);\r\n                } else {\r\n                    // canceled or other status\r\n                    this.disposeContinue();\r\n                }\r\n            } catch (e) {\r\n                this.logger.warn('Error disposing driver: ', e);    // ignore any errors at disposal stage\r\n            }\r\n        } else {\r\n            this.disposeContinue();\r\n        }\r\n\r\n        return this._whenWebModuleDispose.promise;\r\n    }\r\n\r\n    async deleteSession() {\r\n        try {\r\n            if (this.driver && this.driver.deleteSession) {\r\n                if (this.seleniumSessionTimeout) {\r\n                    // ignore\r\n                    // deleteSession will take 5 min to call\r\n                } else {\r\n                    await this.driver.deleteSession();\r\n                }\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('deleteSession error', e);\r\n        }\r\n    }\r\n\r\n    async closeBrowserWindows(status) {\r\n        if (status && 'FAILED' === status.toUpperCase() && this.options && this.options.seleniumPid) {\r\n            this.disposeContinue(status);\r\n        } else {\r\n            await this.deleteSession();\r\n            this.disposeContinue();\r\n        }\r\n    }\r\n\r\n    disposeContinue(status) {\r\n        this.driver = null;\r\n        this.lastNavigationStartTime = null;\r\n        super.dispose();\r\n\r\n        // cleanup chromedriver's only when running from within the IDE and test did not fail\r\n        if (this.options && this.options.seleniumPid && (!status || 'FAILED' !== status.toUpperCase())) {\r\n            try {\r\n                if (process.platform === 'win32') {\r\n                    execSync('taskkill /IM chromedriver.exe /F', { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                } else {\r\n                    let pgrepResult = execSync(\"pgrep -d' ' chromedriver\");\r\n                    if (pgrepResult && pgrepResult.toString) {\r\n                        pgrepResult = pgrepResult.toString();\r\n                        if (pgrepResult) {\r\n                            execSync('kill -9 ' + pgrepResult, { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                        }\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n            }\r\n        }\r\n\r\n        // cleanup edgedriver's only when running from within the IDE and test did not fail\r\n        if (this.options && this.options.seleniumPid && (!status || 'FAILED' !== status.toUpperCase())) {\r\n            try {\r\n                if (process.platform === 'win32') {\r\n                    // ignore for now\r\n                } else {\r\n                    let pgrepResult = execSync(\"pgrep -d' ' msedgedriver\");\r\n                    if (pgrepResult && pgrepResult.toString) {\r\n                        pgrepResult = pgrepResult.toString();\r\n                        if (pgrepResult) {\r\n                            execSync('kill -9 ' + pgrepResult, { stdio: ['ignore', 'ignore', 'ignore'] });\r\n                        }\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n            }\r\n        }\r\n\r\n        this._whenWebModuleDispose.resolve(null);\r\n    }\r\n\r\n    _iterationStart() {\r\n        // clear transaction name saved in previous iteration if any\r\n        global._lastTransactionName = null;\r\n    }\r\n\r\n    async _iterationEnd(error) {\r\n        if (error && error.type === errorHelper.errorCode.SELENIUM_SESSION_TIMEOUT) {\r\n            this.seleniumSessionTimeout = true;\r\n            return;\r\n        } else {\r\n            this.seleniumSessionTimeout = false;\r\n        }\r\n\r\n        if (!this.isInitialized) {\r\n            return;\r\n        }\r\n        // collect browser logs for this session\r\n        if (this.options.collectBrowserLogs === true && this.caps.browserName === 'chrome') {\r\n            try {\r\n                const logs = await this.getBrowserLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (var log of logs) {\r\n                        this.rs.logs.push(this._adjustBrowserLog(log));\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n        // TODO: should clear transactions to avoid duplicate names across iterations\r\n        // also should throw on duplicate names.\r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            // there might be no transactions set if test fails before web.transaction command\r\n            if (global._lastTransactionName) {\r\n                this.transactions[global._lastTransactionName] = await this._getHAR();\r\n            }\r\n        }\r\n\r\n        this.rs.har = this.transactions;\r\n        const hasFailed = error !== undefined && error !== null;\r\n        this._addSelenoidVideoAsTestAttachment(hasFailed);\r\n    }\r\n\r\n    _isAction(name) {\r\n        return ACTION_COMMANDS.includes(name);\r\n    }\r\n\r\n    _takeScreenshotSilent(name) {\r\n        if (!NO_SCREENSHOT_COMMANDS.includes(name)) {\r\n            let error;\r\n            try {\r\n                if (\r\n                    this.driver &&\r\n                    this.driver.takeScreenshot\r\n                ) {\r\n                    let retval;\r\n                    this.driver.call(() => {\r\n                        return new Promise((resolve, reject) => {\r\n                            try {\r\n                                const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                                    try {\r\n                                        let images = [];\r\n\r\n                                        // collect all (screenshot and title) images\r\n                                        const handles = await this.driver.getWindowHandles();\r\n                                        if (Array.isArray(handles) && handles.length > 0) {\r\n                                            for (const handle of handles) {\r\n                                                await this.driver.switchToWindow(handle);\r\n                                                const image = await this.driver.takeScreenshot();\r\n                                                const title = await this.driver.getTitle();\r\n\r\n                                                if (title) {\r\n                                                    const textToImage = require('../lib/text-to-image');\r\n                                                    let titleImage = await textToImage.generate(title);\r\n                                                    if (titleImage && typeof titleImage === 'string') {\r\n                                                        titleImage = titleImage.replace('data:image/png;base64,', '');\r\n                                                        images.push(titleImage);\r\n                                                    }\r\n                                                }\r\n\r\n                                                images.push(image);\r\n                                            }\r\n                                        }\r\n\r\n                                        // merge all images into one\r\n                                        const mergedImage = await mergeImages(images, { direction: true });\r\n                                        if (mergedImage && typeof mergedImage === 'string') {\r\n                                            retval = mergedImage.replace('data:image/jpeg;base64,', '');\r\n                                        }\r\n\r\n                                        return true;\r\n                                    } catch (e) {\r\n                                        error = e;\r\n                                        return false;\r\n                                    }\r\n                                },\r\n                                { timeout: 30*1000 });\r\n\r\n                                if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                                    waitUntilRetVal.then(() => {\r\n                                        resolve();\r\n                                    }).catch((err) => {\r\n                                        reject(err);\r\n                                    });\r\n                                } else {\r\n                                    resolve();\r\n                                }\r\n                            } catch (ew) {\r\n                                this.logger.error('Cannot get screenshot (1)', error);\r\n                            }\r\n                        });\r\n                    });\r\n\r\n                    if (error) {\r\n                        this.logger.error('Cannot get screenshot (2)', error);\r\n                    }\r\n\r\n                    return retval;\r\n                }\r\n            } catch (e) {\r\n                this.logger.error('Cannot get screenshot (3)', e);\r\n                if (error) {\r\n                    this.logger.error('Cannot get screenshot inner error', error);\r\n                }\r\n                // ignore\r\n            }\r\n        }\r\n    }\r\n\r\n    _adjustBrowserLog(log) {\r\n        if (!log || typeof log !== 'object') {\r\n            return null;\r\n        }\r\n        // TODO: convert log.timestamp from the browser time zone to the local one (so we can later correlate between steps and logs)\r\n        return {\r\n            time: log.timestamp,\r\n            msg: log.message,\r\n            // convert SEVERE log level to ERROR\r\n            level: log.level === 'SEVERE' ? 'ERROR' : log.level,\r\n            src: 'browser'\r\n        };\r\n    }\r\n\r\n    /*\r\n     * FIXME: There is a bug with IE. See the comment within function body.\r\n     *\r\n     *  domContentLoaded (aka First Visual Time)- Represents the difference between domContentLoadedEventStart and navigationStart.\r\n     *  load (aka Full Load Time)               - Represents the difference between loadEventStart and navigationStart.\r\n     *\r\n     * The processing model:\r\n     *\r\n     *  1. navigationStart              - The browser has requested the document.\r\n     *  2. ...                          - Not relevant to us. See http://www.w3.org/TR/navigation-timing/#process for more information.\r\n     *  3. domLoading                   - The browser starts parsing the document.\r\n     *  4. domInteractive               - The browser has finished parsing the document and the user can interact with the page.\r\n     *  5. domContentLoadedEventStart   - The document has been completely loaded and parsed and deferred scripts, if any, have executed. \r\n     *                                    Async scripts, if any, might or might not have executed.\r\n     *                                    Stylesheets[1], images, and subframes might or might not have finished loading.\r\n     *                                      [1] - Stylesheets /usually/ defer this event! - http://molily.de/weblog/domcontentloaded\r\n     *  6. domContentLoadedEventEnd     - The DOMContentLoaded event callback, if any, finished executing. E.g.\r\n     *                                      document.addEventListener(\"DOMContentLoaded\", function(event) {\r\n     *                                          console.log(\"DOM fully loaded and parsed\");\r\n     *                                      });\r\n     *  7. domComplete                  - The DOM tree is completely built. Async scripts, if any, have executed.\r\n     *  8. loadEventStart               - The browser have finished loading all the resources like images, swf, etc.\r\n     *  9. loadEventEnd                 - The load event callback, if any, finished executing.\r\n     */\r\n    _getStats(commandName) {\r\n        if (this.options.fetchStats && this.isInitialized && this._isAction(commandName)) {\r\n            var navigationStart;\r\n            var domContentLoaded = 0;\r\n            var load = 0;\r\n            var samePage = false;\r\n\r\n            // TODO: handle following situation:\r\n            // if navigateStart equals to the one we got from previous attempt (we need to save it)\r\n            // it means we are still on the same page and don't need to record load/domContentLoaded times\r\n            try {\r\n                this.driver.call(() => {\r\n                    return new Promise((resolve, reject) => {\r\n                        let lastError = false;\r\n                        const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                            try {\r\n                                /*global window*/\r\n                                var timings = await this.driver.execute(function() {\r\n                                    return {\r\n                                        navigationStart: window.performance.timing.navigationStart,\r\n                                        domContentLoadedEventStart: window.performance.timing.domContentLoadedEventStart,\r\n                                        loadEventStart: window.performance.timing.loadEventStart\r\n                                    };\r\n                                });\r\n                                lastError = false;\r\n\r\n                                if (timings.domContentLoadedEventStart > 0 && timings.loadEventStart > 0) {\r\n                                    samePage = this.lastNavigationStartTime && this.lastNavigationStartTime == timings.navigationStart;\r\n                                    navigationStart = this.lastNavigationStartTime = timings.navigationStart;\r\n                                    var domContentLoadedEventStart = timings.domContentLoadedEventStart;\r\n                                    var loadEventStart = timings.loadEventStart;\r\n\r\n                                    domContentLoaded = domContentLoadedEventStart - navigationStart;\r\n                                    load = loadEventStart - navigationStart;\r\n\r\n                                    return domContentLoadedEventStart > 0 && loadEventStart > 0;\r\n                                } else {\r\n                                    return false;\r\n                                }\r\n                            } catch (executeError) {\r\n                                // collect error inside driver.execute or driver.waitUntil\r\n                                lastError = executeError;\r\n                            }\r\n                        },\r\n                        { timeout: 30*1000 });\r\n\r\n                        if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                            waitUntilRetVal.then(() => {\r\n                                if (lastError) {\r\n                                    // print error from driver.execute or driver.waitUntil\r\n                                    console.log(lastError);\r\n                                }\r\n                                resolve();\r\n                            }).catch((err) => {\r\n                                if (lastError) {\r\n                                    // print error from driver.execute or driver.waitUntil\r\n                                    console.log(lastError);\r\n                                }\r\n                                reject(err);\r\n                            });\r\n                        } else {\r\n                            resolve();\r\n                        }\r\n                    });\r\n                });\r\n            } catch (e) {\r\n                return {};\r\n                // couldn't get timings.\r\n            }\r\n\r\n            this.lastNavigationStartTime = navigationStart;\r\n\r\n            return samePage ? {} : { DomContentLoadedEvent: domContentLoaded, LoadEvent: load };\r\n        }\r\n\r\n        return {};\r\n    }\r\n\r\n    /**\r\n     * @summary Opens new transaction.\r\n     * @description The transaction will persist till 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\r\n        if (global._lastTransactionName) {\r\n            this.transactions[global._lastTransactionName] = null;\r\n\r\n            if (this.options.recordHAR && this.isInitialized && this.caps.browserName === 'chrome') {\r\n                this.transactions[global._lastTransactionName] = await this._getHAR();\r\n            }\r\n        }\r\n\r\n        if (typeof this.transactions[name] !== 'undefined') {\r\n            const counter = Object.keys(this.transactions).filter((item) => item.startsWith(name)).length + 1;\r\n            global._lastTransactionName = name+' (#'+counter+')';\r\n        } else {\r\n            global._lastTransactionName = name;\r\n        }\r\n    }\r\n\r\n    _loadHelperFunctions() {\r\n        this.helpers.getWdioLocator = modUtils.getWdioLocator;\r\n        this.helpers.matchPattern = modUtils.matchPattern;\r\n        this.helpers.getElement = modUtils.getElement;\r\n        this.helpers.getElements = modUtils.getElements;\r\n        this.helpers.getChildElement = modUtils.getChildElement;\r\n        this.helpers.getChildElements = modUtils.getChildElements;\r\n        this.helpers.setTimeoutImplicit = modUtils.setTimeoutImplicit;\r\n        this.helpers.restoreTimeoutImplicit = modUtils.restoreTimeoutImplicit;\r\n        this.helpers.assertArgument = modUtils.assertArgument;\r\n        this.helpers.assertArgumentNonEmptyString = modUtils.assertArgumentNonEmptyString;\r\n        this.helpers.assertArgumentNumber = modUtils.assertArgumentNumber;\r\n        this.helpers.assertArgumentNumberNonNegative = modUtils.assertArgumentNumberNonNegative;\r\n        this.helpers.assertArgumentBool = modUtils.assertArgumentBool;\r\n        this.helpers.assertArgumentBoolOptional = modUtils.assertArgumentBoolOptional;\r\n        this.helpers.assertArgumentTimeout = modUtils.assertArgumentTimeout;\r\n        this.helpers.assertArgumentString = modUtils.assertArgumentString;\r\n    }\r\n\r\n    async _getHAR() {\r\n        try {\r\n            const types = await this.driver.getLogTypes();\r\n\r\n            if (types.includes('performance')) {\r\n                const logs = await this.driver.getLogs('performance');\r\n\r\n                // in one instance, logs was not iterable for some reason - hence the following check:\r\n                if (!logs || typeof logs[Symbol.iterator] !== 'function') {\r\n                    this.logger.error('getHAR: logs not iterable: ' + JSON.stringify(logs));\r\n                    return null;\r\n                }\r\n\r\n                const events = [];\r\n                for (let log of logs) {\r\n                    const msgObj = JSON.parse(log.message);   // returned as string\r\n                    events.push(msgObj.message);\r\n                }\r\n\r\n                const har = harFromMessages(events);\r\n                return JSON.stringify(har);\r\n            } else {\r\n                return null;\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('Unable to fetch HAR: ' + e.toString());\r\n            return null;\r\n        }\r\n    }\r\n\r\n    async checkWaitForAngular() {\r\n        if (this.autoWaitForAngular) {\r\n            await this.waitForAngular(this.autoWaitForAngularRootSelector, this.autoWaitForAngularSoftWait, this.autoWaitForAngularTimeout);\r\n        }\r\n    }\r\n\r\n    async _sendResultStatusToLambdaTest(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const lambdaCredentials = {\r\n                username: this.wdioOpts.user,\r\n                accessKey: this.wdioOpts.key\r\n            };\r\n            const sessionId = this.driver.sessionId;\r\n            const lambdaAutomationClient = lambdaRestClient.AutomationClient(\r\n                lambdaCredentials\r\n            );\r\n            const requestBody = {\r\n                status_ind: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n            try {\r\n                lambdaAutomationClient.updateSessionById(sessionId, requestBody, (error) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to LambdaTest: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _sendResultStatusToTestingBot(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const sessionId = this.driver.sessionId;\r\n            const tb = new TestingBot({\r\n                api_key: this.wdioOpts.user,\r\n                api_secret: this.wdioOpts.key\r\n            });\r\n            const testData = { \"test[success]\" : status === 'PASSED' ? \"1\" : \"0\" };\r\n            try {\r\n                tb.updateTest(testData, sessionId, function(error, testDetails) {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to TestingBot: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _sendResultStatusToBrowserstack(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const requestBody = {\r\n                status: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n\r\n            const options = {\r\n                url: `https://api.browserstack.com/automate/sessions/${this.driver.sessionId}.json`,\r\n                method: 'PUT',\r\n                json: true,\r\n                rejectUnauthorized: false,\r\n                body: requestBody,\r\n                'auth': {\r\n                    'user': this.wdioOpts.user,\r\n                    'pass': this.wdioOpts.key,\r\n                    'sendImmediately': false\r\n                },\r\n            };\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    async _isSelenoidHub(seleniumUrl) {\r\n        return new Promise((resolve, reject) => {\r\n            const options = {\r\n                url: `${seleniumUrl}`,\r\n                method: 'GET',\r\n                json: false,\r\n                rejectUnauthorized: false,\r\n            };\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    if (err) {\r\n                        reject(err);\r\n                    }\r\n                    else {\r\n                        if (body && body.length && body.indexOf('You are using Selenoid') > -1) {\r\n                            resolve(true);\r\n                        }\r\n                        else {\r\n                            resolve(false);\r\n                        }\r\n                    }\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n\r\n    // if the test is running inside Selenoid, then download the video if test has failed\r\n    async _addSelenoidVideoAsTestAttachment(hasFailed = false) {\r\n        if (!this.isRunningOnSelenoid) {\r\n            return;\r\n        }\r\n        if (!this.options.recordVideo && !hasFailed) {\r\n            return;\r\n        }\r\n        const videoFileUrl = `${this.seleniumUrlBase}/video/${this.sessionId}.mp4`;\r\n        const fileName = `${this.sessionId}.mp4`;\r\n        this.rs.attachments.push(modUtils.newVideoAttachment(fileName, videoFileUrl));\r\n    }\r\n}\r\n\r\n"]}
@@ -463,19 +463,19 @@ class OxygenRunner extends _events.EventEmitter {
463
463
  const reRun = reRunCount > 0;
464
464
 
465
465
  if (suite.paramManager) {
466
- _lodash.default.extend(params, suite.paramManager.getValues());
467
-
468
- if (!reRun) {
469
- suite.paramManager.readNext();
466
+ if (reRun) {
467
+ suite.paramManager.readPrev();
470
468
  }
469
+
470
+ _lodash.default.extend(params, suite.paramManager.getValues());
471
471
  }
472
472
 
473
473
  if (caze.paramManager) {
474
- _lodash.default.extend(params, caze.paramManager.getValues());
475
-
476
- if (!reRun) {
477
- caze.paramManager.readNext();
474
+ if (reRun) {
475
+ caze.paramManager.readPrev();
478
476
  }
477
+
478
+ _lodash.default.extend(params, caze.paramManager.getValues());
479
479
  }
480
480
 
481
481
  if (this._debugMode && this._worker && this._worker.debugger && caze.breakpoints) {
@@ -505,6 +505,15 @@ class OxygenRunner extends _events.EventEmitter {
505
505
  caseResult.duration = 0;
506
506
  caseResult.failure = _helper.default.getFailureFromError(e);
507
507
  caseResult.status = _status.default.FAILED;
508
+
509
+ if (suite.paramManager) {
510
+ suite.paramManager.readNext();
511
+ }
512
+
513
+ if (caze.paramManager) {
514
+ caze.paramManager.readNext();
515
+ }
516
+
508
517
  return caseResult;
509
518
  }
510
519
 
@@ -562,6 +571,15 @@ class OxygenRunner extends _events.EventEmitter {
562
571
 
563
572
  const disposeOxygenModules = typeof this._options.autoDispose !== 'boolean' || this._options.autoDispose === true;
564
573
  await this._worker_endSession(caseResult.status, disposeOxygenModules);
574
+
575
+ if (suite.paramManager) {
576
+ suite.paramManager.readNext();
577
+ }
578
+
579
+ if (caze.paramManager) {
580
+ caze.paramManager.readNext();
581
+ }
582
+
565
583
  return caseResult;
566
584
  }
567
585
 
@@ -865,4 +883,4 @@ class OxygenRunner extends _events.EventEmitter {
865
883
  }
866
884
 
867
885
  exports.default = OxygenRunner;
868
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/runners/oxygen/index.js"],"names":["log","DEFAULT_ISSUER","MAX_RERUNS","snooze","ms","Promise","resolve","setTimeout","getSuitesBreakpoints","suites","retval","Array","isArray","length","map","suite","cases","caze","breakpoints","breakpoint","push","removeBreakpointFromSuites","removeBreakpoint","idx","file","line","splice","OxygenRunner","EventEmitter","constructor","options","_id","oxutil","generateUniqueId","_isRunning","_isInitializing","_isDisposing","_worker","_debugMode","_workerProcLastError","_npmGRootExecution","npmGRootExecution","_suite","_envVars","_vars","_caps","_modCaps","_attributes","_options","_localTime","_testKilled","_scriptContentLineOffset","_whenDisposed","getId","init","caps","reporter","Error","_cwd","cwd","process","_reporter","_isInitialized","optEnv","env","envs","Object","keys","envVars","_env","testAttributes","_suites","debugPortIde","debugPort","_debugPort","scriptContentLineOffset","localTime","_startWorkerProcess","_worker_InitOxygen","dispose","status","stopDebugger","isRunning","stop","e","console","warn","_resetGlobalVariables","run","onRunnerStart","error","result","_runTest","failure","onRunnerEnd","kill","debugContinue","debugger","continue","updateBreakpoints","filePath","setBreakpointsActive","promises","tsBreakpoints","getBreakpoints","suitesBreakpoints","suiteBp","includes","actualCurrentBp","removeBreakpointByValue","userSetBp","setBreakpoint","promiseAllPromise","all","then","value","debug","breakpointsAferManipulations","replClose","_send","event","name","replSend","cmd","content","replStart","invoke","clearBreakpoint","TestResult","startTime","getTimeStamp","Status","PASSED","_worker_callBeforeTestHook","suiteResult","_runSuite","endTime","duration","hasFailedSuites","some","suiteIterations","x","FAILED","environment","capabilities","errorHelper","getFailureFromError","_worker_callAfterTestHook","path","iterationCount","showSuiteIterationsMessages","reRunOnFailure","reRunOnFailed","suiteIteration","onIterationStart","TestSuiteResult","getFileNameWithoutExt","iterationNum","_worker_callBeforeSuiteHook","onSuiteStart","uri","caseIteration","showCaseIterationsMessages","onCaseStart","id","caseResult","reRunCount","_runCase","onCaseEnd","onIterationEnd","WARNING","_worker_callAfterSuiteHook","onSuiteEnd","params","reRun","paramManager","_","extend","getValues","readNext","i","_worker_callBeforeCaseHook","TestCaseResult","location","_worker_startSession","resultStore","context","moduleCaps","_worker_Run","_processTestResults","steps","logs","har","attributes","attachments","failedSteps","find","warningSteps","isEmpty","makeTransactionFailedIfStepFailed","_worker_callAfterCaseHook","disposeOxygenModules","autoDispose","_worker_endSession","_whenTestCaseFinished","reject","scriptName","scriptPath","vars","test","case","iteration","poFile","po","initOxygen","startSession","disposeModules","endSession","invokeTestHook","onLogEntry","workerPath","join","__dirname","WorkerProcess","start","_hookWorkerEvents","startDebugger","_hookWorkerDebuggerEvents","_this","subscribe","_handleBeforeCommand","bind","_handleAfterCommand","on","payload","exitDone","emit","exitCode","promise","OxygenError","errorCode","SCRIPT_ERROR","msg","level","info","err","time","src","stack","method","breakpointData","breakError","onStepStart","module","onStepEnd","_emitIterationEnd","ts","tc","suiteIterationNum","caseIterationNum","caseIterationResult","_status","_emitTestEnd"],"mappings":"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","sourcesContent":["/* eslint-disable no-async-promise-executor */\r\n/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\nimport logger from '../../lib/logger';\r\nconst log = logger('OxygenRunner');\r\nconst DEFAULT_ISSUER = 'user';\r\nconst MAX_RERUNS = 2;\r\n\r\nimport { EventEmitter } from 'events';\r\nimport _  from 'lodash';\r\nimport { defer } from 'when';\r\nimport path from 'path';\r\n\r\nimport TestSuiteResult from '../../model/suite-result';\r\nimport TestCaseResult from '../../model/case-result';\r\nimport TestResult from '../../model/test-result';\r\nimport Status from '../../model/status';\r\nimport oxutil from '../../lib/util';\r\nimport errorHelper from '../../errors/helper';\r\nimport OxygenError from '../../errors/OxygenError';\r\nimport ParameterManager from '../../lib/param-manager.js';\r\nimport WorkerProcess from '../WorkerProcess';\r\n\r\n// snooze function - async wrapper around setTimeout function\r\nconst snooze = ms => new Promise(resolve => setTimeout(resolve, ms));\r\n\r\nconst getSuitesBreakpoints = (suites) => {\r\n    const retval = [];\r\n\r\n    if (\r\n        suites &&\r\n        Array.isArray(suites) &&\r\n        suites.length > 0\r\n    ) {\r\n        suites.map((suite) => {\r\n            if (\r\n                suite &&\r\n                suite.cases &&\r\n                Array.isArray(suite.cases) &&\r\n                suite.cases.length > 0\r\n            ) {\r\n                suite.cases.map((caze) => {\r\n                    if (\r\n                        caze &&\r\n                        caze.breakpoints &&\r\n                        Array.isArray(caze.breakpoints) &&\r\n                        caze.breakpoints.length > 0\r\n                    ) {\r\n                        caze.breakpoints.map((breakpoint) => {\r\n                            retval.push(breakpoint);\r\n                        });\r\n                    }\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n    return retval;\r\n};\r\n\r\nconst removeBreakpointFromSuites = (suites, removeBreakpoint) => {\r\n    if (\r\n        suites &&\r\n        Array.isArray(suites) &&\r\n        suites.length > 0\r\n    ) {\r\n        suites.map((suite) => {\r\n            if (\r\n                suite &&\r\n                suite.cases &&\r\n                Array.isArray(suite.cases) &&\r\n                suite.cases.length > 0\r\n            ) {\r\n                suite.cases.map((caze) => {\r\n                    if (\r\n                        caze &&\r\n                        caze.breakpoints &&\r\n                        Array.isArray(caze.breakpoints) &&\r\n                        caze.breakpoints.length > 0\r\n                    ) {\r\n                        caze.breakpoints.map((breakpoint, idx) => {\r\n                            if (\r\n                                breakpoint.file === removeBreakpoint.file &&\r\n                                breakpoint.line === removeBreakpoint.line\r\n                            ) {\r\n                                caze.breakpoints.splice(idx, 1);\r\n                            }\r\n                        });\r\n                    }\r\n                });\r\n            }\r\n        });\r\n    }\r\n};\r\n\r\nexport default class OxygenRunner extends EventEmitter {\r\n    constructor(options) {\r\n        super();\r\n        // class variables\r\n        this._id = oxutil.generateUniqueId();\r\n        this._isRunning = false;\r\n        this._isInitializing = false;\r\n        this._isDisposing = false;\r\n        this._worker = null;\r\n        this._debugMode = false;\r\n        this._workerProcLastError = null;\r\n\r\n        this._npmGRootExecution = true;\r\n        if (options && typeof options.npmGRootExecution !== 'undefined') {\r\n            this._npmGRootExecution = options.npmGRootExecution;\r\n        }\r\n\r\n        // define variables to iterate through test cases and test suite iterations\r\n        this._suite;\r\n        this._envVars = {};  // environment variables passed at the beginning of the test\r\n        this._vars = {};     // user-defined variables that are shared between different scripts\r\n        this._caps = {}; // desired capabilities that are passed to each module\r\n        this._modCaps = {};\r\n        this._attributes = {};\r\n        this._options = null;\r\n        this._localTime = false;\r\n        this._testKilled = false;\r\n        this._scriptContentLineOffset = 3;\r\n        // promises\r\n        this._whenDisposed = defer();\r\n    }\r\n    /*********************************\r\n     * Public methods\r\n     *********************************/\r\n    getId() {\r\n        return this._id;\r\n    }\r\n\r\n    async init(options, caps = {}, reporter) {\r\n        // make sure at least one test suite is defined\r\n        if (!options.suites) {\r\n            throw new Error('Initialization failed - no test suites are defined. You must define \"suites\" property in Oxygen options.');\r\n        }\r\n\r\n        this._options = options;\r\n        this._cwd = this._options.cwd || process.cwd();\r\n        this._reporter = reporter;\r\n        this._isInitialized = true;\r\n        if (options) {\r\n            // merge current and test configuration based environment variables\r\n            let optEnv = {};\r\n            if (options.env) {\r\n                // 'env' option might be defined either as a name of the environment or as an object that lists all environment variables\r\n                // if 'env' is a string, then resolve the actual variables from 'envs' object\r\n                if (typeof options.env === 'string' && typeof options.envs === 'object' && options.envs[options.env]) {\r\n                    optEnv = options.envs[options.env];\r\n\r\n                }\r\n                // if 'env' is an object, use the variables defined in it\r\n                else if (typeof options.env === 'object' && Object.keys(options.env)) {\r\n                    optEnv = options.env;\r\n                }\r\n            }\r\n\r\n            if (options.envVars && Object.keys(options.envVars)) {\r\n                optEnv = { ...optEnv, ...options.envVars };\r\n            }\r\n\r\n            // assign environment variables for later use\r\n            this._env = {\r\n                ...this._env,\r\n                ...optEnv\r\n            };\r\n            this._attributes = options.testAttributes || {};\r\n        }\r\n\r\n        this._caps = { ...caps }; // assign caps for later use\r\n        this._suites = [ ...options.suites ];\r\n        // set up debugging options\r\n        // TODO: this needs to be reimplemented. Everything related to debugging (initializeDebugger) should be removed from Oxygen\r\n        // and added to IDE instead. I.e. the only thing oxygen should do is to launch the child process with the debugging switch.\r\n        this._debugMode =  options.debugPortIde || options.debugPort ? true : false;\r\n        this._debugPort = options.debugPort || options.debugPortIde || null;\r\n        options.scriptContentLineOffset = this._scriptContentLineOffset;\r\n        this._localTime = (this._options && this._options.localTime) || this._localTime;\r\n        await this._startWorkerProcess();\r\n        await this._worker_InitOxygen();\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        this._isDisposing = true;\r\n        try {\r\n            this._worker && await this._worker.stopDebugger();\r\n            if (this._worker && this._worker.isRunning) {\r\n                await this._worker.stop(status);\r\n            }\r\n        } catch (e) {\r\n            console.log('Error when disposing Runner', e);\r\n            // ignore errors during the dispose\r\n            log.warn('Error when disposing Runner:', e);\r\n        }\r\n\r\n        if (status !== 'CANCELED') {\r\n            this._resetGlobalVariables();\r\n        }\r\n    }\r\n\r\n    async run() {\r\n        if (this._isInitializing) {\r\n            throw new Error(\"Initialization hasn't been completed yet, wait for 'initialized' event\");\r\n        }\r\n        if (this._isRunning) {\r\n            throw new Error(\"Previous test is still running, wait for 'test-ended' event\");\r\n        }\r\n        this._isRunning = true;\r\n\r\n        await this._reporter.onRunnerStart(this._id, this._options, this._caps);\r\n\r\n        let error = null;\r\n        let result = null;\r\n        try {\r\n            result = await this._runTest();\r\n        }\r\n        catch (e) {\r\n            error = e;\r\n        }\r\n\r\n        if (!error && result && result.failure) {\r\n            error = result.failure;\r\n        }\r\n\r\n        await this._reporter.onRunnerEnd(this._id, result, error);\r\n        this._isRunning = false;\r\n        if (error) {\r\n            throw error;\r\n        }\r\n        return result;\r\n    }\r\n\r\n    async kill(status = null) {\r\n        this._testKilled = true;\r\n\r\n        if (this._worker && this._worker.isRunning) {\r\n            await this._worker.kill(status);\r\n        }\r\n    }\r\n\r\n    debugContinue() {\r\n        if (this._debugMode && this._worker) {\r\n            this._worker.debugger.continue();\r\n        }\r\n    }\r\n\r\n    async updateBreakpoints(breakpoints, filePath) {\r\n        try {\r\n\r\n            if (this._worker && this._worker.debugger && this._worker.debugger.setBreakpointsActive) {\r\n                await this._worker.debugger.setBreakpointsActive(false);\r\n            } else {\r\n                await snooze(500);\r\n                return await this.updateBreakpoints(breakpoints, filePath);\r\n            }\r\n\r\n            if (this._debugMode && this._worker.debugger) {\r\n                let promises = [];\r\n\r\n                const tsBreakpoints = this._worker.debugger.getBreakpoints(filePath);\r\n                const suitesBreakpoints = getSuitesBreakpoints(this._suites);\r\n\r\n                // remove breakpoints from suites/cases tree\r\n                for (var suiteBp of suitesBreakpoints) {\r\n                    if (!breakpoints.includes(suiteBp.line) &&  filePath === suiteBp.file) {\r\n                        removeBreakpointFromSuites(this._suites, suiteBp);\r\n                    }\r\n                }\r\n\r\n                // remove deleted breakpoints\r\n                for (var actualCurrentBp of tsBreakpoints) {\r\n                    if (!breakpoints.includes(actualCurrentBp)) {\r\n                        promises.push(this._worker.debugger.removeBreakpointByValue(filePath, actualCurrentBp));\r\n                    }\r\n                }\r\n\r\n                // add new breakpoints\r\n                for (var userSetBp of breakpoints) {\r\n                    if (!tsBreakpoints.includes(userSetBp)) {\r\n                        promises.push(this._worker.debugger.setBreakpoint(filePath, userSetBp));\r\n                    }\r\n                }\r\n\r\n                let promiseAllPromise = await Promise.all(promises).then((value) => {\r\n                    return value;\r\n                });\r\n\r\n                await this._worker.debugger.setBreakpointsActive(true);\r\n\r\n                await snooze(500);\r\n\r\n                log.debug('updateBreakpoints() done.');\r\n\r\n                const breakpointsAferManipulations = this._worker.debugger.getBreakpoints(filePath);\r\n\r\n                return { promiseAllPromise : promiseAllPromise, breakpointsAferManipulations : breakpointsAferManipulations };\r\n            } else {\r\n                return null;\r\n            }\r\n        } catch (e) {\r\n            log.error('Debugger error', e);\r\n        }\r\n    }\r\n\r\n    async replClose() {\r\n        await this._worker._send({\r\n            event: 'repl',\r\n            name: 'repl_stop'\r\n        });\r\n    }\r\n\r\n    async replSend(cmd) {\r\n        await this._worker._send({\r\n            event: 'repl',\r\n            name: 'repl_eval',\r\n            content: {\r\n                cmd: cmd\r\n            }\r\n        });\r\n    }\r\n\r\n    async replStart() {\r\n        await this._worker.invoke('replStart');\r\n    }\r\n\r\n    setBreakpoint(line) {\r\n        /*\r\n        if (this.debugMode && this._worker && this._worker.debugger && this._suite && this._suite.testcases) {\r\n            const tc = this._suite.testcases[tcindex];\r\n            log.debug('oxygen.setBreakpoint: ' + (line + this._scriptContentLineOffset));\r\n            this._worker.debugger.setBreakpoint(tc.name, line + this._scriptContentLineOffset);\r\n        }*/\r\n    }\r\n\r\n    clearBreakpoint(line) {\r\n        /*\r\n        if (this.debugMode && this._worker && this._worker.debugger) {\r\n            this._worker.debugger.clearBreakpoint(line + this._scriptContentLineOffset, null);\r\n        }*/\r\n    }\r\n\r\n    /*********************************\r\n     * Private methods\r\n     *********************************/\r\n\r\n    async _runTest() {\r\n        const result = new TestResult();\r\n        result.startTime = oxutil.getTimeStamp();\r\n        result.status = Status.PASSED;\r\n        result.suites = [];\r\n        let error = null;\r\n        // call beforeTest hook\r\n        await this._worker_callBeforeTestHook();\r\n        try {\r\n            // iterate through suites\r\n            for (let suite of this._suites) {\r\n                const suiteResult = await this._runSuite(suite);\r\n                result.suites.push(suiteResult);\r\n            }\r\n        }\r\n        catch (e) {\r\n            error = e;\r\n        }\r\n        result.endTime = oxutil.getTimeStamp();\r\n        result.duration = result.endTime - result.startTime;\r\n\r\n        const hasFailedSuites = result.suites.some(suiteIterations => {\r\n            if (suiteIterations && Array.isArray(suiteIterations) && suiteIterations.length > 0) {\r\n                return suiteIterations.some(x => x.status === Status.FAILED);\r\n            }\r\n        });\r\n\r\n        result.status = hasFailedSuites ? Status.FAILED : Status.PASSED;\r\n        result.environment = { ...this._env };\r\n        // combine test defined caps and per module capabilities, that were passed by user in each module's init function\r\n        result.capabilities = { ...this._caps, ...this._modCaps };    // assign a copy of _caps object\r\n        result.options = { ...this._options };  // assign a copy of _options object\r\n\r\n        // if error occured, add it to the summary\r\n        if (error) {\r\n            result.failure = errorHelper.getFailureFromError(error);\r\n            result.status = Status.FAILED;\r\n        }\r\n        await this._worker_callAfterTestHook(result);\r\n        return result;\r\n    }\r\n\r\n    async _runSuite(suite) {\r\n        if (!suite) {\r\n            log.error('suite is null in _runSuite()!!!');\r\n        }\r\n        // ignore suite with missing mandatory properties\r\n        if (!suite.name && !suite.path) {\r\n            return [];\r\n        }\r\n        // make sure to always specify suite.iterationCount\r\n        if (!suite.iterationCount) {\r\n            suite.iterationCount = 1;\r\n        }\r\n        let showSuiteIterationsMessages = false;\r\n        if (suite.iterationCount > 1) {\r\n            showSuiteIterationsMessages = true;\r\n        }\r\n\r\n        const reRunOnFailure = this._options.reRunOnFailed || false;\r\n        // single suite might produce multiple results, based on amount of defined iterations\r\n        const suiteIterations = [];\r\n        for (let suiteIteration=1; suiteIteration <= suite.iterationCount; suiteIteration++) {\r\n            if (showSuiteIterationsMessages) {\r\n                this._reporter.onIterationStart(this._id, suiteIteration, 'Suite');\r\n            }\r\n            const suiteResult = new TestSuiteResult();\r\n            suiteIterations.push(suiteResult);\r\n            suiteResult.name = suite.name || oxutil.getFileNameWithoutExt(suite.path);\r\n            suiteResult.startTime = oxutil.getTimeStamp();\r\n            suiteResult.iterationNum = suiteIteration;\r\n            suiteResult.status = Status.PASSED;\r\n            await this._worker_callBeforeSuiteHook(suite);\r\n            this._reporter.onSuiteStart(this._id, suite.uri, suiteResult);\r\n            for (let caze of suite.cases) {\r\n                // ignore cases with missing mandatory 'path' property \r\n                if (!caze.path) {\r\n                    continue;\r\n                }\r\n                if (!caze.name) {\r\n                    caze.name = oxutil.getFileNameWithoutExt(caze.path);\r\n                }\r\n                if (!caze.iterationCount) {\r\n                    caze.iterationCount = 1;\r\n                }\r\n                for (let caseIteration=1; caseIteration <= caze.iterationCount; caseIteration++) {\r\n\r\n                    let showCaseIterationsMessages = false;\r\n                    if (caze && caze.iterationCount && caze.iterationCount > 1) {\r\n                        showCaseIterationsMessages = true;\r\n                    }\r\n                    if (showCaseIterationsMessages) {\r\n                        this._reporter.onIterationStart(this._id, caseIteration, 'Case');\r\n                    }\r\n                    // report case start event\r\n                    await this._reporter.onCaseStart(this._id, suite.uri || suite.id, caze.uri || caze.id || caze.path, caze);\r\n                    //let reRunCount = 0;\r\n                    let caseResult;\r\n                    // run or re-run the current test case\r\n                    for (let reRunCount = 0; reRunCount < MAX_RERUNS; reRunCount++) {\r\n                        caseResult = await this._runCase(suite, caze, suiteIteration, caseIteration, reRunCount);\r\n                        if ((!caseResult || caseResult.status === Status.FAILED) && !reRunOnFailure) {\r\n                            break;\r\n                        }\r\n                        else if (caseResult && caseResult.status !== Status.FAILED) {\r\n                            break;\r\n                        }\r\n                    }\r\n                    // report case end event\r\n                    await this._reporter.onCaseEnd(this._id, suite.uri || suite.id, caze.uri || caze.id, caseResult);\r\n                    if (showCaseIterationsMessages) {\r\n                        this._reporter.onIterationEnd(this._id, caseResult, 'Case');\r\n                    }\r\n                    // add case result to the suite result\r\n                    suiteResult.cases.push(caseResult);\r\n                    // if test case iteration has failed, then mark the entire test case as failed, \r\n                    // stop iterating over it and move to the next test case\r\n                    if (caseResult.status === Status.FAILED) {\r\n                        suiteResult.status = Status.FAILED;\r\n                    }\r\n                    else if (caseResult.status === Status.WARNING) {\r\n                        suiteResult.status = Status.WARNING;\r\n                    }\r\n                }\r\n            }\r\n            suiteResult.endTime = oxutil.getTimeStamp();\r\n            suiteResult.duration = suiteResult.endTime - suiteResult.startTime;\r\n\r\n            if (showSuiteIterationsMessages) {\r\n                this._reporter.onIterationEnd(this._id, suiteResult, 'Suite');\r\n            }\r\n\r\n            await this._worker_callAfterSuiteHook(suite, suiteResult);\r\n            this._reporter.onSuiteEnd(this._id, suite.uri, suiteResult);\r\n        }\r\n        return suiteIterations;\r\n    }\r\n\r\n    async _runCase(suite, caze, suiteIteration, caseIteration, reRunCount = 0) {\r\n        const params = {};\r\n        const reRun = reRunCount > 0;\r\n        // get test suite's parameters if defined\r\n        // get them first and then override with test case level parameters if defined\r\n        if (suite.paramManager) {\r\n            /*if (reRun) {\r\n                suite.paramManager.readPrev();\r\n            }*/\r\n            _.extend(params, suite.paramManager.getValues());\r\n            if (!reRun) {\r\n                suite.paramManager.readNext();\r\n            }\r\n        }\r\n        // read test case's next lines of parameters if parameter manager is defined\r\n        if (caze.paramManager) {\r\n            /*if (reRun) {\r\n                caze.paramManager.readPrev();\r\n            }*/\r\n            _.extend(params, caze.paramManager.getValues());\r\n            if (!reRun) {\r\n                caze.paramManager.readNext();\r\n            }\r\n        }\r\n\r\n        // add breakpoints before running the script if in debug mode\r\n        if (this._debugMode && this._worker && this._worker.debugger && caze.breakpoints) {\r\n            for (let i=0; i< caze.breakpoints.length; i++) {\r\n                // editor index starts from 1, but we need zero based index\r\n                let line = caze.breakpoints[i].line;\r\n                let file = caze.breakpoints[i].file;\r\n\r\n                await this._worker.debugger.setBreakpoint(file, line);\r\n            }\r\n        }\r\n        await this._worker_callBeforeCaseHook(caze);\r\n        const caseResult = new TestCaseResult();\r\n        caseResult.name = caze.name;\r\n        caseResult.location = caze.path;\r\n        caseResult.iterationNum = caseIteration;\r\n        caseResult.reRunCount = reRunCount;\r\n\r\n        // try to initialize Oxygen and handle any possible error\r\n        try {\r\n            await (!(this._worker) && this._worker_InitOxygen());\r\n            if (!this._worker) {\r\n                return;\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('_worker_InitOxygen() thrown an error:', e);\r\n            caseResult.startTime = caseResult.endTime = oxutil.getTimeStamp();\r\n            caseResult.duration = 0;\r\n            caseResult.failure = errorHelper.getFailureFromError(e);\r\n            caseResult.status = Status.FAILED;\r\n            return caseResult;\r\n        }\r\n        // start new test session\r\n        await this._worker_startSession();\r\n        // run the test in the worker process and handle any possible error\r\n        try {\r\n            caseResult.startTime = oxutil.getTimeStamp();\r\n            const { resultStore, context, moduleCaps, error } = await this._worker_Run(suite, caze, suiteIteration, caseIteration, params);\r\n            this._processTestResults({ resultStore, context, error, moduleCaps });\r\n            caseResult.endTime = oxutil.getTimeStamp();\r\n            caseResult.duration = caseResult.endTime - caseResult.startTime;\r\n            caseResult.context = context;\r\n            caseResult.steps = resultStore && resultStore.steps ? resultStore.steps : [];\r\n            caseResult.logs = resultStore && resultStore.logs ? resultStore.logs : [];\r\n            caseResult.har = resultStore && resultStore.har ? resultStore.har : null;\r\n            caseResult.testAttributes = resultStore && resultStore.attributes ? resultStore.attributes : null;\r\n            caseResult.attachments = resultStore && resultStore.attachments ? resultStore.attachments : null;\r\n\r\n            // determine test case iteration status - mark it as failed if any step has failed\r\n            var failedSteps = _.find(caseResult.steps, {status: Status.FAILED});\r\n            // check if there are any steps with Warning status\r\n            var warningSteps = _.find(caseResult.steps, {status: Status.WARNING});\r\n            caseResult.status = _.isEmpty(failedSteps) && !error ? Status.PASSED : Status.FAILED;\r\n            if (error) {\r\n                caseResult.failure = error;\r\n                caseResult.status = Status.FAILED;\r\n                caseResult.steps = oxutil.makeTransactionFailedIfStepFailed(caseResult.steps);\r\n            }\r\n            else if (!_.isEmpty(warningSteps)) {\r\n                caseResult.status = Status.WARNING;\r\n            }\r\n            await this._worker_callAfterCaseHook(caze, caseResult);\r\n        } catch (e) {\r\n            log.error('_worker_Run() thrown an error:', e);\r\n            caseResult.failure = errorHelper.getFailureFromError(e);\r\n            caseResult.status = Status.FAILED;\r\n\r\n        }\r\n        const disposeOxygenModules = typeof this._options.autoDispose !== 'boolean' || this._options.autoDispose === true;\r\n        // end session and dispose Oxygen modules if required\r\n        await this._worker_endSession(caseResult.status, disposeOxygenModules);\r\n\r\n        return caseResult;\r\n    }\r\n\r\n    async _worker_Run(suite, caze, suiteIteration, caseIteration, params) {\r\n        if (!this._worker) {\r\n            log.error('_worker is null but not suppose to!');\r\n\r\n            if (this._whenTestCaseFinished) {\r\n                this._whenTestCaseFinished.reject(new Error('_worker is null'));\r\n            }\r\n            return;\r\n        }\r\n        // start running the test\r\n        return await this._worker.run({\r\n            scriptName: caze.name,\r\n            scriptPath: caze.path,\r\n            context: {\r\n                params: params,\r\n                env: this._env,\r\n                caps: this._caps,\r\n                vars: this._vars,\r\n                attributes: this._attributes,\r\n                test: {\r\n                    case: {\r\n                        name: caze.name,\r\n                        iteration: caseIteration\r\n                    },\r\n                    suite: {\r\n                        name: suite.name,\r\n                        iteration: suiteIteration\r\n                    }\r\n                }\r\n            },\r\n            poFile: this._options.po || null,\r\n        });\r\n    }\r\n\r\n    async _worker_InitOxygen() {\r\n        await (this._worker && this._worker.initOxygen(this._id, this._options, this._caps));\r\n    }\r\n\r\n    async _worker_startSession() {\r\n        if (this._worker && this._worker.startSession) {\r\n            await this._worker.startSession();\r\n        }\r\n    }\r\n\r\n    async _worker_endSession(status = null, disposeModules = true) {\r\n        if (this._worker && this._worker.endSession) {\r\n            await this._worker.endSession(status, disposeModules);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeTestHook() {\r\n        try {\r\n            if (this && this._worker && this._worker.invokeTestHook) {\r\n                await this._worker.invokeTestHook('beforeTest', [this._id, this._options, this._caps]);\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeTest\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeTest\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeSuiteHook(suite) {\r\n        try {\r\n            if (this && this._worker && this._worker.invokeTestHook) {\r\n                await this._worker.invokeTestHook('beforeSuite', [suite]);\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeSuite\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeSuite\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeCaseHook(caze) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('beforeCase', [caze]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeCase\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeCase\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterTestHook(result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterTest', [this._id, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterTest\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterTest\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterSuiteHook(suite, result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterSuite', [suite, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterSuite\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterSuite\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterCaseHook(caze, result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterCase', [caze, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterCase\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterCase\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _startWorkerProcess() {\r\n        const workerPath = path.join(__dirname, 'worker.js');\r\n        this._worker = new WorkerProcess(this._id, workerPath, this._debugMode, this._debugPort, 'Oxygen', this._npmGRootExecution);\r\n        await this._worker.start();\r\n        this._hookWorkerEvents();\r\n        await this._worker.startDebugger();\r\n        this._hookWorkerDebuggerEvents();\r\n    }\r\n\r\n    _hookWorkerEvents() {\r\n        // preserve this object\r\n        const _this = this;\r\n        this._worker.subscribe('command:before', this._handleBeforeCommand.bind(this));\r\n        this._worker.subscribe('command:after', this._handleAfterCommand.bind(this));\r\n        this._worker.on('error', (payload) => {\r\n            const { error } = payload;\r\n            log.error('Worker process error: ', error);\r\n\r\n            if (this.exitDone) {\r\n                this.emit('test-error', error);\r\n            } else {\r\n                _this._workerProcLastError = error;\r\n            }\r\n        });\r\n        this._worker.on('exit', (payload) => {\r\n            this.exitDone = true;\r\n            const { exitCode } = payload;\r\n\r\n            if (exitCode && exitCode !== 0) {\r\n                // if the test is running or is being disposed and the child process has died,\r\n                // then end the test or disposal with fatal error\r\n                // (child process not suppose to die with code > 0)\r\n                let promise = null;\r\n                if (_this._isDisposing) {\r\n                    promise = _this._whenDisposed;\r\n                }\r\n                else if (_this._isRunning) {\r\n                    promise = _this._whenTestCaseFinished;\r\n                }\r\n                let error = _this._workerProcLastError || null;\r\n                if (exitCode == 134) {\r\n                    error = new OxygenError(errorHelper.errorCode.SCRIPT_ERROR, 'Out of memory error. Make sure that you don\\'t have any memory leaks in the test script.');\r\n                }\r\n                else if (!error) {\r\n                    error = new OxygenError(`Worker process exited with code: ${exitCode}.`);\r\n                }\r\n\r\n                promise && promise.reject(error);\r\n                _this._resetGlobalVariables();\r\n            }\r\n        });\r\n        this._worker.on('message', async (msg) => {\r\n            if (msg.event && msg.event === 'log') {\r\n                if (msg.level === 'DEBUG') {\r\n                    log.debug(msg.msg);\r\n                } else if (msg.level === 'INFO') {\r\n                    log.info(msg.msg);\r\n                } else if (msg.level === 'ERROR') {\r\n                    log.error(msg.msg, msg.err);\r\n                } else if (msg.level === 'WARN') {\r\n                    log.warn(msg.msg);\r\n                }\r\n\r\n                _this.emit('log', msg.time, msg.level, msg.msg, msg.src || DEFAULT_ISSUER);\r\n                _this._reporter && _this._reporter.onLogEntry(msg.time, msg.level, msg.msg, msg.src || DEFAULT_ISSUER);\r\n            }\r\n            else if (msg.event && msg.event === 'line-update') {\r\n                _this.emit('line-update', msg.line, msg.stack, msg.time);\r\n            }\r\n            else if (msg.event && msg.event === 'result-update') {\r\n                if (msg.method === 'init') {\r\n                    _this.emit('init-done', msg);\r\n                }\r\n            }\r\n            else if (msg.event && msg.event === 'workerError') {\r\n                console.log('workerError:', msg);\r\n                await this.dispose('failed');\r\n                await this.kill('failed');\r\n            }\r\n            else if (msg.event && msg.event === 'repl') {\r\n                _this.emit('repl', msg);\r\n            }\r\n        });\r\n    }\r\n\r\n    _hookWorkerDebuggerEvents() {\r\n        if (!this._worker) {\r\n            return;\r\n        }\r\n        this._worker.debugger && this._worker.debugger.on('debugger:break', (breakpointData) => {\r\n            this.emit('breakpoint', breakpointData);\r\n        });\r\n\r\n        this._worker.debugger && this._worker.debugger.on('debugger:breakError', (breakError) => {\r\n            this.emit('breakpointError', breakError);\r\n        });\r\n    }\r\n\r\n    async _handleBeforeCommand(e) {\r\n        this._reporter && this._reporter.onStepStart(this._id, e);\r\n\r\n        try {\r\n            if (e && e.module && e.module === 'log') {\r\n                // ignore\r\n            } else {\r\n                await (this._worker && this._worker.invokeTestHook('beforeCommand', [e]));\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeCommand\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeCommand\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _handleAfterCommand(e) {\r\n        this._reporter && this._reporter.onStepEnd(this._id, e.result);\r\n        try {\r\n            if (e && e.module && e.module === 'log') {\r\n                // ignore\r\n            } else {\r\n                await (this._worker && this._worker.invokeTestHook('afterCommand', [e.result]));\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterCommand\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterCommand\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    _resetGlobalVariables() {\r\n        this._modCaps = {};\r\n        this._worker = null;\r\n        this._isRunning = false;\r\n        this._isDisposing = false;\r\n        this._isInitializing = false;\r\n        this._testKilled = false;\r\n        this._whenDisposed = defer();\r\n    }\r\n\r\n    _processTestResults({ resultStore, moduleCaps, context = {}, error = null }) {\r\n        // if test was killed before any results were generated, then just finalize the test without processing results\r\n        if (this._testKilled) {\r\n            return null;\r\n        }\r\n        if (error) {\r\n            this.emit('test-error', error);\r\n        }\r\n        // store 'vars' part of the context for a later use\r\n        this._vars = context.vars || this._vars;\r\n        // store 'modCaps' part of the context for a later use\r\n        this._modCaps = { ...this._modCaps, ...moduleCaps || {} };\r\n        // clean up context from internal elements, not need in the report:\r\n        // remove caps from the context as it already appears in TestResult node\r\n        if (context.caps)\r\n            delete context.caps;\r\n        // remove env from the context as it already appears in TestResult node\r\n        if (context.env)\r\n            delete context.env;\r\n        // remove test from the context as it already appears in TestResult node\r\n        if (context.test)\r\n            delete context.test;\r\n    }\r\n\r\n    _emitIterationEnd(ts, tc, suiteIterationNum, caseIterationNum, caseIterationResult) {\r\n        this.emit('iteration-end', {\r\n            status: caseIterationResult._status,\r\n            failure: caseIterationResult.failure || null,\r\n            case: {\r\n                id: tc.id || null,\r\n                name: tc.name,\r\n                iteration: caseIterationNum,\r\n                iterationCount: tc.iterationCount\r\n            },\r\n            suite: {\r\n                id: ts.id || null,\r\n                name: ts.name,\r\n                iteration: suiteIterationNum,\r\n                iterationCount: ts.iterationCount\r\n            }\r\n        });\r\n    }\r\n\r\n    _emitTestEnd(result) {\r\n        this.emit('test-end', result);\r\n    }\r\n\r\n}\r\n\r\nexport { ParameterManager };"]}
886
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/runners/oxygen/index.js"],"names":["log","DEFAULT_ISSUER","MAX_RERUNS","snooze","ms","Promise","resolve","setTimeout","getSuitesBreakpoints","suites","retval","Array","isArray","length","map","suite","cases","caze","breakpoints","breakpoint","push","removeBreakpointFromSuites","removeBreakpoint","idx","file","line","splice","OxygenRunner","EventEmitter","constructor","options","_id","oxutil","generateUniqueId","_isRunning","_isInitializing","_isDisposing","_worker","_debugMode","_workerProcLastError","_npmGRootExecution","npmGRootExecution","_suite","_envVars","_vars","_caps","_modCaps","_attributes","_options","_localTime","_testKilled","_scriptContentLineOffset","_whenDisposed","getId","init","caps","reporter","Error","_cwd","cwd","process","_reporter","_isInitialized","optEnv","env","envs","Object","keys","envVars","_env","testAttributes","_suites","debugPortIde","debugPort","_debugPort","scriptContentLineOffset","localTime","_startWorkerProcess","_worker_InitOxygen","dispose","status","stopDebugger","isRunning","stop","e","console","warn","_resetGlobalVariables","run","onRunnerStart","error","result","_runTest","failure","onRunnerEnd","kill","debugContinue","debugger","continue","updateBreakpoints","filePath","setBreakpointsActive","promises","tsBreakpoints","getBreakpoints","suitesBreakpoints","suiteBp","includes","actualCurrentBp","removeBreakpointByValue","userSetBp","setBreakpoint","promiseAllPromise","all","then","value","debug","breakpointsAferManipulations","replClose","_send","event","name","replSend","cmd","content","replStart","invoke","clearBreakpoint","TestResult","startTime","getTimeStamp","Status","PASSED","_worker_callBeforeTestHook","suiteResult","_runSuite","endTime","duration","hasFailedSuites","some","suiteIterations","x","FAILED","environment","capabilities","errorHelper","getFailureFromError","_worker_callAfterTestHook","path","iterationCount","showSuiteIterationsMessages","reRunOnFailure","reRunOnFailed","suiteIteration","onIterationStart","TestSuiteResult","getFileNameWithoutExt","iterationNum","_worker_callBeforeSuiteHook","onSuiteStart","uri","caseIteration","showCaseIterationsMessages","onCaseStart","id","caseResult","reRunCount","_runCase","onCaseEnd","onIterationEnd","WARNING","_worker_callAfterSuiteHook","onSuiteEnd","params","reRun","paramManager","readPrev","_","extend","getValues","i","_worker_callBeforeCaseHook","TestCaseResult","location","readNext","_worker_startSession","resultStore","context","moduleCaps","_worker_Run","_processTestResults","steps","logs","har","attributes","attachments","failedSteps","find","warningSteps","isEmpty","makeTransactionFailedIfStepFailed","_worker_callAfterCaseHook","disposeOxygenModules","autoDispose","_worker_endSession","_whenTestCaseFinished","reject","scriptName","scriptPath","vars","test","case","iteration","poFile","po","initOxygen","startSession","disposeModules","endSession","invokeTestHook","onLogEntry","workerPath","join","__dirname","WorkerProcess","start","_hookWorkerEvents","startDebugger","_hookWorkerDebuggerEvents","_this","subscribe","_handleBeforeCommand","bind","_handleAfterCommand","on","payload","exitDone","emit","exitCode","promise","OxygenError","errorCode","SCRIPT_ERROR","msg","level","info","err","time","src","stack","method","breakpointData","breakError","onStepStart","module","onStepEnd","_emitIterationEnd","ts","tc","suiteIterationNum","caseIterationNum","caseIterationResult","_status","_emitTestEnd"],"mappings":"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","sourcesContent":["/* eslint-disable no-async-promise-executor */\r\n/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\nimport logger from '../../lib/logger';\r\nconst log = logger('OxygenRunner');\r\nconst DEFAULT_ISSUER = 'user';\r\nconst MAX_RERUNS = 2;\r\n\r\nimport { EventEmitter } from 'events';\r\nimport _  from 'lodash';\r\nimport { defer } from 'when';\r\nimport path from 'path';\r\n\r\nimport TestSuiteResult from '../../model/suite-result';\r\nimport TestCaseResult from '../../model/case-result';\r\nimport TestResult from '../../model/test-result';\r\nimport Status from '../../model/status';\r\nimport oxutil from '../../lib/util';\r\nimport errorHelper from '../../errors/helper';\r\nimport OxygenError from '../../errors/OxygenError';\r\nimport ParameterManager from '../../lib/param-manager.js';\r\nimport WorkerProcess from '../WorkerProcess';\r\n\r\n// snooze function - async wrapper around setTimeout function\r\nconst snooze = ms => new Promise(resolve => setTimeout(resolve, ms));\r\n\r\nconst getSuitesBreakpoints = (suites) => {\r\n    const retval = [];\r\n\r\n    if (\r\n        suites &&\r\n        Array.isArray(suites) &&\r\n        suites.length > 0\r\n    ) {\r\n        suites.map((suite) => {\r\n            if (\r\n                suite &&\r\n                suite.cases &&\r\n                Array.isArray(suite.cases) &&\r\n                suite.cases.length > 0\r\n            ) {\r\n                suite.cases.map((caze) => {\r\n                    if (\r\n                        caze &&\r\n                        caze.breakpoints &&\r\n                        Array.isArray(caze.breakpoints) &&\r\n                        caze.breakpoints.length > 0\r\n                    ) {\r\n                        caze.breakpoints.map((breakpoint) => {\r\n                            retval.push(breakpoint);\r\n                        });\r\n                    }\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n    return retval;\r\n};\r\n\r\nconst removeBreakpointFromSuites = (suites, removeBreakpoint) => {\r\n    if (\r\n        suites &&\r\n        Array.isArray(suites) &&\r\n        suites.length > 0\r\n    ) {\r\n        suites.map((suite) => {\r\n            if (\r\n                suite &&\r\n                suite.cases &&\r\n                Array.isArray(suite.cases) &&\r\n                suite.cases.length > 0\r\n            ) {\r\n                suite.cases.map((caze) => {\r\n                    if (\r\n                        caze &&\r\n                        caze.breakpoints &&\r\n                        Array.isArray(caze.breakpoints) &&\r\n                        caze.breakpoints.length > 0\r\n                    ) {\r\n                        caze.breakpoints.map((breakpoint, idx) => {\r\n                            if (\r\n                                breakpoint.file === removeBreakpoint.file &&\r\n                                breakpoint.line === removeBreakpoint.line\r\n                            ) {\r\n                                caze.breakpoints.splice(idx, 1);\r\n                            }\r\n                        });\r\n                    }\r\n                });\r\n            }\r\n        });\r\n    }\r\n};\r\n\r\nexport default class OxygenRunner extends EventEmitter {\r\n    constructor(options) {\r\n        super();\r\n        // class variables\r\n        this._id = oxutil.generateUniqueId();\r\n        this._isRunning = false;\r\n        this._isInitializing = false;\r\n        this._isDisposing = false;\r\n        this._worker = null;\r\n        this._debugMode = false;\r\n        this._workerProcLastError = null;\r\n\r\n        this._npmGRootExecution = true;\r\n        if (options && typeof options.npmGRootExecution !== 'undefined') {\r\n            this._npmGRootExecution = options.npmGRootExecution;\r\n        }\r\n\r\n        // define variables to iterate through test cases and test suite iterations\r\n        this._suite;\r\n        this._envVars = {};  // environment variables passed at the beginning of the test\r\n        this._vars = {};     // user-defined variables that are shared between different scripts\r\n        this._caps = {}; // desired capabilities that are passed to each module\r\n        this._modCaps = {};\r\n        this._attributes = {};\r\n        this._options = null;\r\n        this._localTime = false;\r\n        this._testKilled = false;\r\n        this._scriptContentLineOffset = 3;\r\n        // promises\r\n        this._whenDisposed = defer();\r\n    }\r\n    /*********************************\r\n     * Public methods\r\n     *********************************/\r\n    getId() {\r\n        return this._id;\r\n    }\r\n\r\n    async init(options, caps = {}, reporter) {\r\n        // make sure at least one test suite is defined\r\n        if (!options.suites) {\r\n            throw new Error('Initialization failed - no test suites are defined. You must define \"suites\" property in Oxygen options.');\r\n        }\r\n\r\n        this._options = options;\r\n        this._cwd = this._options.cwd || process.cwd();\r\n        this._reporter = reporter;\r\n        this._isInitialized = true;\r\n        if (options) {\r\n            // merge current and test configuration based environment variables\r\n            let optEnv = {};\r\n            if (options.env) {\r\n                // 'env' option might be defined either as a name of the environment or as an object that lists all environment variables\r\n                // if 'env' is a string, then resolve the actual variables from 'envs' object\r\n                if (typeof options.env === 'string' && typeof options.envs === 'object' && options.envs[options.env]) {\r\n                    optEnv = options.envs[options.env];\r\n\r\n                }\r\n                // if 'env' is an object, use the variables defined in it\r\n                else if (typeof options.env === 'object' && Object.keys(options.env)) {\r\n                    optEnv = options.env;\r\n                }\r\n            }\r\n\r\n            if (options.envVars && Object.keys(options.envVars)) {\r\n                optEnv = { ...optEnv, ...options.envVars };\r\n            }\r\n\r\n            // assign environment variables for later use\r\n            this._env = {\r\n                ...this._env,\r\n                ...optEnv\r\n            };\r\n            this._attributes = options.testAttributes || {};\r\n        }\r\n\r\n        this._caps = { ...caps }; // assign caps for later use\r\n        this._suites = [ ...options.suites ];\r\n        // set up debugging options\r\n        // TODO: this needs to be reimplemented. Everything related to debugging (initializeDebugger) should be removed from Oxygen\r\n        // and added to IDE instead. I.e. the only thing oxygen should do is to launch the child process with the debugging switch.\r\n        this._debugMode =  options.debugPortIde || options.debugPort ? true : false;\r\n        this._debugPort = options.debugPort || options.debugPortIde || null;\r\n        options.scriptContentLineOffset = this._scriptContentLineOffset;\r\n        this._localTime = (this._options && this._options.localTime) || this._localTime;\r\n        await this._startWorkerProcess();\r\n        await this._worker_InitOxygen();\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        this._isDisposing = true;\r\n        try {\r\n            this._worker && await this._worker.stopDebugger();\r\n            if (this._worker && this._worker.isRunning) {\r\n                await this._worker.stop(status);\r\n            }\r\n        } catch (e) {\r\n            console.log('Error when disposing Runner', e);\r\n            // ignore errors during the dispose\r\n            log.warn('Error when disposing Runner:', e);\r\n        }\r\n\r\n        if (status !== 'CANCELED') {\r\n            this._resetGlobalVariables();\r\n        }\r\n    }\r\n\r\n    async run() {\r\n        if (this._isInitializing) {\r\n            throw new Error(\"Initialization hasn't been completed yet, wait for 'initialized' event\");\r\n        }\r\n        if (this._isRunning) {\r\n            throw new Error(\"Previous test is still running, wait for 'test-ended' event\");\r\n        }\r\n        this._isRunning = true;\r\n\r\n        await this._reporter.onRunnerStart(this._id, this._options, this._caps);\r\n\r\n        let error = null;\r\n        let result = null;\r\n        try {\r\n            result = await this._runTest();\r\n        }\r\n        catch (e) {\r\n            error = e;\r\n        }\r\n\r\n        if (!error && result && result.failure) {\r\n            error = result.failure;\r\n        }\r\n\r\n        await this._reporter.onRunnerEnd(this._id, result, error);\r\n        this._isRunning = false;\r\n        if (error) {\r\n            throw error;\r\n        }\r\n        return result;\r\n    }\r\n\r\n    async kill(status = null) {\r\n        this._testKilled = true;\r\n\r\n        if (this._worker && this._worker.isRunning) {\r\n            await this._worker.kill(status);\r\n        }\r\n    }\r\n\r\n    debugContinue() {\r\n        if (this._debugMode && this._worker) {\r\n            this._worker.debugger.continue();\r\n        }\r\n    }\r\n\r\n    async updateBreakpoints(breakpoints, filePath) {\r\n        try {\r\n\r\n            if (this._worker && this._worker.debugger && this._worker.debugger.setBreakpointsActive) {\r\n                await this._worker.debugger.setBreakpointsActive(false);\r\n            } else {\r\n                await snooze(500);\r\n                return await this.updateBreakpoints(breakpoints, filePath);\r\n            }\r\n\r\n            if (this._debugMode && this._worker.debugger) {\r\n                let promises = [];\r\n\r\n                const tsBreakpoints = this._worker.debugger.getBreakpoints(filePath);\r\n                const suitesBreakpoints = getSuitesBreakpoints(this._suites);\r\n\r\n                // remove breakpoints from suites/cases tree\r\n                for (var suiteBp of suitesBreakpoints) {\r\n                    if (!breakpoints.includes(suiteBp.line) &&  filePath === suiteBp.file) {\r\n                        removeBreakpointFromSuites(this._suites, suiteBp);\r\n                    }\r\n                }\r\n\r\n                // remove deleted breakpoints\r\n                for (var actualCurrentBp of tsBreakpoints) {\r\n                    if (!breakpoints.includes(actualCurrentBp)) {\r\n                        promises.push(this._worker.debugger.removeBreakpointByValue(filePath, actualCurrentBp));\r\n                    }\r\n                }\r\n\r\n                // add new breakpoints\r\n                for (var userSetBp of breakpoints) {\r\n                    if (!tsBreakpoints.includes(userSetBp)) {\r\n                        promises.push(this._worker.debugger.setBreakpoint(filePath, userSetBp));\r\n                    }\r\n                }\r\n\r\n                let promiseAllPromise = await Promise.all(promises).then((value) => {\r\n                    return value;\r\n                });\r\n\r\n                await this._worker.debugger.setBreakpointsActive(true);\r\n\r\n                await snooze(500);\r\n\r\n                log.debug('updateBreakpoints() done.');\r\n\r\n                const breakpointsAferManipulations = this._worker.debugger.getBreakpoints(filePath);\r\n\r\n                return { promiseAllPromise : promiseAllPromise, breakpointsAferManipulations : breakpointsAferManipulations };\r\n            } else {\r\n                return null;\r\n            }\r\n        } catch (e) {\r\n            log.error('Debugger error', e);\r\n        }\r\n    }\r\n\r\n    async replClose() {\r\n        await this._worker._send({\r\n            event: 'repl',\r\n            name: 'repl_stop'\r\n        });\r\n    }\r\n\r\n    async replSend(cmd) {\r\n        await this._worker._send({\r\n            event: 'repl',\r\n            name: 'repl_eval',\r\n            content: {\r\n                cmd: cmd\r\n            }\r\n        });\r\n    }\r\n\r\n    async replStart() {\r\n        await this._worker.invoke('replStart');\r\n    }\r\n\r\n    setBreakpoint(line) {\r\n        /*\r\n        if (this.debugMode && this._worker && this._worker.debugger && this._suite && this._suite.testcases) {\r\n            const tc = this._suite.testcases[tcindex];\r\n            log.debug('oxygen.setBreakpoint: ' + (line + this._scriptContentLineOffset));\r\n            this._worker.debugger.setBreakpoint(tc.name, line + this._scriptContentLineOffset);\r\n        }*/\r\n    }\r\n\r\n    clearBreakpoint(line) {\r\n        /*\r\n        if (this.debugMode && this._worker && this._worker.debugger) {\r\n            this._worker.debugger.clearBreakpoint(line + this._scriptContentLineOffset, null);\r\n        }*/\r\n    }\r\n\r\n    /*********************************\r\n     * Private methods\r\n     *********************************/\r\n\r\n    async _runTest() {\r\n        const result = new TestResult();\r\n        result.startTime = oxutil.getTimeStamp();\r\n        result.status = Status.PASSED;\r\n        result.suites = [];\r\n        let error = null;\r\n        // call beforeTest hook\r\n        await this._worker_callBeforeTestHook();\r\n        try {\r\n            // iterate through suites\r\n            for (let suite of this._suites) {\r\n                const suiteResult = await this._runSuite(suite);\r\n                result.suites.push(suiteResult);\r\n            }\r\n        }\r\n        catch (e) {\r\n            error = e;\r\n        }\r\n        result.endTime = oxutil.getTimeStamp();\r\n        result.duration = result.endTime - result.startTime;\r\n\r\n        const hasFailedSuites = result.suites.some(suiteIterations => {\r\n            if (suiteIterations && Array.isArray(suiteIterations) && suiteIterations.length > 0) {\r\n                return suiteIterations.some(x => x.status === Status.FAILED);\r\n            }\r\n        });\r\n\r\n        result.status = hasFailedSuites ? Status.FAILED : Status.PASSED;\r\n        result.environment = { ...this._env };\r\n        // combine test defined caps and per module capabilities, that were passed by user in each module's init function\r\n        result.capabilities = { ...this._caps, ...this._modCaps };    // assign a copy of _caps object\r\n        result.options = { ...this._options };  // assign a copy of _options object\r\n\r\n        // if error occured, add it to the summary\r\n        if (error) {\r\n            result.failure = errorHelper.getFailureFromError(error);\r\n            result.status = Status.FAILED;\r\n        }\r\n        await this._worker_callAfterTestHook(result);\r\n        return result;\r\n    }\r\n\r\n    async _runSuite(suite) {\r\n        if (!suite) {\r\n            log.error('suite is null in _runSuite()!!!');\r\n        }\r\n        // ignore suite with missing mandatory properties\r\n        if (!suite.name && !suite.path) {\r\n            return [];\r\n        }\r\n        // make sure to always specify suite.iterationCount\r\n        if (!suite.iterationCount) {\r\n            suite.iterationCount = 1;\r\n        }\r\n        let showSuiteIterationsMessages = false;\r\n        if (suite.iterationCount > 1) {\r\n            showSuiteIterationsMessages = true;\r\n        }\r\n\r\n        const reRunOnFailure = this._options.reRunOnFailed || false;\r\n        // single suite might produce multiple results, based on amount of defined iterations\r\n        const suiteIterations = [];\r\n        for (let suiteIteration=1; suiteIteration <= suite.iterationCount; suiteIteration++) {\r\n            if (showSuiteIterationsMessages) {\r\n                this._reporter.onIterationStart(this._id, suiteIteration, 'Suite');\r\n            }\r\n            const suiteResult = new TestSuiteResult();\r\n            suiteIterations.push(suiteResult);\r\n            suiteResult.name = suite.name || oxutil.getFileNameWithoutExt(suite.path);\r\n            suiteResult.startTime = oxutil.getTimeStamp();\r\n            suiteResult.iterationNum = suiteIteration;\r\n            suiteResult.status = Status.PASSED;\r\n            await this._worker_callBeforeSuiteHook(suite);\r\n            this._reporter.onSuiteStart(this._id, suite.uri, suiteResult);\r\n            for (let caze of suite.cases) {\r\n                // ignore cases with missing mandatory 'path' property \r\n                if (!caze.path) {\r\n                    continue;\r\n                }\r\n                if (!caze.name) {\r\n                    caze.name = oxutil.getFileNameWithoutExt(caze.path);\r\n                }\r\n                if (!caze.iterationCount) {\r\n                    caze.iterationCount = 1;\r\n                }\r\n                for (let caseIteration=1; caseIteration <= caze.iterationCount; caseIteration++) {\r\n\r\n                    let showCaseIterationsMessages = false;\r\n                    if (caze && caze.iterationCount && caze.iterationCount > 1) {\r\n                        showCaseIterationsMessages = true;\r\n                    }\r\n                    if (showCaseIterationsMessages) {\r\n                        this._reporter.onIterationStart(this._id, caseIteration, 'Case');\r\n                    }\r\n                    // report case start event\r\n                    await this._reporter.onCaseStart(this._id, suite.uri || suite.id, caze.uri || caze.id || caze.path, caze);\r\n                    //let reRunCount = 0;\r\n                    let caseResult;\r\n                    // run or re-run the current test case\r\n                    for (let reRunCount = 0; reRunCount < MAX_RERUNS; reRunCount++) {\r\n                        caseResult = await this._runCase(suite, caze, suiteIteration, caseIteration, reRunCount);\r\n                        if ((!caseResult || caseResult.status === Status.FAILED) && !reRunOnFailure) {\r\n                            break;\r\n                        }\r\n                        else if (caseResult && caseResult.status !== Status.FAILED) {\r\n                            break;\r\n                        }\r\n                    }\r\n                    // report case end event\r\n                    await this._reporter.onCaseEnd(this._id, suite.uri || suite.id, caze.uri || caze.id, caseResult);\r\n                    if (showCaseIterationsMessages) {\r\n                        this._reporter.onIterationEnd(this._id, caseResult, 'Case');\r\n                    }\r\n                    // add case result to the suite result\r\n                    suiteResult.cases.push(caseResult);\r\n                    // if test case iteration has failed, then mark the entire test case as failed, \r\n                    // stop iterating over it and move to the next test case\r\n                    if (caseResult.status === Status.FAILED) {\r\n                        suiteResult.status = Status.FAILED;\r\n                    }\r\n                    else if (caseResult.status === Status.WARNING) {\r\n                        suiteResult.status = Status.WARNING;\r\n                    }\r\n                }\r\n            }\r\n            suiteResult.endTime = oxutil.getTimeStamp();\r\n            suiteResult.duration = suiteResult.endTime - suiteResult.startTime;\r\n\r\n            if (showSuiteIterationsMessages) {\r\n                this._reporter.onIterationEnd(this._id, suiteResult, 'Suite');\r\n            }\r\n\r\n            await this._worker_callAfterSuiteHook(suite, suiteResult);\r\n            this._reporter.onSuiteEnd(this._id, suite.uri, suiteResult);\r\n        }\r\n        return suiteIterations;\r\n    }\r\n\r\n    async _runCase(suite, caze, suiteIteration, caseIteration, reRunCount = 0) {\r\n        const params = {};\r\n        const reRun = reRunCount > 0;\r\n        // get test suite's parameters if defined\r\n        // get them first and then override with test case level parameters if defined\r\n        if (suite.paramManager) {\r\n            if (reRun) {\r\n                suite.paramManager.readPrev();\r\n            }\r\n            _.extend(params, suite.paramManager.getValues());\r\n        }\r\n        // read test case's next lines of parameters if parameter manager is defined\r\n        if (caze.paramManager) {\r\n            if (reRun) {\r\n                caze.paramManager.readPrev();\r\n            }\r\n            _.extend(params, caze.paramManager.getValues());\r\n        }\r\n\r\n        // add breakpoints before running the script if in debug mode\r\n        if (this._debugMode && this._worker && this._worker.debugger && caze.breakpoints) {\r\n            for (let i=0; i< caze.breakpoints.length; i++) {\r\n                // editor index starts from 1, but we need zero based index\r\n                let line = caze.breakpoints[i].line;\r\n                let file = caze.breakpoints[i].file;\r\n\r\n                await this._worker.debugger.setBreakpoint(file, line);\r\n            }\r\n        }\r\n        await this._worker_callBeforeCaseHook(caze);\r\n        const caseResult = new TestCaseResult();\r\n        caseResult.name = caze.name;\r\n        caseResult.location = caze.path;\r\n        caseResult.iterationNum = caseIteration;\r\n        caseResult.reRunCount = reRunCount;\r\n\r\n        // try to initialize Oxygen and handle any possible error\r\n        try {\r\n            await (!(this._worker) && this._worker_InitOxygen());\r\n            if (!this._worker) {\r\n                return;\r\n            }\r\n        } catch (e) {\r\n            log.error('_worker_InitOxygen() thrown an error:', e);\r\n            caseResult.startTime = caseResult.endTime = oxutil.getTimeStamp();\r\n            caseResult.duration = 0;\r\n            caseResult.failure = errorHelper.getFailureFromError(e);\r\n            caseResult.status = Status.FAILED;\r\n\r\n            if (suite.paramManager) {\r\n                suite.paramManager.readNext();\r\n            }\r\n\r\n            if (caze.paramManager) {\r\n                caze.paramManager.readNext();\r\n            }\r\n\r\n            return caseResult;\r\n        }\r\n        // start new test session\r\n        await this._worker_startSession();\r\n        // run the test in the worker process and handle any possible error\r\n        try {\r\n            caseResult.startTime = oxutil.getTimeStamp();\r\n            const { resultStore, context, moduleCaps, error } = await this._worker_Run(suite, caze, suiteIteration, caseIteration, params);\r\n            this._processTestResults({ resultStore, context, error, moduleCaps });\r\n            caseResult.endTime = oxutil.getTimeStamp();\r\n            caseResult.duration = caseResult.endTime - caseResult.startTime;\r\n            caseResult.context = context;\r\n            caseResult.steps = resultStore && resultStore.steps ? resultStore.steps : [];\r\n            caseResult.logs = resultStore && resultStore.logs ? resultStore.logs : [];\r\n            caseResult.har = resultStore && resultStore.har ? resultStore.har : null;\r\n            caseResult.testAttributes = resultStore && resultStore.attributes ? resultStore.attributes : null;\r\n            caseResult.attachments = resultStore && resultStore.attachments ? resultStore.attachments : null;\r\n\r\n            // determine test case iteration status - mark it as failed if any step has failed\r\n            var failedSteps = _.find(caseResult.steps, {status: Status.FAILED});\r\n            // check if there are any steps with Warning status\r\n            var warningSteps = _.find(caseResult.steps, {status: Status.WARNING});\r\n            caseResult.status = _.isEmpty(failedSteps) && !error ? Status.PASSED : Status.FAILED;\r\n            if (error) {\r\n                caseResult.failure = error;\r\n                caseResult.status = Status.FAILED;\r\n                caseResult.steps = oxutil.makeTransactionFailedIfStepFailed(caseResult.steps);\r\n            }\r\n            else if (!_.isEmpty(warningSteps)) {\r\n                caseResult.status = Status.WARNING;\r\n            }\r\n            await this._worker_callAfterCaseHook(caze, caseResult);\r\n        } catch (e) {\r\n            log.error('_worker_Run() thrown an error:', e);\r\n            caseResult.failure = errorHelper.getFailureFromError(e);\r\n            caseResult.status = Status.FAILED;\r\n\r\n        }\r\n        const disposeOxygenModules = typeof this._options.autoDispose !== 'boolean' || this._options.autoDispose === true;\r\n        // end session and dispose Oxygen modules if required\r\n        await this._worker_endSession(caseResult.status, disposeOxygenModules);\r\n\r\n        if (suite.paramManager) {\r\n            suite.paramManager.readNext();\r\n        }\r\n\r\n        if (caze.paramManager) {\r\n            caze.paramManager.readNext();\r\n        }\r\n\r\n        return caseResult;\r\n    }\r\n\r\n    async _worker_Run(suite, caze, suiteIteration, caseIteration, params) {\r\n        if (!this._worker) {\r\n            log.error('_worker is null but not suppose to!');\r\n\r\n            if (this._whenTestCaseFinished) {\r\n                this._whenTestCaseFinished.reject(new Error('_worker is null'));\r\n            }\r\n            return;\r\n        }\r\n        // start running the test\r\n        return await this._worker.run({\r\n            scriptName: caze.name,\r\n            scriptPath: caze.path,\r\n            context: {\r\n                params: params,\r\n                env: this._env,\r\n                caps: this._caps,\r\n                vars: this._vars,\r\n                attributes: this._attributes,\r\n                test: {\r\n                    case: {\r\n                        name: caze.name,\r\n                        iteration: caseIteration\r\n                    },\r\n                    suite: {\r\n                        name: suite.name,\r\n                        iteration: suiteIteration\r\n                    }\r\n                }\r\n            },\r\n            poFile: this._options.po || null,\r\n        });\r\n    }\r\n\r\n    async _worker_InitOxygen() {\r\n        await (this._worker && this._worker.initOxygen(this._id, this._options, this._caps));\r\n    }\r\n\r\n    async _worker_startSession() {\r\n        if (this._worker && this._worker.startSession) {\r\n            await this._worker.startSession();\r\n        }\r\n    }\r\n\r\n    async _worker_endSession(status = null, disposeModules = true) {\r\n        if (this._worker && this._worker.endSession) {\r\n            await this._worker.endSession(status, disposeModules);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeTestHook() {\r\n        try {\r\n            if (this && this._worker && this._worker.invokeTestHook) {\r\n                await this._worker.invokeTestHook('beforeTest', [this._id, this._options, this._caps]);\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeTest\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeTest\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeSuiteHook(suite) {\r\n        try {\r\n            if (this && this._worker && this._worker.invokeTestHook) {\r\n                await this._worker.invokeTestHook('beforeSuite', [suite]);\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeSuite\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeSuite\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callBeforeCaseHook(caze) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('beforeCase', [caze]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeCase\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeCase\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterTestHook(result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterTest', [this._id, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterTest\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterTest\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterSuiteHook(suite, result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterSuite', [suite, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterSuite\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterSuite\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _worker_callAfterCaseHook(caze, result) {\r\n        try {\r\n            await (this._worker && this._worker.invokeTestHook('afterCase', [caze, result]));\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterCase\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterCase\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _startWorkerProcess() {\r\n        const workerPath = path.join(__dirname, 'worker.js');\r\n        this._worker = new WorkerProcess(this._id, workerPath, this._debugMode, this._debugPort, 'Oxygen', this._npmGRootExecution);\r\n        await this._worker.start();\r\n        this._hookWorkerEvents();\r\n        await this._worker.startDebugger();\r\n        this._hookWorkerDebuggerEvents();\r\n    }\r\n\r\n    _hookWorkerEvents() {\r\n        // preserve this object\r\n        const _this = this;\r\n        this._worker.subscribe('command:before', this._handleBeforeCommand.bind(this));\r\n        this._worker.subscribe('command:after', this._handleAfterCommand.bind(this));\r\n        this._worker.on('error', (payload) => {\r\n            const { error } = payload;\r\n            log.error('Worker process error: ', error);\r\n\r\n            if (this.exitDone) {\r\n                this.emit('test-error', error);\r\n            } else {\r\n                _this._workerProcLastError = error;\r\n            }\r\n        });\r\n        this._worker.on('exit', (payload) => {\r\n            this.exitDone = true;\r\n            const { exitCode } = payload;\r\n\r\n            if (exitCode && exitCode !== 0) {\r\n                // if the test is running or is being disposed and the child process has died,\r\n                // then end the test or disposal with fatal error\r\n                // (child process not suppose to die with code > 0)\r\n                let promise = null;\r\n                if (_this._isDisposing) {\r\n                    promise = _this._whenDisposed;\r\n                }\r\n                else if (_this._isRunning) {\r\n                    promise = _this._whenTestCaseFinished;\r\n                }\r\n                let error = _this._workerProcLastError || null;\r\n                if (exitCode == 134) {\r\n                    error = new OxygenError(errorHelper.errorCode.SCRIPT_ERROR, 'Out of memory error. Make sure that you don\\'t have any memory leaks in the test script.');\r\n                }\r\n                else if (!error) {\r\n                    error = new OxygenError(`Worker process exited with code: ${exitCode}.`);\r\n                }\r\n\r\n                promise && promise.reject(error);\r\n                _this._resetGlobalVariables();\r\n            }\r\n        });\r\n        this._worker.on('message', async (msg) => {\r\n            if (msg.event && msg.event === 'log') {\r\n                if (msg.level === 'DEBUG') {\r\n                    log.debug(msg.msg);\r\n                } else if (msg.level === 'INFO') {\r\n                    log.info(msg.msg);\r\n                } else if (msg.level === 'ERROR') {\r\n                    log.error(msg.msg, msg.err);\r\n                } else if (msg.level === 'WARN') {\r\n                    log.warn(msg.msg);\r\n                }\r\n\r\n                _this.emit('log', msg.time, msg.level, msg.msg, msg.src || DEFAULT_ISSUER);\r\n                _this._reporter && _this._reporter.onLogEntry(msg.time, msg.level, msg.msg, msg.src || DEFAULT_ISSUER);\r\n            }\r\n            else if (msg.event && msg.event === 'line-update') {\r\n                _this.emit('line-update', msg.line, msg.stack, msg.time);\r\n            }\r\n            else if (msg.event && msg.event === 'result-update') {\r\n                if (msg.method === 'init') {\r\n                    _this.emit('init-done', msg);\r\n                }\r\n            }\r\n            else if (msg.event && msg.event === 'workerError') {\r\n                console.log('workerError:', msg);\r\n                await this.dispose('failed');\r\n                await this.kill('failed');\r\n            }\r\n            else if (msg.event && msg.event === 'repl') {\r\n                _this.emit('repl', msg);\r\n            }\r\n        });\r\n    }\r\n\r\n    _hookWorkerDebuggerEvents() {\r\n        if (!this._worker) {\r\n            return;\r\n        }\r\n        this._worker.debugger && this._worker.debugger.on('debugger:break', (breakpointData) => {\r\n            this.emit('breakpoint', breakpointData);\r\n        });\r\n\r\n        this._worker.debugger && this._worker.debugger.on('debugger:breakError', (breakError) => {\r\n            this.emit('breakpointError', breakError);\r\n        });\r\n    }\r\n\r\n    async _handleBeforeCommand(e) {\r\n        this._reporter && this._reporter.onStepStart(this._id, e);\r\n\r\n        try {\r\n            if (e && e.module && e.module === 'log') {\r\n                // ignore\r\n            } else {\r\n                await (this._worker && this._worker.invokeTestHook('beforeCommand', [e]));\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"beforeCommand\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"beforeCommand\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    async _handleAfterCommand(e) {\r\n        this._reporter && this._reporter.onStepEnd(this._id, e.result);\r\n        try {\r\n            if (e && e.module && e.module === 'log') {\r\n                // ignore\r\n            } else {\r\n                await (this._worker && this._worker.invokeTestHook('afterCommand', [e.result]));\r\n            }\r\n        }\r\n        catch (e) {\r\n            log.error('\"afterCommand\" hook failed:', e);\r\n            this._reporter && this._reporter.onLogEntry(null, 'WARN', '\"afterCommand\" hook failed:'+e, DEFAULT_ISSUER);\r\n        }\r\n    }\r\n\r\n    _resetGlobalVariables() {\r\n        this._modCaps = {};\r\n        this._worker = null;\r\n        this._isRunning = false;\r\n        this._isDisposing = false;\r\n        this._isInitializing = false;\r\n        this._testKilled = false;\r\n        this._whenDisposed = defer();\r\n    }\r\n\r\n    _processTestResults({ resultStore, moduleCaps, context = {}, error = null }) {\r\n        // if test was killed before any results were generated, then just finalize the test without processing results\r\n        if (this._testKilled) {\r\n            return null;\r\n        }\r\n        if (error) {\r\n            this.emit('test-error', error);\r\n        }\r\n        // store 'vars' part of the context for a later use\r\n        this._vars = context.vars || this._vars;\r\n        // store 'modCaps' part of the context for a later use\r\n        this._modCaps = { ...this._modCaps, ...moduleCaps || {} };\r\n        // clean up context from internal elements, not need in the report:\r\n        // remove caps from the context as it already appears in TestResult node\r\n        if (context.caps)\r\n            delete context.caps;\r\n        // remove env from the context as it already appears in TestResult node\r\n        if (context.env)\r\n            delete context.env;\r\n        // remove test from the context as it already appears in TestResult node\r\n        if (context.test)\r\n            delete context.test;\r\n    }\r\n\r\n    _emitIterationEnd(ts, tc, suiteIterationNum, caseIterationNum, caseIterationResult) {\r\n        this.emit('iteration-end', {\r\n            status: caseIterationResult._status,\r\n            failure: caseIterationResult.failure || null,\r\n            case: {\r\n                id: tc.id || null,\r\n                name: tc.name,\r\n                iteration: caseIterationNum,\r\n                iterationCount: tc.iterationCount\r\n            },\r\n            suite: {\r\n                id: ts.id || null,\r\n                name: ts.name,\r\n                iteration: suiteIterationNum,\r\n                iterationCount: ts.iterationCount\r\n            }\r\n        });\r\n    }\r\n\r\n    _emitTestEnd(result) {\r\n        this.emit('test-end', result);\r\n    }\r\n\r\n}\r\n\r\nexport { ParameterManager };"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "oxygen-cli",
3
- "version": "1.33.3",
3
+ "version": "1.33.5",
4
4
  "description": "Automation framework for testing modern applications",
5
5
  "main": "./build/index.js",
6
6
  "bin": {
@@ -57,9 +57,9 @@
57
57
  "@lambdatest/node-rest-client": "1.0.5",
58
58
  "@oxygenhq/logger": "0.5.1",
59
59
  "@oxygenhq/mitmproxy-node": "1.0.1",
60
- "@wdio/cli": "7.30.0",
61
- "@wdio/devtools-service": "7.30.0",
62
- "@wdio/sync": "7.30.0",
60
+ "@wdio/cli": "7.36.0",
61
+ "@wdio/devtools-service": "7.36.0",
62
+ "@wdio/sync": "7.36.0",
63
63
  "async": "3.2.5",
64
64
  "axios": "0.27.2",
65
65
  "canvas": "2.11.2",
@@ -106,7 +106,7 @@
106
106
  "testdouble": "3.16.8",
107
107
  "testingbot-api": "1.0.8",
108
108
  "twilio": "3.84.1",
109
- "webdriverio": "7.30.0",
109
+ "webdriverio": "7.36.0",
110
110
  "when": "3.7.8",
111
111
  "xlsx": "0.18.5"
112
112
  },