oxygen-cli 1.24.1 → 1.24.4

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.
@@ -13,7 +13,7 @@ require("source-map-support/register");
13
13
 
14
14
  /**
15
15
  * @summary Waits for inner text of the given element to stop matching the specified pattern.
16
- * @description Text pattern can be any of the supported
16
+ * @description Text pattern can be any of the supported
17
17
  * string matching patterns(on the top of page).
18
18
  * @function waitForNotText
19
19
  * @param {String|Element} locator - An element locator.
@@ -38,8 +38,8 @@ module.exports = async function (locator, pattern, timeout) {
38
38
  timeout: timeout ? timeout : this.waitForTimeout
39
39
  });
40
40
  } catch (e) {
41
- text = text.replace(/\n/g, '\\n');
41
+ if (text) text = text.replace(/\n/g, '\\n');
42
42
  throw new this.OxError(this.errHelper.errorCode.TIMEOUT, `Expected not: "${pattern}". Got: "${text}"`);
43
43
  }
44
44
  };
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvck5vdFRleHQuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsImxvY2F0b3IiLCJwYXR0ZXJuIiwidGltZW91dCIsImhlbHBlcnMiLCJhc3NlcnRBcmd1bWVudCIsImFzc2VydEFyZ3VtZW50VGltZW91dCIsImVsIiwiZ2V0RWxlbWVudCIsInRleHQiLCJkcml2ZXIiLCJ3YWl0VW50aWwiLCJnZXRUZXh0IiwibWF0Y2hQYXR0ZXJuIiwid2FpdEZvclRpbWVvdXQiLCJlIiwicmVwbGFjZSIsIk94RXJyb3IiLCJlcnJIZWxwZXIiLCJlcnJvckNvZGUiLCJUSU1FT1VUIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBQSxNQUFNLENBQUNDLE9BQVAsR0FBaUIsZ0JBQWVDLE9BQWYsRUFBd0JDLE9BQXhCLEVBQWlDQyxPQUFqQyxFQUEwQztBQUN2RCxPQUFLQyxPQUFMLENBQWFDLGNBQWIsQ0FBNEJILE9BQTVCLEVBQXFDLFNBQXJDO0FBQ0EsT0FBS0UsT0FBTCxDQUFhRSxxQkFBYixDQUFtQ0gsT0FBbkMsRUFBNEMsU0FBNUM7QUFFQSxNQUFJSSxFQUFFLEdBQUcsTUFBTSxLQUFLSCxPQUFMLENBQWFJLFVBQWIsQ0FBd0JQLE9BQXhCLEVBQWlDLEtBQWpDLEVBQXdDRSxPQUF4QyxDQUFmO0FBRUEsTUFBSU0sSUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTSxLQUFLQyxNQUFMLENBQVlDLFNBQVosQ0FBc0IsWUFBVztBQUNuQ0YsTUFBQUEsSUFBSSxHQUFHLE1BQU1GLEVBQUUsQ0FBQ0ssT0FBSCxFQUFiO0FBQ0EsYUFBTyxDQUFDLEtBQUtSLE9BQUwsQ0FBYVMsWUFBYixDQUEwQkosSUFBMUIsRUFBZ0NQLE9BQWhDLENBQVI7QUFDSCxLQUhLLEVBSU47QUFBRUMsTUFBQUEsT0FBTyxFQUFHQSxPQUFPLEdBQUdBLE9BQUgsR0FBYSxLQUFLVztBQUFyQyxLQUpNLENBQU47QUFLSCxHQU5ELENBTUUsT0FBT0MsQ0FBUCxFQUFVO0FBQ1JOLElBQUFBLElBQUksR0FBR0EsSUFBSSxDQUFDTyxPQUFMLENBQWEsS0FBYixFQUFvQixLQUFwQixDQUFQO0FBQ0EsVUFBTSxJQUFJLEtBQUtDLE9BQVQsQ0FBaUIsS0FBS0MsU0FBTCxDQUFlQyxTQUFmLENBQXlCQyxPQUExQyxFQUFvRCxrQkFBaUJsQixPQUFRLFlBQVdPLElBQUssR0FBN0YsQ0FBTjtBQUNIO0FBQ0osQ0FqQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBDb3B5cmlnaHQgKEMpIDIwMTUtcHJlc2VudCBDbG91ZEJlYXQgTGltaXRlZFxyXG4gKlxyXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxyXG4gKiBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieVxyXG4gKiB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uLCBlaXRoZXIgdmVyc2lvbiAzIG9mIHRoZSBMaWNlbnNlLCBvclxyXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxyXG4gKi9cclxuXHJcbi8qKlxyXG4gKiBAc3VtbWFyeSBXYWl0cyBmb3IgaW5uZXIgdGV4dCBvZiB0aGUgZ2l2ZW4gZWxlbWVudCB0byBzdG9wIG1hdGNoaW5nIHRoZSBzcGVjaWZpZWQgcGF0dGVybi5cclxuICogQGRlc2NyaXB0aW9uIFRleHQgcGF0dGVybiBjYW4gYmUgYW55IG9mIHRoZSBzdXBwb3J0ZWQgXHJcbiAqICBzdHJpbmcgbWF0Y2hpbmcgcGF0dGVybnMob24gdGhlIHRvcCBvZiBwYWdlKS5cclxuICogQGZ1bmN0aW9uIHdhaXRGb3JOb3RUZXh0XHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVGV4dCBwYXR0ZXJuLlxyXG4gKiBAcGFyYW0ge051bWJlcj19IHRpbWVvdXQgLSBUaW1lb3V0IGluIG1pbGxpc2Vjb25kcy4gRGVmYXVsdCBpcyA2MCBzZWNvbmRzLlxyXG4gKiBAZXhhbXBsZSA8Y2FwdGlvbj5bamF2YXNjcmlwdF0gVXNhZ2UgZXhhbXBsZTwvY2FwdGlvbj5cclxuICogd2ViLmluaXQoKTsvL09wZW5zIGJyb3dzZXIgc2Vzc2lvbi5cclxuICogd2ViLm9wZW4oXCJ3d3cueW91cndlYnNpdGUuY29tXCIpOy8vIE9wZW5zIGEgd2Vic2l0ZS5cclxuICogd2ViLndhaXRGb3JOb3RUZXh0KFwiaWQ9VGl0bGVcIixcIldlYnNpdGVcIik7Ly9XYWl0cyBmb3IgYW4gZWxlbWVudOKAmXMgdGV4dCB0byBub3QgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFRleHQoKTtcclxuICAgICAgICAgICAgcmV0dXJuICF0aGlzLmhlbHBlcnMubWF0Y2hQYXR0ZXJuKHRleHQsIHBhdHRlcm4pO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgeyB0aW1lb3V0OiAodGltZW91dCA/IHRpbWVvdXQgOiB0aGlzLndhaXRGb3JUaW1lb3V0KSB9KTtcclxuICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICB0ZXh0ID0gdGV4dC5yZXBsYWNlKC9cXG4vZywgJ1xcXFxuJyk7XHJcbiAgICAgICAgdGhyb3cgbmV3IHRoaXMuT3hFcnJvcih0aGlzLmVyckhlbHBlci5lcnJvckNvZGUuVElNRU9VVCwgYEV4cGVjdGVkIG5vdDogXCIke3BhdHRlcm59XCIuIEdvdDogXCIke3RleHR9XCJgKTtcclxuICAgIH1cclxufTtcclxuIl19
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvck5vdFRleHQuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsImxvY2F0b3IiLCJwYXR0ZXJuIiwidGltZW91dCIsImhlbHBlcnMiLCJhc3NlcnRBcmd1bWVudCIsImFzc2VydEFyZ3VtZW50VGltZW91dCIsImVsIiwiZ2V0RWxlbWVudCIsInRleHQiLCJkcml2ZXIiLCJ3YWl0VW50aWwiLCJnZXRUZXh0IiwibWF0Y2hQYXR0ZXJuIiwid2FpdEZvclRpbWVvdXQiLCJlIiwicmVwbGFjZSIsIk94RXJyb3IiLCJlcnJIZWxwZXIiLCJlcnJvckNvZGUiLCJUSU1FT1VUIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBQSxNQUFNLENBQUNDLE9BQVAsR0FBaUIsZ0JBQWVDLE9BQWYsRUFBd0JDLE9BQXhCLEVBQWlDQyxPQUFqQyxFQUEwQztBQUN2RCxPQUFLQyxPQUFMLENBQWFDLGNBQWIsQ0FBNEJILE9BQTVCLEVBQXFDLFNBQXJDO0FBQ0EsT0FBS0UsT0FBTCxDQUFhRSxxQkFBYixDQUFtQ0gsT0FBbkMsRUFBNEMsU0FBNUM7QUFFQSxNQUFJSSxFQUFFLEdBQUcsTUFBTSxLQUFLSCxPQUFMLENBQWFJLFVBQWIsQ0FBd0JQLE9BQXhCLEVBQWlDLEtBQWpDLEVBQXdDRSxPQUF4QyxDQUFmO0FBRUEsTUFBSU0sSUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTSxLQUFLQyxNQUFMLENBQVlDLFNBQVosQ0FBc0IsWUFBVztBQUNuQ0YsTUFBQUEsSUFBSSxHQUFHLE1BQU1GLEVBQUUsQ0FBQ0ssT0FBSCxFQUFiO0FBQ0EsYUFBTyxDQUFDLEtBQUtSLE9BQUwsQ0FBYVMsWUFBYixDQUEwQkosSUFBMUIsRUFBZ0NQLE9BQWhDLENBQVI7QUFDSCxLQUhLLEVBSU47QUFBRUMsTUFBQUEsT0FBTyxFQUFHQSxPQUFPLEdBQUdBLE9BQUgsR0FBYSxLQUFLVztBQUFyQyxLQUpNLENBQU47QUFLSCxHQU5ELENBTUUsT0FBT0MsQ0FBUCxFQUFVO0FBQ1IsUUFBSU4sSUFBSixFQUNJQSxJQUFJLEdBQUdBLElBQUksQ0FBQ08sT0FBTCxDQUFhLEtBQWIsRUFBb0IsS0FBcEIsQ0FBUDtBQUNKLFVBQU0sSUFBSSxLQUFLQyxPQUFULENBQWlCLEtBQUtDLFNBQUwsQ0FBZUMsU0FBZixDQUF5QkMsT0FBMUMsRUFBb0Qsa0JBQWlCbEIsT0FBUSxZQUFXTyxJQUFLLEdBQTdGLENBQU47QUFDSDtBQUNKLENBbEJEIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogQ29weXJpZ2h0IChDKSAyMDE1LXByZXNlbnQgQ2xvdWRCZWF0IExpbWl0ZWRcclxuICpcclxuICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU6IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnlcclxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcclxuICogdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbiwgZWl0aGVyIHZlcnNpb24gMyBvZiB0aGUgTGljZW5zZSwgb3JcclxuICogKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi5cclxuICovXHJcblxyXG4vKipcclxuICogQHN1bW1hcnkgV2FpdHMgZm9yIGlubmVyIHRleHQgb2YgdGhlIGdpdmVuIGVsZW1lbnQgdG8gc3RvcCBtYXRjaGluZyB0aGUgc3BlY2lmaWVkIHBhdHRlcm4uXHJcbiAqIEBkZXNjcmlwdGlvbiBUZXh0IHBhdHRlcm4gY2FuIGJlIGFueSBvZiB0aGUgc3VwcG9ydGVkXHJcbiAqICBzdHJpbmcgbWF0Y2hpbmcgcGF0dGVybnMob24gdGhlIHRvcCBvZiBwYWdlKS5cclxuICogQGZ1bmN0aW9uIHdhaXRGb3JOb3RUZXh0XHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVGV4dCBwYXR0ZXJuLlxyXG4gKiBAcGFyYW0ge051bWJlcj19IHRpbWVvdXQgLSBUaW1lb3V0IGluIG1pbGxpc2Vjb25kcy4gRGVmYXVsdCBpcyA2MCBzZWNvbmRzLlxyXG4gKiBAZXhhbXBsZSA8Y2FwdGlvbj5bamF2YXNjcmlwdF0gVXNhZ2UgZXhhbXBsZTwvY2FwdGlvbj5cclxuICogd2ViLmluaXQoKTsvL09wZW5zIGJyb3dzZXIgc2Vzc2lvbi5cclxuICogd2ViLm9wZW4oXCJ3d3cueW91cndlYnNpdGUuY29tXCIpOy8vIE9wZW5zIGEgd2Vic2l0ZS5cclxuICogd2ViLndhaXRGb3JOb3RUZXh0KFwiaWQ9VGl0bGVcIixcIldlYnNpdGVcIik7Ly9XYWl0cyBmb3IgYW4gZWxlbWVudOKAmXMgdGV4dCB0byBub3QgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFRleHQoKTtcclxuICAgICAgICAgICAgcmV0dXJuICF0aGlzLmhlbHBlcnMubWF0Y2hQYXR0ZXJuKHRleHQsIHBhdHRlcm4pO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgeyB0aW1lb3V0OiAodGltZW91dCA/IHRpbWVvdXQgOiB0aGlzLndhaXRGb3JUaW1lb3V0KSB9KTtcclxuICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICBpZiAodGV4dClcclxuICAgICAgICAgICAgdGV4dCA9IHRleHQucmVwbGFjZSgvXFxuL2csICdcXFxcbicpO1xyXG4gICAgICAgIHRocm93IG5ldyB0aGlzLk94RXJyb3IodGhpcy5lcnJIZWxwZXIuZXJyb3JDb2RlLlRJTUVPVVQsIGBFeHBlY3RlZCBub3Q6IFwiJHtwYXR0ZXJufVwiLiBHb3Q6IFwiJHt0ZXh0fVwiYCk7XHJcbiAgICB9XHJcbn07XHJcbiJdfQ==
@@ -13,7 +13,7 @@ require("source-map-support/register");
13
13
 
14
14
  /**
15
15
  * @summary Waits for input element's value to stop matching the specified pattern.
16
- * @description Value pattern can be any of the supported
16
+ * @description Value pattern can be any of the supported
17
17
  * string matching patterns(on the top of page).
18
18
  * @function waitForNotValue
19
19
  * @param {String|Element} locator - An element locator.
@@ -38,8 +38,8 @@ module.exports = async function (locator, pattern, timeout) {
38
38
  timeout: timeout ? timeout : this.waitForTimeout
39
39
  });
40
40
  } catch (e) {
41
- text = text.replace(/\n/g, '\\n');
41
+ if (text) text = text.replace(/\n/g, '\\n');
42
42
  throw new this.OxError(this.errHelper.errorCode.TIMEOUT, `Expected not: "${pattern}". Got: "${text}"`);
43
43
  }
44
44
  };
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvck5vdFZhbHVlLmpzIl0sIm5hbWVzIjpbIm1vZHVsZSIsImV4cG9ydHMiLCJsb2NhdG9yIiwicGF0dGVybiIsInRpbWVvdXQiLCJoZWxwZXJzIiwiYXNzZXJ0QXJndW1lbnQiLCJhc3NlcnRBcmd1bWVudFRpbWVvdXQiLCJlbCIsImdldEVsZW1lbnQiLCJ0ZXh0IiwiZHJpdmVyIiwid2FpdFVudGlsIiwiZ2V0VmFsdWUiLCJtYXRjaFBhdHRlcm4iLCJ3YWl0Rm9yVGltZW91dCIsImUiLCJyZXBsYWNlIiwiT3hFcnJvciIsImVyckhlbHBlciIsImVycm9yQ29kZSIsIlRJTUVPVVQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0FBLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQixnQkFBZUMsT0FBZixFQUF3QkMsT0FBeEIsRUFBaUNDLE9BQWpDLEVBQTBDO0FBQ3ZELE9BQUtDLE9BQUwsQ0FBYUMsY0FBYixDQUE0QkgsT0FBNUIsRUFBcUMsU0FBckM7QUFDQSxPQUFLRSxPQUFMLENBQWFFLHFCQUFiLENBQW1DSCxPQUFuQyxFQUE0QyxTQUE1QztBQUVBLE1BQUlJLEVBQUUsR0FBRyxNQUFNLEtBQUtILE9BQUwsQ0FBYUksVUFBYixDQUF3QlAsT0FBeEIsRUFBaUMsS0FBakMsRUFBd0NFLE9BQXhDLENBQWY7QUFFQSxNQUFJTSxJQUFKOztBQUNBLE1BQUk7QUFDQSxVQUFNLEtBQUtDLE1BQUwsQ0FBWUMsU0FBWixDQUFzQixZQUFXO0FBQ25DRixNQUFBQSxJQUFJLEdBQUcsTUFBTUYsRUFBRSxDQUFDSyxRQUFILEVBQWI7QUFDQSxhQUFPLENBQUMsS0FBS1IsT0FBTCxDQUFhUyxZQUFiLENBQTBCSixJQUExQixFQUFnQ1AsT0FBaEMsQ0FBUjtBQUNILEtBSEssRUFJTjtBQUFFQyxNQUFBQSxPQUFPLEVBQUdBLE9BQU8sR0FBR0EsT0FBSCxHQUFhLEtBQUtXO0FBQXJDLEtBSk0sQ0FBTjtBQUtILEdBTkQsQ0FNRSxPQUFPQyxDQUFQLEVBQVU7QUFDUk4sSUFBQUEsSUFBSSxHQUFHQSxJQUFJLENBQUNPLE9BQUwsQ0FBYSxLQUFiLEVBQW9CLEtBQXBCLENBQVA7QUFDQSxVQUFNLElBQUksS0FBS0MsT0FBVCxDQUFpQixLQUFLQyxTQUFMLENBQWVDLFNBQWYsQ0FBeUJDLE9BQTFDLEVBQW9ELGtCQUFpQmxCLE9BQVEsWUFBV08sSUFBSyxHQUE3RixDQUFOO0FBQ0g7QUFDSixDQWpCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoQykgMjAxNS1wcmVzZW50IENsb3VkQmVhdCBMaW1pdGVkXHJcbiAqXHJcbiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOiB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5XHJcbiAqIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5XHJcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXHJcbiAqIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIEBzdW1tYXJ5IFdhaXRzIGZvciBpbnB1dCBlbGVtZW50J3MgdmFsdWUgdG8gc3RvcCBtYXRjaGluZyB0aGUgc3BlY2lmaWVkIHBhdHRlcm4uXHJcbiAqIEBkZXNjcmlwdGlvbiBWYWx1ZSBwYXR0ZXJuIGNhbiBiZSBhbnkgb2YgdGhlIHN1cHBvcnRlZCBcclxuICogIHN0cmluZyBtYXRjaGluZyBwYXR0ZXJucyhvbiB0aGUgdG9wIG9mIHBhZ2UpLlxyXG4gKiBAZnVuY3Rpb24gd2FpdEZvck5vdFZhbHVlXHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVmFsdWUgcGF0dGVybi5cclxuICogQHBhcmFtIHtOdW1iZXI9fSB0aW1lb3V0IC0gVGltZW91dCBpbiBtaWxsaXNlY29uZHMuIERlZmF1bHQgaXMgNjAgc2Vjb25kcy5cclxuICogQGV4YW1wbGUgPGNhcHRpb24+W2phdmFzY3JpcHRdIFVzYWdlIGV4YW1wbGU8L2NhcHRpb24+XHJcbiAqIHdlYi5pbml0KCk7Ly9PcGVucyBicm93c2VyIHNlc3Npb24uXHJcbiAqIHdlYi5vcGVuKFwid3d3LnlvdXJ3ZWJzaXRlLmNvbVwiKTsvLyBPcGVucyBhIHdlYnNpdGUuXHJcbiAqIHdlYi53YWl0Rm9yTm90VmFsdWUoXCJpZD1Vc2VyTmFtZVwiLFwiVXNlclwiKTsvL1dhaXRzIGZvciBhbiBlbGVtZW504oCZcyB2YWx1ZSB0byBub3QgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFZhbHVlKCk7XHJcbiAgICAgICAgICAgIHJldHVybiAhdGhpcy5oZWxwZXJzLm1hdGNoUGF0dGVybih0ZXh0LCBwYXR0ZXJuKTtcclxuICAgICAgICB9LFxyXG4gICAgICAgIHsgdGltZW91dDogKHRpbWVvdXQgPyB0aW1lb3V0IDogdGhpcy53YWl0Rm9yVGltZW91dCkgfSk7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgICAgdGV4dCA9IHRleHQucmVwbGFjZSgvXFxuL2csICdcXFxcbicpO1xyXG4gICAgICAgIHRocm93IG5ldyB0aGlzLk94RXJyb3IodGhpcy5lcnJIZWxwZXIuZXJyb3JDb2RlLlRJTUVPVVQsIGBFeHBlY3RlZCBub3Q6IFwiJHtwYXR0ZXJufVwiLiBHb3Q6IFwiJHt0ZXh0fVwiYCk7XHJcbiAgICB9XHJcbn07XHJcbiJdfQ==
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvck5vdFZhbHVlLmpzIl0sIm5hbWVzIjpbIm1vZHVsZSIsImV4cG9ydHMiLCJsb2NhdG9yIiwicGF0dGVybiIsInRpbWVvdXQiLCJoZWxwZXJzIiwiYXNzZXJ0QXJndW1lbnQiLCJhc3NlcnRBcmd1bWVudFRpbWVvdXQiLCJlbCIsImdldEVsZW1lbnQiLCJ0ZXh0IiwiZHJpdmVyIiwid2FpdFVudGlsIiwiZ2V0VmFsdWUiLCJtYXRjaFBhdHRlcm4iLCJ3YWl0Rm9yVGltZW91dCIsImUiLCJyZXBsYWNlIiwiT3hFcnJvciIsImVyckhlbHBlciIsImVycm9yQ29kZSIsIlRJTUVPVVQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0FBLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQixnQkFBZUMsT0FBZixFQUF3QkMsT0FBeEIsRUFBaUNDLE9BQWpDLEVBQTBDO0FBQ3ZELE9BQUtDLE9BQUwsQ0FBYUMsY0FBYixDQUE0QkgsT0FBNUIsRUFBcUMsU0FBckM7QUFDQSxPQUFLRSxPQUFMLENBQWFFLHFCQUFiLENBQW1DSCxPQUFuQyxFQUE0QyxTQUE1QztBQUVBLE1BQUlJLEVBQUUsR0FBRyxNQUFNLEtBQUtILE9BQUwsQ0FBYUksVUFBYixDQUF3QlAsT0FBeEIsRUFBaUMsS0FBakMsRUFBd0NFLE9BQXhDLENBQWY7QUFFQSxNQUFJTSxJQUFKOztBQUNBLE1BQUk7QUFDQSxVQUFNLEtBQUtDLE1BQUwsQ0FBWUMsU0FBWixDQUFzQixZQUFXO0FBQ25DRixNQUFBQSxJQUFJLEdBQUcsTUFBTUYsRUFBRSxDQUFDSyxRQUFILEVBQWI7QUFDQSxhQUFPLENBQUMsS0FBS1IsT0FBTCxDQUFhUyxZQUFiLENBQTBCSixJQUExQixFQUFnQ1AsT0FBaEMsQ0FBUjtBQUNILEtBSEssRUFJTjtBQUFFQyxNQUFBQSxPQUFPLEVBQUdBLE9BQU8sR0FBR0EsT0FBSCxHQUFhLEtBQUtXO0FBQXJDLEtBSk0sQ0FBTjtBQUtILEdBTkQsQ0FNRSxPQUFPQyxDQUFQLEVBQVU7QUFDUixRQUFJTixJQUFKLEVBQ0lBLElBQUksR0FBR0EsSUFBSSxDQUFDTyxPQUFMLENBQWEsS0FBYixFQUFvQixLQUFwQixDQUFQO0FBQ0osVUFBTSxJQUFJLEtBQUtDLE9BQVQsQ0FBaUIsS0FBS0MsU0FBTCxDQUFlQyxTQUFmLENBQXlCQyxPQUExQyxFQUFvRCxrQkFBaUJsQixPQUFRLFlBQVdPLElBQUssR0FBN0YsQ0FBTjtBQUNIO0FBQ0osQ0FsQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBDb3B5cmlnaHQgKEMpIDIwMTUtcHJlc2VudCBDbG91ZEJlYXQgTGltaXRlZFxyXG4gKlxyXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxyXG4gKiBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieVxyXG4gKiB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uLCBlaXRoZXIgdmVyc2lvbiAzIG9mIHRoZSBMaWNlbnNlLCBvclxyXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxyXG4gKi9cclxuXHJcbi8qKlxyXG4gKiBAc3VtbWFyeSBXYWl0cyBmb3IgaW5wdXQgZWxlbWVudCdzIHZhbHVlIHRvIHN0b3AgbWF0Y2hpbmcgdGhlIHNwZWNpZmllZCBwYXR0ZXJuLlxyXG4gKiBAZGVzY3JpcHRpb24gVmFsdWUgcGF0dGVybiBjYW4gYmUgYW55IG9mIHRoZSBzdXBwb3J0ZWRcclxuICogIHN0cmluZyBtYXRjaGluZyBwYXR0ZXJucyhvbiB0aGUgdG9wIG9mIHBhZ2UpLlxyXG4gKiBAZnVuY3Rpb24gd2FpdEZvck5vdFZhbHVlXHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVmFsdWUgcGF0dGVybi5cclxuICogQHBhcmFtIHtOdW1iZXI9fSB0aW1lb3V0IC0gVGltZW91dCBpbiBtaWxsaXNlY29uZHMuIERlZmF1bHQgaXMgNjAgc2Vjb25kcy5cclxuICogQGV4YW1wbGUgPGNhcHRpb24+W2phdmFzY3JpcHRdIFVzYWdlIGV4YW1wbGU8L2NhcHRpb24+XHJcbiAqIHdlYi5pbml0KCk7Ly9PcGVucyBicm93c2VyIHNlc3Npb24uXHJcbiAqIHdlYi5vcGVuKFwid3d3LnlvdXJ3ZWJzaXRlLmNvbVwiKTsvLyBPcGVucyBhIHdlYnNpdGUuXHJcbiAqIHdlYi53YWl0Rm9yTm90VmFsdWUoXCJpZD1Vc2VyTmFtZVwiLFwiVXNlclwiKTsvL1dhaXRzIGZvciBhbiBlbGVtZW504oCZcyB2YWx1ZSB0byBub3QgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFZhbHVlKCk7XHJcbiAgICAgICAgICAgIHJldHVybiAhdGhpcy5oZWxwZXJzLm1hdGNoUGF0dGVybih0ZXh0LCBwYXR0ZXJuKTtcclxuICAgICAgICB9LFxyXG4gICAgICAgIHsgdGltZW91dDogKHRpbWVvdXQgPyB0aW1lb3V0IDogdGhpcy53YWl0Rm9yVGltZW91dCkgfSk7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgICAgaWYgKHRleHQpXHJcbiAgICAgICAgICAgIHRleHQgPSB0ZXh0LnJlcGxhY2UoL1xcbi9nLCAnXFxcXG4nKTtcclxuICAgICAgICB0aHJvdyBuZXcgdGhpcy5PeEVycm9yKHRoaXMuZXJySGVscGVyLmVycm9yQ29kZS5USU1FT1VULCBgRXhwZWN0ZWQgbm90OiBcIiR7cGF0dGVybn1cIi4gR290OiBcIiR7dGV4dH1cImApO1xyXG4gICAgfVxyXG59O1xyXG4iXX0=
@@ -13,7 +13,7 @@ require("source-map-support/register");
13
13
 
14
14
  /**
15
15
  * @summary Waits for inner text of the given element to match the specified pattern.
16
- * @description Text pattern can be any of the supported
16
+ * @description Text pattern can be any of the supported
17
17
  * string matching patterns(on the top of page).
18
18
  * @function waitForText
19
19
  * @param {String|Element} locator - An element locator.
@@ -38,8 +38,8 @@ module.exports = async function (locator, pattern, timeout) {
38
38
  timeout: timeout ? timeout : this.waitForTimeout
39
39
  });
40
40
  } catch (e) {
41
- text = text.replace(/\n/g, '\\n');
41
+ if (text) text = text.replace(/\n/g, '\\n');
42
42
  throw new this.OxError(this.errHelper.errorCode.TIMEOUT, `Expected: "${pattern}". Got: "${text}"`);
43
43
  }
44
44
  };
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvclRleHQuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsImxvY2F0b3IiLCJwYXR0ZXJuIiwidGltZW91dCIsImhlbHBlcnMiLCJhc3NlcnRBcmd1bWVudCIsImFzc2VydEFyZ3VtZW50VGltZW91dCIsImVsIiwiZ2V0RWxlbWVudCIsInRleHQiLCJkcml2ZXIiLCJ3YWl0VW50aWwiLCJnZXRUZXh0IiwibWF0Y2hQYXR0ZXJuIiwid2FpdEZvclRpbWVvdXQiLCJlIiwicmVwbGFjZSIsIk94RXJyb3IiLCJlcnJIZWxwZXIiLCJlcnJvckNvZGUiLCJUSU1FT1VUIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBQSxNQUFNLENBQUNDLE9BQVAsR0FBaUIsZ0JBQWVDLE9BQWYsRUFBd0JDLE9BQXhCLEVBQWlDQyxPQUFqQyxFQUEwQztBQUN2RCxPQUFLQyxPQUFMLENBQWFDLGNBQWIsQ0FBNEJILE9BQTVCLEVBQXFDLFNBQXJDO0FBQ0EsT0FBS0UsT0FBTCxDQUFhRSxxQkFBYixDQUFtQ0gsT0FBbkMsRUFBNEMsU0FBNUM7QUFFQSxNQUFJSSxFQUFFLEdBQUcsTUFBTSxLQUFLSCxPQUFMLENBQWFJLFVBQWIsQ0FBd0JQLE9BQXhCLEVBQWlDLEtBQWpDLEVBQXdDRSxPQUF4QyxDQUFmO0FBRUEsTUFBSU0sSUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTSxLQUFLQyxNQUFMLENBQVlDLFNBQVosQ0FBc0IsWUFBVztBQUNuQ0YsTUFBQUEsSUFBSSxHQUFHLE1BQU1GLEVBQUUsQ0FBQ0ssT0FBSCxFQUFiO0FBQ0EsYUFBTyxLQUFLUixPQUFMLENBQWFTLFlBQWIsQ0FBMEJKLElBQTFCLEVBQWdDUCxPQUFoQyxDQUFQO0FBQ0gsS0FISyxFQUlOO0FBQUVDLE1BQUFBLE9BQU8sRUFBR0EsT0FBTyxHQUFHQSxPQUFILEdBQWEsS0FBS1c7QUFBckMsS0FKTSxDQUFOO0FBS0gsR0FORCxDQU1FLE9BQU9DLENBQVAsRUFBVTtBQUNSTixJQUFBQSxJQUFJLEdBQUdBLElBQUksQ0FBQ08sT0FBTCxDQUFhLEtBQWIsRUFBb0IsS0FBcEIsQ0FBUDtBQUNBLFVBQU0sSUFBSSxLQUFLQyxPQUFULENBQWlCLEtBQUtDLFNBQUwsQ0FBZUMsU0FBZixDQUF5QkMsT0FBMUMsRUFBb0QsY0FBYWxCLE9BQVEsWUFBV08sSUFBSyxHQUF6RixDQUFOO0FBQ0g7QUFDSixDQWpCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoQykgMjAxNS1wcmVzZW50IENsb3VkQmVhdCBMaW1pdGVkXHJcbiAqXHJcbiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOiB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5XHJcbiAqIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5XHJcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXHJcbiAqIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIEBzdW1tYXJ5IFdhaXRzIGZvciBpbm5lciB0ZXh0IG9mIHRoZSBnaXZlbiBlbGVtZW50IHRvIG1hdGNoIHRoZSBzcGVjaWZpZWQgcGF0dGVybi5cclxuICogQGRlc2NyaXB0aW9uIFRleHQgcGF0dGVybiBjYW4gYmUgYW55IG9mIHRoZSBzdXBwb3J0ZWQgXHJcbiAqICBzdHJpbmcgbWF0Y2hpbmcgcGF0dGVybnMob24gdGhlIHRvcCBvZiBwYWdlKS5cclxuICogQGZ1bmN0aW9uIHdhaXRGb3JUZXh0XHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVGV4dCBwYXR0ZXJuLlxyXG4gKiBAcGFyYW0ge051bWJlcj19IHRpbWVvdXQgLSBUaW1lb3V0IGluIG1pbGxpc2Vjb25kcy4gRGVmYXVsdCBpcyA2MCBzZWNvbmRzLlxyXG4gKiBAZXhhbXBsZSA8Y2FwdGlvbj5bamF2YXNjcmlwdF0gVXNhZ2UgZXhhbXBsZTwvY2FwdGlvbj5cclxuICogd2ViLmluaXQoKTsvL09wZW5zIGJyb3dzZXIgc2Vzc2lvbi5cclxuICogd2ViLm9wZW4oXCJ3d3cueW91cndlYnNpdGUuY29tXCIpOy8vIE9wZW5zIGEgd2Vic2l0ZS5cclxuICogd2ViLndhaXRGb3JUZXh0KFwiaWQ9VGl0bGVcIixcIldlYnNpdGVcIik7Ly9XYWl0cyBmb3IgYW4gZWxlbWVudOKAmXMgdGV4dCB0byAgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFRleHQoKTtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuaGVscGVycy5tYXRjaFBhdHRlcm4odGV4dCwgcGF0dGVybik7XHJcbiAgICAgICAgfSxcclxuICAgICAgICB7IHRpbWVvdXQ6ICh0aW1lb3V0ID8gdGltZW91dCA6IHRoaXMud2FpdEZvclRpbWVvdXQpIH0pO1xyXG4gICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgIHRleHQgPSB0ZXh0LnJlcGxhY2UoL1xcbi9nLCAnXFxcXG4nKTtcclxuICAgICAgICB0aHJvdyBuZXcgdGhpcy5PeEVycm9yKHRoaXMuZXJySGVscGVyLmVycm9yQ29kZS5USU1FT1VULCBgRXhwZWN0ZWQ6IFwiJHtwYXR0ZXJufVwiLiBHb3Q6IFwiJHt0ZXh0fVwiYCk7XHJcbiAgICB9XHJcbn07XHJcbiJdfQ==
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvclRleHQuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsImxvY2F0b3IiLCJwYXR0ZXJuIiwidGltZW91dCIsImhlbHBlcnMiLCJhc3NlcnRBcmd1bWVudCIsImFzc2VydEFyZ3VtZW50VGltZW91dCIsImVsIiwiZ2V0RWxlbWVudCIsInRleHQiLCJkcml2ZXIiLCJ3YWl0VW50aWwiLCJnZXRUZXh0IiwibWF0Y2hQYXR0ZXJuIiwid2FpdEZvclRpbWVvdXQiLCJlIiwicmVwbGFjZSIsIk94RXJyb3IiLCJlcnJIZWxwZXIiLCJlcnJvckNvZGUiLCJUSU1FT1VUIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBQSxNQUFNLENBQUNDLE9BQVAsR0FBaUIsZ0JBQWVDLE9BQWYsRUFBd0JDLE9BQXhCLEVBQWlDQyxPQUFqQyxFQUEwQztBQUN2RCxPQUFLQyxPQUFMLENBQWFDLGNBQWIsQ0FBNEJILE9BQTVCLEVBQXFDLFNBQXJDO0FBQ0EsT0FBS0UsT0FBTCxDQUFhRSxxQkFBYixDQUFtQ0gsT0FBbkMsRUFBNEMsU0FBNUM7QUFFQSxNQUFJSSxFQUFFLEdBQUcsTUFBTSxLQUFLSCxPQUFMLENBQWFJLFVBQWIsQ0FBd0JQLE9BQXhCLEVBQWlDLEtBQWpDLEVBQXdDRSxPQUF4QyxDQUFmO0FBRUEsTUFBSU0sSUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTSxLQUFLQyxNQUFMLENBQVlDLFNBQVosQ0FBc0IsWUFBVztBQUNuQ0YsTUFBQUEsSUFBSSxHQUFHLE1BQU1GLEVBQUUsQ0FBQ0ssT0FBSCxFQUFiO0FBQ0EsYUFBTyxLQUFLUixPQUFMLENBQWFTLFlBQWIsQ0FBMEJKLElBQTFCLEVBQWdDUCxPQUFoQyxDQUFQO0FBQ0gsS0FISyxFQUlOO0FBQUVDLE1BQUFBLE9BQU8sRUFBR0EsT0FBTyxHQUFHQSxPQUFILEdBQWEsS0FBS1c7QUFBckMsS0FKTSxDQUFOO0FBS0gsR0FORCxDQU1FLE9BQU9DLENBQVAsRUFBVTtBQUNSLFFBQUlOLElBQUosRUFDSUEsSUFBSSxHQUFHQSxJQUFJLENBQUNPLE9BQUwsQ0FBYSxLQUFiLEVBQW9CLEtBQXBCLENBQVA7QUFDSixVQUFNLElBQUksS0FBS0MsT0FBVCxDQUFpQixLQUFLQyxTQUFMLENBQWVDLFNBQWYsQ0FBeUJDLE9BQTFDLEVBQW9ELGNBQWFsQixPQUFRLFlBQVdPLElBQUssR0FBekYsQ0FBTjtBQUNIO0FBQ0osQ0FsQkQiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBDb3B5cmlnaHQgKEMpIDIwMTUtcHJlc2VudCBDbG91ZEJlYXQgTGltaXRlZFxyXG4gKlxyXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxyXG4gKiBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieVxyXG4gKiB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uLCBlaXRoZXIgdmVyc2lvbiAzIG9mIHRoZSBMaWNlbnNlLCBvclxyXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxyXG4gKi9cclxuXHJcbi8qKlxyXG4gKiBAc3VtbWFyeSBXYWl0cyBmb3IgaW5uZXIgdGV4dCBvZiB0aGUgZ2l2ZW4gZWxlbWVudCB0byBtYXRjaCB0aGUgc3BlY2lmaWVkIHBhdHRlcm4uXHJcbiAqIEBkZXNjcmlwdGlvbiBUZXh0IHBhdHRlcm4gY2FuIGJlIGFueSBvZiB0aGUgc3VwcG9ydGVkXHJcbiAqICBzdHJpbmcgbWF0Y2hpbmcgcGF0dGVybnMob24gdGhlIHRvcCBvZiBwYWdlKS5cclxuICogQGZ1bmN0aW9uIHdhaXRGb3JUZXh0XHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVGV4dCBwYXR0ZXJuLlxyXG4gKiBAcGFyYW0ge051bWJlcj19IHRpbWVvdXQgLSBUaW1lb3V0IGluIG1pbGxpc2Vjb25kcy4gRGVmYXVsdCBpcyA2MCBzZWNvbmRzLlxyXG4gKiBAZXhhbXBsZSA8Y2FwdGlvbj5bamF2YXNjcmlwdF0gVXNhZ2UgZXhhbXBsZTwvY2FwdGlvbj5cclxuICogd2ViLmluaXQoKTsvL09wZW5zIGJyb3dzZXIgc2Vzc2lvbi5cclxuICogd2ViLm9wZW4oXCJ3d3cueW91cndlYnNpdGUuY29tXCIpOy8vIE9wZW5zIGEgd2Vic2l0ZS5cclxuICogd2ViLndhaXRGb3JUZXh0KFwiaWQ9VGl0bGVcIixcIldlYnNpdGVcIik7Ly9XYWl0cyBmb3IgYW4gZWxlbWVudOKAmXMgdGV4dCB0byAgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFRleHQoKTtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuaGVscGVycy5tYXRjaFBhdHRlcm4odGV4dCwgcGF0dGVybik7XHJcbiAgICAgICAgfSxcclxuICAgICAgICB7IHRpbWVvdXQ6ICh0aW1lb3V0ID8gdGltZW91dCA6IHRoaXMud2FpdEZvclRpbWVvdXQpIH0pO1xyXG4gICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgIGlmICh0ZXh0KVxyXG4gICAgICAgICAgICB0ZXh0ID0gdGV4dC5yZXBsYWNlKC9cXG4vZywgJ1xcXFxuJyk7XHJcbiAgICAgICAgdGhyb3cgbmV3IHRoaXMuT3hFcnJvcih0aGlzLmVyckhlbHBlci5lcnJvckNvZGUuVElNRU9VVCwgYEV4cGVjdGVkOiBcIiR7cGF0dGVybn1cIi4gR290OiBcIiR7dGV4dH1cImApO1xyXG4gICAgfVxyXG59O1xyXG4iXX0=
@@ -13,7 +13,7 @@ require("source-map-support/register");
13
13
 
14
14
  /**
15
15
  * @summary Waits for input element's value to match the specified pattern.
16
- * @description Value pattern can be any of the supported
16
+ * @description Value pattern can be any of the supported
17
17
  * string matching patterns(on the top of page).
18
18
  * @function waitForValue
19
19
  * @param {String|Element} locator - An element locator.
@@ -38,8 +38,8 @@ module.exports = async function (locator, pattern, timeout) {
38
38
  timeout: timeout ? timeout : this.waitForTimeout
39
39
  });
40
40
  } catch (e) {
41
- text = text.replace(/\n/g, '\\n');
41
+ if (text) text = text.replace(/\n/g, '\\n');
42
42
  throw new this.OxError(this.errHelper.errorCode.TIMEOUT, `Expected: "${pattern}". Got: "${text}"`);
43
43
  }
44
44
  };
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvclZhbHVlLmpzIl0sIm5hbWVzIjpbIm1vZHVsZSIsImV4cG9ydHMiLCJsb2NhdG9yIiwicGF0dGVybiIsInRpbWVvdXQiLCJoZWxwZXJzIiwiYXNzZXJ0QXJndW1lbnQiLCJhc3NlcnRBcmd1bWVudFRpbWVvdXQiLCJlbCIsImdldEVsZW1lbnQiLCJ0ZXh0IiwiZHJpdmVyIiwid2FpdFVudGlsIiwiZ2V0VmFsdWUiLCJtYXRjaFBhdHRlcm4iLCJ3YWl0Rm9yVGltZW91dCIsImUiLCJyZXBsYWNlIiwiT3hFcnJvciIsImVyckhlbHBlciIsImVycm9yQ29kZSIsIlRJTUVPVVQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0FBLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQixnQkFBZUMsT0FBZixFQUF3QkMsT0FBeEIsRUFBaUNDLE9BQWpDLEVBQTBDO0FBQ3ZELE9BQUtDLE9BQUwsQ0FBYUMsY0FBYixDQUE0QkgsT0FBNUIsRUFBcUMsU0FBckM7QUFDQSxPQUFLRSxPQUFMLENBQWFFLHFCQUFiLENBQW1DSCxPQUFuQyxFQUE0QyxTQUE1QztBQUVBLE1BQUlJLEVBQUUsR0FBRyxNQUFNLEtBQUtILE9BQUwsQ0FBYUksVUFBYixDQUF3QlAsT0FBeEIsRUFBaUMsS0FBakMsRUFBd0NFLE9BQXhDLENBQWY7QUFFQSxNQUFJTSxJQUFKOztBQUNBLE1BQUk7QUFDQSxVQUFNLEtBQUtDLE1BQUwsQ0FBWUMsU0FBWixDQUFzQixZQUFXO0FBQ25DRixNQUFBQSxJQUFJLEdBQUcsTUFBTUYsRUFBRSxDQUFDSyxRQUFILEVBQWI7QUFDQSxhQUFPLEtBQUtSLE9BQUwsQ0FBYVMsWUFBYixDQUEwQkosSUFBMUIsRUFBZ0NQLE9BQWhDLENBQVA7QUFDSCxLQUhLLEVBSU47QUFBRUMsTUFBQUEsT0FBTyxFQUFHQSxPQUFPLEdBQUdBLE9BQUgsR0FBYSxLQUFLVztBQUFyQyxLQUpNLENBQU47QUFLSCxHQU5ELENBTUUsT0FBT0MsQ0FBUCxFQUFVO0FBQ1JOLElBQUFBLElBQUksR0FBR0EsSUFBSSxDQUFDTyxPQUFMLENBQWEsS0FBYixFQUFvQixLQUFwQixDQUFQO0FBQ0EsVUFBTSxJQUFJLEtBQUtDLE9BQVQsQ0FBaUIsS0FBS0MsU0FBTCxDQUFlQyxTQUFmLENBQXlCQyxPQUExQyxFQUFvRCxjQUFhbEIsT0FBUSxZQUFXTyxJQUFLLEdBQXpGLENBQU47QUFDSDtBQUNKLENBakJEIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogQ29weXJpZ2h0IChDKSAyMDE1LXByZXNlbnQgQ2xvdWRCZWF0IExpbWl0ZWRcclxuICpcclxuICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU6IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnlcclxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcclxuICogdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbiwgZWl0aGVyIHZlcnNpb24gMyBvZiB0aGUgTGljZW5zZSwgb3JcclxuICogKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi5cclxuICovXHJcblxyXG4vKipcclxuICogQHN1bW1hcnkgV2FpdHMgZm9yIGlucHV0IGVsZW1lbnQncyB2YWx1ZSB0byBtYXRjaCB0aGUgc3BlY2lmaWVkIHBhdHRlcm4uXHJcbiAqIEBkZXNjcmlwdGlvbiBWYWx1ZSBwYXR0ZXJuIGNhbiBiZSBhbnkgb2YgdGhlIHN1cHBvcnRlZCBcclxuICogIHN0cmluZyBtYXRjaGluZyBwYXR0ZXJucyhvbiB0aGUgdG9wIG9mIHBhZ2UpLlxyXG4gKiBAZnVuY3Rpb24gd2FpdEZvclZhbHVlXHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVmFsdWUgcGF0dGVybi5cclxuICogQHBhcmFtIHtOdW1iZXI9fSB0aW1lb3V0IC0gVGltZW91dCBpbiBtaWxsaXNlY29uZHMuIERlZmF1bHQgaXMgNjAgc2Vjb25kcy5cclxuICogQGV4YW1wbGUgPGNhcHRpb24+W2phdmFzY3JpcHRdIFVzYWdlIGV4YW1wbGU8L2NhcHRpb24+XHJcbiAqIHdlYi5pbml0KCk7Ly9PcGVucyBicm93c2VyIHNlc3Npb24uXHJcbiAqIHdlYi5vcGVuKFwid3d3LnlvdXJ3ZWJzaXRlLmNvbVwiKTsvLyBPcGVucyBhIHdlYnNpdGUuXHJcbiAqIHdlYi53YWl0Rm9yVmFsdWUoXCJpZD1UaXRsZVwiLFwiV2Vic2l0ZVwiKTsvL1dhaXRzIGZvciBhbiBlbGVtZW504oCZcyB2YWx1ZSB0byAgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFZhbHVlKCk7XHJcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmhlbHBlcnMubWF0Y2hQYXR0ZXJuKHRleHQsIHBhdHRlcm4pO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgeyB0aW1lb3V0OiAodGltZW91dCA/IHRpbWVvdXQgOiB0aGlzLndhaXRGb3JUaW1lb3V0KSB9KTtcclxuICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICB0ZXh0ID0gdGV4dC5yZXBsYWNlKC9cXG4vZywgJ1xcXFxuJyk7XHJcbiAgICAgICAgdGhyb3cgbmV3IHRoaXMuT3hFcnJvcih0aGlzLmVyckhlbHBlci5lcnJvckNvZGUuVElNRU9VVCwgYEV4cGVjdGVkOiBcIiR7cGF0dGVybn1cIi4gR290OiBcIiR7dGV4dH1cImApO1xyXG4gICAgfVxyXG59O1xyXG4iXX0=
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS13ZWIvY29tbWFuZHMvd2FpdEZvclZhbHVlLmpzIl0sIm5hbWVzIjpbIm1vZHVsZSIsImV4cG9ydHMiLCJsb2NhdG9yIiwicGF0dGVybiIsInRpbWVvdXQiLCJoZWxwZXJzIiwiYXNzZXJ0QXJndW1lbnQiLCJhc3NlcnRBcmd1bWVudFRpbWVvdXQiLCJlbCIsImdldEVsZW1lbnQiLCJ0ZXh0IiwiZHJpdmVyIiwid2FpdFVudGlsIiwiZ2V0VmFsdWUiLCJtYXRjaFBhdHRlcm4iLCJ3YWl0Rm9yVGltZW91dCIsImUiLCJyZXBsYWNlIiwiT3hFcnJvciIsImVyckhlbHBlciIsImVycm9yQ29kZSIsIlRJTUVPVVQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0FBLE1BQU0sQ0FBQ0MsT0FBUCxHQUFpQixnQkFBZUMsT0FBZixFQUF3QkMsT0FBeEIsRUFBaUNDLE9BQWpDLEVBQTBDO0FBQ3ZELE9BQUtDLE9BQUwsQ0FBYUMsY0FBYixDQUE0QkgsT0FBNUIsRUFBcUMsU0FBckM7QUFDQSxPQUFLRSxPQUFMLENBQWFFLHFCQUFiLENBQW1DSCxPQUFuQyxFQUE0QyxTQUE1QztBQUVBLE1BQUlJLEVBQUUsR0FBRyxNQUFNLEtBQUtILE9BQUwsQ0FBYUksVUFBYixDQUF3QlAsT0FBeEIsRUFBaUMsS0FBakMsRUFBd0NFLE9BQXhDLENBQWY7QUFFQSxNQUFJTSxJQUFKOztBQUNBLE1BQUk7QUFDQSxVQUFNLEtBQUtDLE1BQUwsQ0FBWUMsU0FBWixDQUFzQixZQUFXO0FBQ25DRixNQUFBQSxJQUFJLEdBQUcsTUFBTUYsRUFBRSxDQUFDSyxRQUFILEVBQWI7QUFDQSxhQUFPLEtBQUtSLE9BQUwsQ0FBYVMsWUFBYixDQUEwQkosSUFBMUIsRUFBZ0NQLE9BQWhDLENBQVA7QUFDSCxLQUhLLEVBSU47QUFBRUMsTUFBQUEsT0FBTyxFQUFHQSxPQUFPLEdBQUdBLE9BQUgsR0FBYSxLQUFLVztBQUFyQyxLQUpNLENBQU47QUFLSCxHQU5ELENBTUUsT0FBT0MsQ0FBUCxFQUFVO0FBQ1IsUUFBSU4sSUFBSixFQUNJQSxJQUFJLEdBQUdBLElBQUksQ0FBQ08sT0FBTCxDQUFhLEtBQWIsRUFBb0IsS0FBcEIsQ0FBUDtBQUNKLFVBQU0sSUFBSSxLQUFLQyxPQUFULENBQWlCLEtBQUtDLFNBQUwsQ0FBZUMsU0FBZixDQUF5QkMsT0FBMUMsRUFBb0QsY0FBYWxCLE9BQVEsWUFBV08sSUFBSyxHQUF6RixDQUFOO0FBQ0g7QUFDSixDQWxCRCIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoQykgMjAxNS1wcmVzZW50IENsb3VkQmVhdCBMaW1pdGVkXHJcbiAqXHJcbiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOiB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5XHJcbiAqIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5XHJcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXHJcbiAqIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIEBzdW1tYXJ5IFdhaXRzIGZvciBpbnB1dCBlbGVtZW50J3MgdmFsdWUgdG8gbWF0Y2ggdGhlIHNwZWNpZmllZCBwYXR0ZXJuLlxyXG4gKiBAZGVzY3JpcHRpb24gVmFsdWUgcGF0dGVybiBjYW4gYmUgYW55IG9mIHRoZSBzdXBwb3J0ZWRcclxuICogIHN0cmluZyBtYXRjaGluZyBwYXR0ZXJucyhvbiB0aGUgdG9wIG9mIHBhZ2UpLlxyXG4gKiBAZnVuY3Rpb24gd2FpdEZvclZhbHVlXHJcbiAqIEBwYXJhbSB7U3RyaW5nfEVsZW1lbnR9IGxvY2F0b3IgLSBBbiBlbGVtZW50IGxvY2F0b3IuXHJcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXR0ZXJuIC0gVmFsdWUgcGF0dGVybi5cclxuICogQHBhcmFtIHtOdW1iZXI9fSB0aW1lb3V0IC0gVGltZW91dCBpbiBtaWxsaXNlY29uZHMuIERlZmF1bHQgaXMgNjAgc2Vjb25kcy5cclxuICogQGV4YW1wbGUgPGNhcHRpb24+W2phdmFzY3JpcHRdIFVzYWdlIGV4YW1wbGU8L2NhcHRpb24+XHJcbiAqIHdlYi5pbml0KCk7Ly9PcGVucyBicm93c2VyIHNlc3Npb24uXHJcbiAqIHdlYi5vcGVuKFwid3d3LnlvdXJ3ZWJzaXRlLmNvbVwiKTsvLyBPcGVucyBhIHdlYnNpdGUuXHJcbiAqIHdlYi53YWl0Rm9yVmFsdWUoXCJpZD1UaXRsZVwiLFwiV2Vic2l0ZVwiKTsvL1dhaXRzIGZvciBhbiBlbGVtZW504oCZcyB2YWx1ZSB0byAgbWF0Y2ggdG8gZXhwZWN0ZWQgc3RyaW5nLlxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbihsb2NhdG9yLCBwYXR0ZXJuLCB0aW1lb3V0KSB7XHJcbiAgICB0aGlzLmhlbHBlcnMuYXNzZXJ0QXJndW1lbnQocGF0dGVybiwgJ3BhdHRlcm4nKTtcclxuICAgIHRoaXMuaGVscGVycy5hc3NlcnRBcmd1bWVudFRpbWVvdXQodGltZW91dCwgJ3RpbWVvdXQnKTtcclxuXHJcbiAgICB2YXIgZWwgPSBhd2FpdCB0aGlzLmhlbHBlcnMuZ2V0RWxlbWVudChsb2NhdG9yLCBmYWxzZSwgdGltZW91dCk7XHJcblxyXG4gICAgdmFyIHRleHQ7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLndhaXRVbnRpbChhc3luYygpID0+IHtcclxuICAgICAgICAgICAgdGV4dCA9IGF3YWl0IGVsLmdldFZhbHVlKCk7XHJcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmhlbHBlcnMubWF0Y2hQYXR0ZXJuKHRleHQsIHBhdHRlcm4pO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgeyB0aW1lb3V0OiAodGltZW91dCA/IHRpbWVvdXQgOiB0aGlzLndhaXRGb3JUaW1lb3V0KSB9KTtcclxuICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgICBpZiAodGV4dClcclxuICAgICAgICAgICAgdGV4dCA9IHRleHQucmVwbGFjZSgvXFxuL2csICdcXFxcbicpO1xyXG4gICAgICAgIHRocm93IG5ldyB0aGlzLk94RXJyb3IodGhpcy5lcnJIZWxwZXIuZXJyb3JDb2RlLlRJTUVPVVQsIGBFeHBlY3RlZDogXCIke3BhdHRlcm59XCIuIEdvdDogXCIke3RleHR9XCJgKTtcclxuICAgIH1cclxufTtcclxuIl19
@@ -89,6 +89,26 @@ class OxygenWorker extends EventEmitter {
89
89
  try {
90
90
  require.cache[require.resolve(scriptPath)] && delete require.cache[require.resolve(scriptPath)];
91
91
 
92
+ const Module = require('module');
93
+
94
+ const originalRequire = Module.prototype.require;
95
+
96
+ Module.prototype.require = function () {
97
+ const script = arguments['0'];
98
+
99
+ try {
100
+ if (script && script.startsWith('.')) {
101
+ var resolvedPath = require.resolve(path.resolve(path.dirname(scriptPath), script));
102
+
103
+ if (require.cache[resolvedPath]) {
104
+ delete require.cache[resolvedPath];
105
+ }
106
+ }
107
+ } catch (ex) {}
108
+
109
+ return originalRequire.apply(this, arguments);
110
+ };
111
+
92
112
  require(scriptPath);
93
113
  } catch (e) {
94
114
  if (e && e.type && e.type === errorHelper.errorCode.ASSERT_PASSED) {} else {
@@ -243,4 +263,4 @@ class OxygenWorker extends EventEmitter {
243
263
  }
244
264
 
245
265
  exports.default = OxygenWorker;
246
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/runners/oxygen/OxygenWorker.js"],"names":["Fiber","require","path","EventEmitter","Oxygen","default","oxutil","errorHelper","module","global","browser","OxygenWorker","constructor","reporter","logger","_oxygen","_opts","_logger","_testHooks","_reporter","_runId","init","runId","options","caps","_cwd","cwd","process","on","_handleBeforeCommand","bind","_handleAfterCommand","_handleLogEntry","loadTestHooks","debug","e","toString","run","scriptPath","context","poFile","Error","loadPageObjectFile","_steps","isAbsolute","resolve","error","onBeforeCase","_runFnInFiberContext","cache","type","errorCode","ASSERT_PASSED","_waitStepResult","getFailureFromError","moduleCaps","getModulesCapabilities","onAfterCase","resultStore","results","resetResults","oxContext","vars","dispose","status","disposeModules","callTestHook","hookName","hookArgs","executeTestHook","fn","Promise","reject","result","apply","err","replStart","commandResolve","setTimeout","modules","keys","Object","map","item","driver","emit","push","level","message","src"],"mappings":"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","sourcesContent":["/*\r\n * Copyright (C) 2019-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 * Based on:\r\n * Copyright (c) OpenJS Foundation and other contributors. Licensed under MIT.\r\n */\r\n\r\nconst Fiber = require('fibers');\r\nconst path = require('path');\r\nconst { EventEmitter } = require('events');\r\n\r\nconst Oxygen = require('../../core/OxygenCore').default;\r\nconst oxutil = require('../../lib/util');\r\nconst errorHelper = require('../../errors/helper');\r\n\r\n// eslint-disable-next-line no-global-assign\r\nrequire = require('esm')(module);\r\n\r\n// mockup globbal.browser object for internal WDIO functions to work properly\r\nglobal.browser = {};\r\n\r\nexport default class OxygenWorker extends EventEmitter {\r\n    constructor (reporter, logger) {\r\n        super();\r\n        this._oxygen = null;\r\n        this._opts = null;\r\n        this._logger = logger;\r\n        this._testHooks = {};\r\n        this._reporter = reporter;\r\n        this._runId = null;\r\n    }\r\n\r\n    async init(runId, options, caps) {\r\n        this._runId = runId;\r\n        this._opts = options;\r\n        this._cwd = this._opts.cwd || process.cwd();\r\n\r\n        if (!this._oxygen) {\r\n            try {\r\n                this._oxygen = new Oxygen();\r\n                this._oxygen.on('command:before', this._handleBeforeCommand.bind(this));\r\n                this._oxygen.on('command:after', this._handleAfterCommand.bind(this));\r\n                this._oxygen.on('log', this._handleLogEntry.bind(this));\r\n                await this._oxygen.init(options, caps);\r\n                this._testHooks = oxutil.loadTestHooks(options);\r\n                //makeModulesGlobal(options);\r\n                this._logger.debug('Oxygen initialization completed');\r\n            }\r\n            catch (e) {\r\n                this._logger.debug(`Oxygen initialization failed: ${e.toString()}`);\r\n                throw e;\r\n            }\r\n        }\r\n    }\r\n\r\n    async run({ scriptPath, context, poFile = null }) {\r\n        // assign up to date context to Oxygen Core to reflect new parameters and other context data\r\n        if (!this._oxygen) {\r\n            throw Error ('Oxygen is not initialized');\r\n        }\r\n        this._oxygen.context = context;\r\n        this._oxygen.loadPageObjectFile(poFile);\r\n        this._steps = [];\r\n        if (this._cwd && !path.isAbsolute(scriptPath)) {\r\n            scriptPath = path.resolve(this._cwd, scriptPath);\r\n        }\r\n        let error = null;\r\n        // load and run the test script\r\n        try {\r\n            this._oxygen && this._oxygen.onBeforeCase && await this._oxygen.onBeforeCase(context);\r\n            await this._runFnInFiberContext(() => {\r\n                try {\r\n                    // make sure to clear require cache so the script will be executed on each iteration\r\n                    require.cache[require.resolve(scriptPath)] && delete require.cache[require.resolve(scriptPath)];\r\n                    require(scriptPath);\r\n                }\r\n                catch (e) {\r\n                    // error = e.code && e.code === 'MODULE_NOT_FOUND' ? new ScriptNotFoundError(scriptPath) : e;\r\n\r\n                    if (e && e.type && e.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n                        //ignore\r\n                    } else {\r\n                        error = e;\r\n                    }\r\n                }\r\n            });\r\n        } catch (e) {\r\n            error = e;\r\n        }\r\n\r\n        // In some cases step result generation takes some time to make screenshot\r\n        await this._oxygen._waitStepResult();\r\n\r\n        if (error) {\r\n            error = errorHelper.getFailureFromError(error);\r\n        }\r\n\r\n        let moduleCaps = {};\r\n\r\n        if (this._oxygen && this._oxygen.getModulesCapabilities) {\r\n            moduleCaps = this._oxygen.getModulesCapabilities();\r\n        }\r\n\r\n        this._oxygen && this._oxygen.onAfterCase && await this._oxygen.onAfterCase(error);\r\n\r\n        // clone the results, otherwise resultStore will be empty after the following this._oxygen.resetResults() call\r\n\r\n        let resultStore = {};\r\n\r\n        if (this._oxygen && this._oxygen.results) {\r\n            resultStore = { ...this._oxygen.results };\r\n        }\r\n\r\n        if (this._oxygen && this._oxygen.resetResults) {\r\n            // reset steps and other result data\r\n            this._oxygen.resetResults();\r\n        }\r\n        this._steps = null;\r\n\r\n        let oxContext = {};\r\n        if (this._oxygen && this._oxygen.context) {\r\n            oxContext = this._oxygen.context;\r\n        }\r\n        oxContext.vars = global.vars;\r\n\r\n        return { error, moduleCaps, resultStore, context: oxContext };\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        if (this._oxygen) {\r\n            try {\r\n                await this._oxygen.dispose(status);\r\n            }\r\n            catch (e) {\r\n                this._logger.error('Failed to dispose Oxygen', null, e);\r\n            }\r\n            finally {\r\n                this._steps = null;\r\n            }\r\n        }\r\n    }\r\n\r\n    async disposeModules(status = null) {\r\n        if (this._oxygen) {\r\n            try {\r\n                await this._oxygen.disposeModules(status);\r\n            }\r\n            catch (e) {\r\n                this._logger.error('Failed to dispose Oxygen modules', null, e);\r\n            }\r\n            finally {\r\n                this._oxygen.resetResults();\r\n            }\r\n        }\r\n    }\r\n\r\n    async callTestHook(hookName, hookArgs) {\r\n        if (!this._testHooks || !this._testHooks[hookName] || typeof this._testHooks[hookName] !== 'function') {\r\n            throw new Error(`Hook does not exist: ${hookName}`);\r\n        }\r\n        await oxutil.executeTestHook(this._testHooks, hookName, hookArgs);\r\n    }\r\n\r\n    async _runFnInFiberContext (fn) {\r\n        return new Promise((resolve, reject) => Fiber(() => {\r\n            try {\r\n                const result = fn.apply(this);\r\n                return resolve(result);\r\n            } catch (err) {\r\n                return reject(err);\r\n            }\r\n        }).run());\r\n    }\r\n\r\n    async replStart() {\r\n        let commandResolve = () => { };\r\n\r\n        setTimeout(async() => {\r\n            if (this._oxygen && this._oxygen.modules) {\r\n                const keys = Object.keys(this._oxygen.modules);\r\n                let debug;\r\n                keys.map((item) => {\r\n                    const driver = this._oxygen.modules[item]['getDriver'] && this._oxygen.modules[item]['getDriver']();\r\n                    if (driver) {\r\n                        debug = this._oxygen.modules[item]['debug'];\r\n                    }\r\n                });\r\n\r\n                if (debug) {\r\n                    await debug();\r\n                    commandResolve();\r\n                } else {\r\n                    commandResolve();\r\n                }\r\n            } else {\r\n                commandResolve();\r\n            }\r\n        }, 10);\r\n\r\n        return new Promise((resolve) => (commandResolve = resolve));\r\n    }\r\n\r\n    _handleBeforeCommand(e) {\r\n        if (!e) {\r\n            return;\r\n        }\r\n        this.emit('command:before', e);\r\n    }\r\n\r\n    _handleAfterCommand(e) {\r\n        if (!e || !e.result) {\r\n            return;\r\n        }\r\n\r\n        this._steps && this._steps.push(e.result);\r\n        this.emit('command:after', e);\r\n    }\r\n\r\n    _handleLogEntry(e) {\r\n        if (!e || !e.level || !e.message) {\r\n            return;\r\n        }\r\n        if (e && e.level && e.level === 'error') {\r\n            this._logger[e.level](e.message, e.src, e.err);\r\n        } else {\r\n            this._logger[e.level](e.message, e.src);\r\n        }\r\n    }\r\n}\r\n"]}
266
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/runners/oxygen/OxygenWorker.js"],"names":["Fiber","require","path","EventEmitter","Oxygen","default","oxutil","errorHelper","module","global","browser","OxygenWorker","constructor","reporter","logger","_oxygen","_opts","_logger","_testHooks","_reporter","_runId","init","runId","options","caps","_cwd","cwd","process","on","_handleBeforeCommand","bind","_handleAfterCommand","_handleLogEntry","loadTestHooks","debug","e","toString","run","scriptPath","context","poFile","Error","loadPageObjectFile","_steps","isAbsolute","resolve","error","onBeforeCase","_runFnInFiberContext","cache","Module","originalRequire","prototype","script","arguments","startsWith","resolvedPath","dirname","ex","apply","type","errorCode","ASSERT_PASSED","_waitStepResult","getFailureFromError","moduleCaps","getModulesCapabilities","onAfterCase","resultStore","results","resetResults","oxContext","vars","dispose","status","disposeModules","callTestHook","hookName","hookArgs","executeTestHook","fn","Promise","reject","result","err","replStart","commandResolve","setTimeout","modules","keys","Object","map","item","driver","emit","push","level","message","src"],"mappings":"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","sourcesContent":["/*\r\n * Copyright (C) 2019-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 * Based on:\r\n * Copyright (c) OpenJS Foundation and other contributors. Licensed under MIT.\r\n */\r\n\r\nconst Fiber = require('fibers');\r\nconst path = require('path');\r\nconst { EventEmitter } = require('events');\r\n\r\nconst Oxygen = require('../../core/OxygenCore').default;\r\nconst oxutil = require('../../lib/util');\r\nconst errorHelper = require('../../errors/helper');\r\n\r\n// eslint-disable-next-line no-global-assign\r\nrequire = require('esm')(module);\r\n\r\n// mockup globbal.browser object for internal WDIO functions to work properly\r\nglobal.browser = {};\r\n\r\nexport default class OxygenWorker extends EventEmitter {\r\n    constructor (reporter, logger) {\r\n        super();\r\n        this._oxygen = null;\r\n        this._opts = null;\r\n        this._logger = logger;\r\n        this._testHooks = {};\r\n        this._reporter = reporter;\r\n        this._runId = null;\r\n    }\r\n\r\n    async init(runId, options, caps) {\r\n        this._runId = runId;\r\n        this._opts = options;\r\n        this._cwd = this._opts.cwd || process.cwd();\r\n\r\n        if (!this._oxygen) {\r\n            try {\r\n                this._oxygen = new Oxygen();\r\n                this._oxygen.on('command:before', this._handleBeforeCommand.bind(this));\r\n                this._oxygen.on('command:after', this._handleAfterCommand.bind(this));\r\n                this._oxygen.on('log', this._handleLogEntry.bind(this));\r\n                await this._oxygen.init(options, caps);\r\n                this._testHooks = oxutil.loadTestHooks(options);\r\n                //makeModulesGlobal(options);\r\n                this._logger.debug('Oxygen initialization completed');\r\n            }\r\n            catch (e) {\r\n                this._logger.debug(`Oxygen initialization failed: ${e.toString()}`);\r\n                throw e;\r\n            }\r\n        }\r\n    }\r\n\r\n    async run({ scriptPath, context, poFile = null }) {\r\n        // assign up to date context to Oxygen Core to reflect new parameters and other context data\r\n        if (!this._oxygen) {\r\n            throw Error ('Oxygen is not initialized');\r\n        }\r\n        this._oxygen.context = context;\r\n        this._oxygen.loadPageObjectFile(poFile);\r\n        this._steps = [];\r\n        if (this._cwd && !path.isAbsolute(scriptPath)) {\r\n            scriptPath = path.resolve(this._cwd, scriptPath);\r\n        }\r\n        let error = null;\r\n        // load and run the test script\r\n        try {\r\n            this._oxygen && this._oxygen.onBeforeCase && await this._oxygen.onBeforeCase(context);\r\n            await this._runFnInFiberContext(() => {\r\n                try {\r\n                    // make sure to clear require cache so the script will be executed on each iteration\r\n                    require.cache[require.resolve(scriptPath)] && delete require.cache[require.resolve(scriptPath)];\r\n\r\n                    // if user uses require('./somescript.js') in multiple test scripts (cases), and somescript.js contains web/mob.init\r\n                    // then, when those scripts are executed in a suite, only first case will pass, the rest will fail with MODULE_NOT_INITIALIZED error.\r\n                    // this is because 'require' is cached, and when the first case is finished, the module is marked as isInitialized = false\r\n                    // and not re-initialized back on next case.\r\n                    // thus we clean user level scripts from 'require' cache.\r\n                    // FIXME: this should be probably fixed in a different way.\r\n                    const Module = require('module');\r\n                    const originalRequire = Module.prototype.require;\r\n\r\n                    Module.prototype.require = function() {\r\n                        const script = arguments['0'];\r\n                        try {\r\n                            // invalidate cache only for user level scripts (those starting with './')\r\n                            if (script && script.startsWith('.')) {\r\n                                var resolvedPath = require.resolve(path.resolve(path.dirname(scriptPath), script));\r\n                                if (require.cache[resolvedPath]) {\r\n                                    delete require.cache[resolvedPath];\r\n                                }\r\n                            }\r\n                        } catch (ex) {\r\n                            // ignored\r\n                        }\r\n                        return originalRequire.apply(this, arguments);\r\n                    };\r\n                    require(scriptPath);\r\n                }\r\n                catch (e) {\r\n                    // error = e.code && e.code === 'MODULE_NOT_FOUND' ? new ScriptNotFoundError(scriptPath) : e;\r\n\r\n                    if (e && e.type && e.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n                        //ignore\r\n                    } else {\r\n                        error = e;\r\n                    }\r\n                }\r\n            });\r\n        } catch (e) {\r\n            error = e;\r\n        }\r\n\r\n        // In some cases step result generation takes some time to make screenshot\r\n        await this._oxygen._waitStepResult();\r\n\r\n        if (error) {\r\n            error = errorHelper.getFailureFromError(error);\r\n        }\r\n\r\n        let moduleCaps = {};\r\n\r\n        if (this._oxygen && this._oxygen.getModulesCapabilities) {\r\n            moduleCaps = this._oxygen.getModulesCapabilities();\r\n        }\r\n\r\n        this._oxygen && this._oxygen.onAfterCase && await this._oxygen.onAfterCase(error);\r\n\r\n        // clone the results, otherwise resultStore will be empty after the following this._oxygen.resetResults() call\r\n\r\n        let resultStore = {};\r\n\r\n        if (this._oxygen && this._oxygen.results) {\r\n            resultStore = { ...this._oxygen.results };\r\n        }\r\n\r\n        if (this._oxygen && this._oxygen.resetResults) {\r\n            // reset steps and other result data\r\n            this._oxygen.resetResults();\r\n        }\r\n        this._steps = null;\r\n\r\n        let oxContext = {};\r\n        if (this._oxygen && this._oxygen.context) {\r\n            oxContext = this._oxygen.context;\r\n        }\r\n        oxContext.vars = global.vars;\r\n\r\n        return { error, moduleCaps, resultStore, context: oxContext };\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        if (this._oxygen) {\r\n            try {\r\n                await this._oxygen.dispose(status);\r\n            }\r\n            catch (e) {\r\n                this._logger.error('Failed to dispose Oxygen', null, e);\r\n            }\r\n            finally {\r\n                this._steps = null;\r\n            }\r\n        }\r\n    }\r\n\r\n    async disposeModules(status = null) {\r\n        if (this._oxygen) {\r\n            try {\r\n                await this._oxygen.disposeModules(status);\r\n            }\r\n            catch (e) {\r\n                this._logger.error('Failed to dispose Oxygen modules', null, e);\r\n            }\r\n            finally {\r\n                this._oxygen.resetResults();\r\n            }\r\n        }\r\n    }\r\n\r\n    async callTestHook(hookName, hookArgs) {\r\n        if (!this._testHooks || !this._testHooks[hookName] || typeof this._testHooks[hookName] !== 'function') {\r\n            throw new Error(`Hook does not exist: ${hookName}`);\r\n        }\r\n        await oxutil.executeTestHook(this._testHooks, hookName, hookArgs);\r\n    }\r\n\r\n    async _runFnInFiberContext (fn) {\r\n        return new Promise((resolve, reject) => Fiber(() => {\r\n            try {\r\n                const result = fn.apply(this);\r\n                return resolve(result);\r\n            } catch (err) {\r\n                return reject(err);\r\n            }\r\n        }).run());\r\n    }\r\n\r\n    async replStart() {\r\n        let commandResolve = () => { };\r\n\r\n        setTimeout(async() => {\r\n            if (this._oxygen && this._oxygen.modules) {\r\n                const keys = Object.keys(this._oxygen.modules);\r\n                let debug;\r\n                keys.map((item) => {\r\n                    const driver = this._oxygen.modules[item]['getDriver'] && this._oxygen.modules[item]['getDriver']();\r\n                    if (driver) {\r\n                        debug = this._oxygen.modules[item]['debug'];\r\n                    }\r\n                });\r\n\r\n                if (debug) {\r\n                    await debug();\r\n                    commandResolve();\r\n                } else {\r\n                    commandResolve();\r\n                }\r\n            } else {\r\n                commandResolve();\r\n            }\r\n        }, 10);\r\n\r\n        return new Promise((resolve) => (commandResolve = resolve));\r\n    }\r\n\r\n    _handleBeforeCommand(e) {\r\n        if (!e) {\r\n            return;\r\n        }\r\n        this.emit('command:before', e);\r\n    }\r\n\r\n    _handleAfterCommand(e) {\r\n        if (!e || !e.result) {\r\n            return;\r\n        }\r\n\r\n        this._steps && this._steps.push(e.result);\r\n        this.emit('command:after', e);\r\n    }\r\n\r\n    _handleLogEntry(e) {\r\n        if (!e || !e.level || !e.message) {\r\n            return;\r\n        }\r\n        if (e && e.level && e.level === 'error') {\r\n            this._logger[e.level](e.message, e.src, e.err);\r\n        } else {\r\n            this._logger[e.level](e.message, e.src);\r\n        }\r\n    }\r\n}\r\n"]}