appium-geckodriver 0.3.3 → 1.0.3

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/.eslintrc CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "extends": "appium"
2
+ "extends": "@appium/eslint-config-appium"
3
3
  }
@@ -0,0 +1,30 @@
1
+ name: Release
2
+
3
+ on:
4
+ workflow_dispatch:
5
+ push:
6
+ branches: [ master ]
7
+
8
+ jobs:
9
+ build:
10
+ runs-on: ubuntu-latest
11
+ steps:
12
+ - uses: actions/checkout@v2
13
+ - name: Use Node.js 14.x
14
+ uses: actions/setup-node@v1
15
+ with:
16
+ node-version: 14.x
17
+ - run: npm install --production
18
+ name: Install prod dependencies
19
+ - run: rm -rf package-lock.json
20
+ - run: npm shrinkwrap
21
+ - run: npm install --no-package-lock
22
+ name: Install dev dependencies
23
+ - run: npm test
24
+ name: Run NPM Test
25
+ - run: npx semantic-release
26
+ env:
27
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
28
+ NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
29
+ name: Release
30
+
package/.releaserc ADDED
@@ -0,0 +1,18 @@
1
+ {
2
+ "plugins": [
3
+ ["@semantic-release/commit-analyzer", {
4
+ "preset": "angular",
5
+ "releaseRules": [
6
+ {"type": "chore", "release": "patch"}
7
+
8
+ ]
9
+ }],
10
+ "@semantic-release/npm",
11
+ "@semantic-release/release-notes-generator",
12
+ ["@semantic-release/git", {
13
+ "assets": ["docs", "package.json"],
14
+ "message": "chore(release): ${nextRelease.version} [skip ci]\n\n${nextRelease.notes}"
15
+ }],
16
+ "@semantic-release/github",
17
+ ]
18
+ }
package/README.md CHANGED
@@ -1,6 +1,11 @@
1
- appium-geckodriver
1
+ Appium Geckodriver
2
2
  ====
3
3
 
4
+ [![NPM version](http://img.shields.io/npm/v/appium-geckodriver.svg)](https://npmjs.org/package/appium-geckodriver)
5
+ [![Downloads](http://img.shields.io/npm/dm/appium-geckodriver.svg)](https://npmjs.org/package/appium-geckodriver)
6
+
7
+ [![Release](https://github.com/appium/appium-geckodriver/actions/workflows/publish.js.yml/badge.svg)](https://github.com/appium/appium-geckodriver/actions/workflows/publish.js.yml)
8
+
4
9
  This is Appium driver for automating Firefox on different platforms, including Android.
5
10
  The driver only supports Firefox and Gecko-based web views (Android only) automation using [W3C WebDriver protocol](https://www.w3.org/TR/webdriver/).
6
11
  Under the hood this driver is a wrapper/proxy over `geckodriver` binary. Check the driver [release notes](https://github.com/mozilla/geckodriver/releases) and the [official documentation](https://developer.mozilla.org/en-US/docs/Web/WebDriver/Capabilities) to get more details on the supported features and possible pitfalls.
@@ -18,6 +23,8 @@ Then you need to decide where the automated test is going to be executed. Gecko
18
23
 
19
24
  In order to run your automated tests on Android it is necessary to have [Android SDK](https://developer.android.com/studio) installed, so the destination device is marked as `online` in the `adb devices -l` command output.
20
25
 
26
+ Since the version 1.0.0 this driver is only compatible with Appium 2. Use the `appium driver install gecko` CLI command to add it to your server dist.
27
+
21
28
  Gecko driver allows to define multiple criterions for platform selection and also to fine-tune your automation session properties. This could be done via the following session capabilities:
22
29
 
23
30
  Capability Name | Description
@@ -25,11 +32,12 @@ Capability Name | Description
25
32
  platformName | Gecko Driver supports the following platforms: `mac`, `linux`, `windows`. The fact your test must be executed on Android is detected based on `moz:firefoxOptions` entry values. Values of platformName are compared case-insensitively.
26
33
  browserName | Any value passed to this capability will be changed to 'firefox'.
27
34
  browserVersion | Provide the version number of the browser to automate if there are multiple versions installed on the same machine where the driver is running.
28
- automationName | Must always be set to `Gecko`.
29
- noReset | Being set to `true` adds the `--connect-existing` argument to the server, that allows to connect to an existing browser instance instead of starting a new browser instance on session startup.
30
- systemPort | The number of the port for the driver to listen on. Must be unique for each session. If not provided then Appium will try to detect it automatically.
31
- verbosity | The verbosity level of driver logging. By default minimum verbosity is applied. Possible values are `debug` or `trace`.
32
- androidStorage | See https://firefox-source-docs.mozilla.org/testing/geckodriver/Flags.html#code-android-storage-var-android-storage-var-code
35
+ appium:automationName | Must always be set to `Gecko`.
36
+ appium:noReset | Being set to `true` adds the `--connect-existing` argument to the server, that allows to connect to an existing browser instance instead of starting a new browser instance on session startup.
37
+ appium:marionettePort | Selects the port for Geckodriver’s connection to the Marionette remote protocol. The existing Firefox instance must have Marionette enabled. To enable the remote protocol in Firefox, you can pass the `-marionette` flag. Unless the `marionette.port` preference has been user-set, Marionette will listen on port `2828`, which is the default value for this capability.
38
+ appium:systemPort | The number of the port for the driver to listen on. Must be unique for each session. If not provided then Appium will try to detect it automatically.
39
+ appium:verbosity | The verbosity level of driver logging. By default minimum verbosity is applied. Possible values are `debug` or `trace`.
40
+ appium:androidStorage | See https://firefox-source-docs.mozilla.org/testing/geckodriver/Flags.html#code-android-storage-var-android-storage-var-code
33
41
  moz:firefoxOptions | See https://developer.mozilla.org/en-US/docs/Web/WebDriver/Capabilities/firefoxOptions
34
42
  acceptInsecureCerts | See https://www.w3.org/TR/webdriver/#capabilities
35
43
  pageLoadStrategy | See https://www.w3.org/TR/webdriver/#capabilities
@@ -146,4 +154,3 @@ def test_feature_status_page_filters(driver):
146
154
  npm install
147
155
  gulp watch
148
156
  ```
149
-
package/build/index.js CHANGED
@@ -11,13 +11,13 @@ Object.defineProperty(exports, "GeckoDriver", {
11
11
  return _driver.default;
12
12
  }
13
13
  });
14
+ exports.default = void 0;
14
15
  Object.defineProperty(exports, "startServer", {
15
16
  enumerable: true,
16
17
  get: function () {
17
18
  return _server.startServer;
18
19
  }
19
20
  });
20
- exports.default = void 0;
21
21
 
22
22
  require("source-map-support/register");
23
23
 
@@ -7,13 +7,13 @@ exports.default = exports.commands = void 0;
7
7
 
8
8
  require("source-map-support/register");
9
9
 
10
- var _appiumSupport = require("appium-support");
10
+ var _support = require("@appium/support");
11
11
 
12
12
  const commands = {};
13
13
  exports.commands = commands;
14
14
 
15
15
  commands.findElOrEls = async function findElOrEls(strategy, selector, mult, context) {
16
- context = _appiumSupport.util.unwrapElement(context);
16
+ context = _support.util.unwrapElement(context);
17
17
  const endpoint = `/element${context ? `/${context}/element` : ''}${mult ? 's' : ''}`;
18
18
  return await this.gecko.proxy.command(endpoint, 'POST', {
19
19
  using: strategy,
@@ -25,4 +25,4 @@ var _default = commands;
25
25
  exports.default = _default;require('source-map-support').install();
26
26
 
27
27
 
28
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9maW5kLmpzIl0sIm5hbWVzIjpbImNvbW1hbmRzIiwiZmluZEVsT3JFbHMiLCJzdHJhdGVneSIsInNlbGVjdG9yIiwibXVsdCIsImNvbnRleHQiLCJ1dGlsIiwidW53cmFwRWxlbWVudCIsImVuZHBvaW50IiwiZ2Vja28iLCJwcm94eSIsImNvbW1hbmQiLCJ1c2luZyIsInZhbHVlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFHQSxNQUFNQSxRQUFRLEdBQUcsRUFBakI7OztBQUdBQSxRQUFRLENBQUNDLFdBQVQsR0FBdUIsZUFBZUEsV0FBZixDQUE0QkMsUUFBNUIsRUFBc0NDLFFBQXRDLEVBQWdEQyxJQUFoRCxFQUFzREMsT0FBdEQsRUFBK0Q7QUFDcEZBLEVBQUFBLE9BQU8sR0FBR0Msb0JBQUtDLGFBQUwsQ0FBbUJGLE9BQW5CLENBQVY7QUFDQSxRQUFNRyxRQUFRLEdBQUksV0FBVUgsT0FBTyxHQUFJLElBQUdBLE9BQVEsVUFBZixHQUEyQixFQUFHLEdBQUVELElBQUksR0FBRyxHQUFILEdBQVMsRUFBRyxFQUFuRjtBQUVBLFNBQU8sTUFBTSxLQUFLSyxLQUFMLENBQVdDLEtBQVgsQ0FBaUJDLE9BQWpCLENBQXlCSCxRQUF6QixFQUFtQyxNQUFuQyxFQUEyQztBQUN0REksSUFBQUEsS0FBSyxFQUFFVixRQUQrQztBQUV0RFcsSUFBQUEsS0FBSyxFQUFFVjtBQUYrQyxHQUEzQyxDQUFiO0FBSUQsQ0FSRDs7ZUFZZUgsUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHV0aWwgfSBmcm9tICdhcHBpdW0tc3VwcG9ydCc7XG5cblxuY29uc3QgY29tbWFuZHMgPSB7fTtcblxuLy8gVGhpcyBpcyBuZWVkZWQgdG8gbWFrZSBsb29rdXAgYnkgaW1hZ2Ugd29ya2luZ1xuY29tbWFuZHMuZmluZEVsT3JFbHMgPSBhc3luYyBmdW5jdGlvbiBmaW5kRWxPckVscyAoc3RyYXRlZ3ksIHNlbGVjdG9yLCBtdWx0LCBjb250ZXh0KSB7XG4gIGNvbnRleHQgPSB1dGlsLnVud3JhcEVsZW1lbnQoY29udGV4dCk7XG4gIGNvbnN0IGVuZHBvaW50ID0gYC9lbGVtZW50JHtjb250ZXh0ID8gYC8ke2NvbnRleHR9L2VsZW1lbnRgIDogJyd9JHttdWx0ID8gJ3MnIDogJyd9YDtcblxuICByZXR1cm4gYXdhaXQgdGhpcy5nZWNrby5wcm94eS5jb21tYW5kKGVuZHBvaW50LCAnUE9TVCcsIHtcbiAgICB1c2luZzogc3RyYXRlZ3ksXG4gICAgdmFsdWU6IHNlbGVjdG9yLFxuICB9KTtcbn07XG5cblxuZXhwb3J0IHsgY29tbWFuZHMgfTtcbmV4cG9ydCBkZWZhdWx0IGNvbW1hbmRzO1xuIl0sImZpbGUiOiJsaWIvY29tbWFuZHMvZmluZC5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
28
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9maW5kLmpzIl0sIm5hbWVzIjpbImNvbW1hbmRzIiwiZmluZEVsT3JFbHMiLCJzdHJhdGVneSIsInNlbGVjdG9yIiwibXVsdCIsImNvbnRleHQiLCJ1dGlsIiwidW53cmFwRWxlbWVudCIsImVuZHBvaW50IiwiZ2Vja28iLCJwcm94eSIsImNvbW1hbmQiLCJ1c2luZyIsInZhbHVlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFHQSxNQUFNQSxRQUFRLEdBQUcsRUFBakI7OztBQUdBQSxRQUFRLENBQUNDLFdBQVQsR0FBdUIsZUFBZUEsV0FBZixDQUE0QkMsUUFBNUIsRUFBc0NDLFFBQXRDLEVBQWdEQyxJQUFoRCxFQUFzREMsT0FBdEQsRUFBK0Q7QUFDcEZBLEVBQUFBLE9BQU8sR0FBR0MsY0FBS0MsYUFBTCxDQUFtQkYsT0FBbkIsQ0FBVjtBQUNBLFFBQU1HLFFBQVEsR0FBSSxXQUFVSCxPQUFPLEdBQUksSUFBR0EsT0FBUSxVQUFmLEdBQTJCLEVBQUcsR0FBRUQsSUFBSSxHQUFHLEdBQUgsR0FBUyxFQUFHLEVBQW5GO0FBRUEsU0FBTyxNQUFNLEtBQUtLLEtBQUwsQ0FBV0MsS0FBWCxDQUFpQkMsT0FBakIsQ0FBeUJILFFBQXpCLEVBQW1DLE1BQW5DLEVBQTJDO0FBQ3RESSxJQUFBQSxLQUFLLEVBQUVWLFFBRCtDO0FBRXREVyxJQUFBQSxLQUFLLEVBQUVWO0FBRitDLEdBQTNDLENBQWI7QUFJRCxDQVJEOztlQVllSCxRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXRpbCB9IGZyb20gJ0BhcHBpdW0vc3VwcG9ydCc7XG5cblxuY29uc3QgY29tbWFuZHMgPSB7fTtcblxuLy8gVGhpcyBpcyBuZWVkZWQgdG8gbWFrZSBsb29rdXAgYnkgaW1hZ2Ugd29ya2luZ1xuY29tbWFuZHMuZmluZEVsT3JFbHMgPSBhc3luYyBmdW5jdGlvbiBmaW5kRWxPckVscyAoc3RyYXRlZ3ksIHNlbGVjdG9yLCBtdWx0LCBjb250ZXh0KSB7XG4gIGNvbnRleHQgPSB1dGlsLnVud3JhcEVsZW1lbnQoY29udGV4dCk7XG4gIGNvbnN0IGVuZHBvaW50ID0gYC9lbGVtZW50JHtjb250ZXh0ID8gYC8ke2NvbnRleHR9L2VsZW1lbnRgIDogJyd9JHttdWx0ID8gJ3MnIDogJyd9YDtcblxuICByZXR1cm4gYXdhaXQgdGhpcy5nZWNrby5wcm94eS5jb21tYW5kKGVuZHBvaW50LCAnUE9TVCcsIHtcbiAgICB1c2luZzogc3RyYXRlZ3ksXG4gICAgdmFsdWU6IHNlbGVjdG9yLFxuICB9KTtcbn07XG5cblxuZXhwb3J0IHsgY29tbWFuZHMgfTtcbmV4cG9ydCBkZWZhdWx0IGNvbW1hbmRzO1xuIl0sImZpbGUiOiJsaWIvY29tbWFuZHMvZmluZC5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
@@ -37,6 +37,9 @@ const desiredCapConstraints = {
37
37
  systemPort: {
38
38
  isNumber: true
39
39
  },
40
+ marionettePort: {
41
+ isNumber: true
42
+ },
40
43
  verbosity: {
41
44
  isString: true,
42
45
  inclusionCaseInsensitive: Object.values(_constants.VERBOSITY)
@@ -52,4 +55,4 @@ const desiredCapConstraints = {
52
55
  exports.desiredCapConstraints = desiredCapConstraints;require('source-map-support').install();
53
56
 
54
57
 
55
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kZXNpcmVkLWNhcHMuanMiXSwibmFtZXMiOlsiZGVzaXJlZENhcENvbnN0cmFpbnRzIiwiYnJvd3Nlck5hbWUiLCJpc1N0cmluZyIsImJyb3dzZXJWZXJzaW9uIiwiYWNjZXB0SW5zZWN1cmVDZXJ0cyIsImlzQm9vbGVhbiIsInBhZ2VMb2FkU3RyYXRlZ3kiLCJwcm94eSIsImlzT2JqZWN0Iiwic2V0V2luZG93UmVjdCIsInRpbWVvdXRzIiwidW5oYW5kbGVkUHJvbXB0QmVoYXZpb3IiLCJzeXN0ZW1Qb3J0IiwiaXNOdW1iZXIiLCJ2ZXJib3NpdHkiLCJpbmNsdXNpb25DYXNlSW5zZW5zaXRpdmUiLCJPYmplY3QiLCJ2YWx1ZXMiLCJWRVJCT1NJVFkiLCJhbmRyb2lkU3RvcmFnZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBRUEsTUFBTUEscUJBQXFCLEdBQUc7QUFDNUJDLEVBQUFBLFdBQVcsRUFBRTtBQUNYQyxJQUFBQSxRQUFRLEVBQUU7QUFEQyxHQURlO0FBSTVCQyxFQUFBQSxjQUFjLEVBQUU7QUFDZEQsSUFBQUEsUUFBUSxFQUFFO0FBREksR0FKWTtBQU81QkUsRUFBQUEsbUJBQW1CLEVBQUU7QUFDbkJDLElBQUFBLFNBQVMsRUFBRTtBQURRLEdBUE87QUFVNUJDLEVBQUFBLGdCQUFnQixFQUFFO0FBQ2hCSixJQUFBQSxRQUFRLEVBQUU7QUFETSxHQVZVO0FBYTVCSyxFQUFBQSxLQUFLLEVBQUU7QUFDTEMsSUFBQUEsUUFBUSxFQUFFO0FBREwsR0FicUI7QUFnQjVCQyxFQUFBQSxhQUFhLEVBQUU7QUFDYkosSUFBQUEsU0FBUyxFQUFFO0FBREUsR0FoQmE7QUFtQjVCSyxFQUFBQSxRQUFRLEVBQUU7QUFDUkYsSUFBQUEsUUFBUSxFQUFFO0FBREYsR0FuQmtCO0FBc0I1QkcsRUFBQUEsdUJBQXVCLEVBQUU7QUFDdkJULElBQUFBLFFBQVEsRUFBRTtBQURhLEdBdEJHO0FBeUI1QlUsRUFBQUEsVUFBVSxFQUFFO0FBQ1ZDLElBQUFBLFFBQVEsRUFBRTtBQURBLEdBekJnQjtBQTRCNUJDLEVBQUFBLFNBQVMsRUFBRTtBQUNUWixJQUFBQSxRQUFRLEVBQUUsSUFERDtBQUVUYSxJQUFBQSx3QkFBd0IsRUFBRUMsTUFBTSxDQUFDQyxNQUFQLENBQWNDLG9CQUFkO0FBRmpCLEdBNUJpQjtBQWdDNUJDLEVBQUFBLGNBQWMsRUFBRTtBQUNkakIsSUFBQUEsUUFBUSxFQUFFLElBREk7QUFFZGEsSUFBQUEsd0JBQXdCLEVBQUUsQ0FBQyxNQUFELEVBQVMsS0FBVCxFQUFnQixVQUFoQixFQUE0QixRQUE1QjtBQUZaLEdBaENZO0FBb0M1Qix3QkFBc0I7QUFDcEJQLElBQUFBLFFBQVEsRUFBRTtBQURVO0FBcENNLENBQTlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVkVSQk9TSVRZIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuXG5jb25zdCBkZXNpcmVkQ2FwQ29uc3RyYWludHMgPSB7XG4gIGJyb3dzZXJOYW1lOiB7XG4gICAgaXNTdHJpbmc6IHRydWVcbiAgfSxcbiAgYnJvd3NlclZlcnNpb246IHtcbiAgICBpc1N0cmluZzogdHJ1ZVxuICB9LFxuICBhY2NlcHRJbnNlY3VyZUNlcnRzOiB7XG4gICAgaXNCb29sZWFuOiB0cnVlXG4gIH0sXG4gIHBhZ2VMb2FkU3RyYXRlZ3k6IHtcbiAgICBpc1N0cmluZzogdHJ1ZVxuICB9LFxuICBwcm94eToge1xuICAgIGlzT2JqZWN0OiB0cnVlXG4gIH0sXG4gIHNldFdpbmRvd1JlY3Q6IHtcbiAgICBpc0Jvb2xlYW46IHRydWVcbiAgfSxcbiAgdGltZW91dHM6IHtcbiAgICBpc09iamVjdDogdHJ1ZVxuICB9LFxuICB1bmhhbmRsZWRQcm9tcHRCZWhhdmlvcjoge1xuICAgIGlzU3RyaW5nOiB0cnVlXG4gIH0sXG4gIHN5c3RlbVBvcnQ6IHtcbiAgICBpc051bWJlcjogdHJ1ZVxuICB9LFxuICB2ZXJib3NpdHk6IHtcbiAgICBpc1N0cmluZzogdHJ1ZSxcbiAgICBpbmNsdXNpb25DYXNlSW5zZW5zaXRpdmU6IE9iamVjdC52YWx1ZXMoVkVSQk9TSVRZKVxuICB9LFxuICBhbmRyb2lkU3RvcmFnZToge1xuICAgIGlzU3RyaW5nOiB0cnVlLFxuICAgIGluY2x1c2lvbkNhc2VJbnNlbnNpdGl2ZTogWydhdXRvJywgJ2FwcCcsICdpbnRlcm5hbCcsICdzZGNhcmQnXVxuICB9LFxuICAnbW96OmZpcmVmb3hPcHRpb25zJzoge1xuICAgIGlzT2JqZWN0OiB0cnVlXG4gIH1cbn07XG5cbmV4cG9ydCB7IGRlc2lyZWRDYXBDb25zdHJhaW50cyB9O1xuIl0sImZpbGUiOiJsaWIvZGVzaXJlZC1jYXBzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
58
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kZXNpcmVkLWNhcHMuanMiXSwibmFtZXMiOlsiZGVzaXJlZENhcENvbnN0cmFpbnRzIiwiYnJvd3Nlck5hbWUiLCJpc1N0cmluZyIsImJyb3dzZXJWZXJzaW9uIiwiYWNjZXB0SW5zZWN1cmVDZXJ0cyIsImlzQm9vbGVhbiIsInBhZ2VMb2FkU3RyYXRlZ3kiLCJwcm94eSIsImlzT2JqZWN0Iiwic2V0V2luZG93UmVjdCIsInRpbWVvdXRzIiwidW5oYW5kbGVkUHJvbXB0QmVoYXZpb3IiLCJzeXN0ZW1Qb3J0IiwiaXNOdW1iZXIiLCJtYXJpb25ldHRlUG9ydCIsInZlcmJvc2l0eSIsImluY2x1c2lvbkNhc2VJbnNlbnNpdGl2ZSIsIk9iamVjdCIsInZhbHVlcyIsIlZFUkJPU0lUWSIsImFuZHJvaWRTdG9yYWdlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxxQkFBcUIsR0FBRztBQUM1QkMsRUFBQUEsV0FBVyxFQUFFO0FBQ1hDLElBQUFBLFFBQVEsRUFBRTtBQURDLEdBRGU7QUFJNUJDLEVBQUFBLGNBQWMsRUFBRTtBQUNkRCxJQUFBQSxRQUFRLEVBQUU7QUFESSxHQUpZO0FBTzVCRSxFQUFBQSxtQkFBbUIsRUFBRTtBQUNuQkMsSUFBQUEsU0FBUyxFQUFFO0FBRFEsR0FQTztBQVU1QkMsRUFBQUEsZ0JBQWdCLEVBQUU7QUFDaEJKLElBQUFBLFFBQVEsRUFBRTtBQURNLEdBVlU7QUFhNUJLLEVBQUFBLEtBQUssRUFBRTtBQUNMQyxJQUFBQSxRQUFRLEVBQUU7QUFETCxHQWJxQjtBQWdCNUJDLEVBQUFBLGFBQWEsRUFBRTtBQUNiSixJQUFBQSxTQUFTLEVBQUU7QUFERSxHQWhCYTtBQW1CNUJLLEVBQUFBLFFBQVEsRUFBRTtBQUNSRixJQUFBQSxRQUFRLEVBQUU7QUFERixHQW5Ca0I7QUFzQjVCRyxFQUFBQSx1QkFBdUIsRUFBRTtBQUN2QlQsSUFBQUEsUUFBUSxFQUFFO0FBRGEsR0F0Qkc7QUF5QjVCVSxFQUFBQSxVQUFVLEVBQUU7QUFDVkMsSUFBQUEsUUFBUSxFQUFFO0FBREEsR0F6QmdCO0FBNEI1QkMsRUFBQUEsY0FBYyxFQUFFO0FBQ2RELElBQUFBLFFBQVEsRUFBRTtBQURJLEdBNUJZO0FBK0I1QkUsRUFBQUEsU0FBUyxFQUFFO0FBQ1RiLElBQUFBLFFBQVEsRUFBRSxJQUREO0FBRVRjLElBQUFBLHdCQUF3QixFQUFFQyxNQUFNLENBQUNDLE1BQVAsQ0FBY0Msb0JBQWQ7QUFGakIsR0EvQmlCO0FBbUM1QkMsRUFBQUEsY0FBYyxFQUFFO0FBQ2RsQixJQUFBQSxRQUFRLEVBQUUsSUFESTtBQUVkYyxJQUFBQSx3QkFBd0IsRUFBRSxDQUFDLE1BQUQsRUFBUyxLQUFULEVBQWdCLFVBQWhCLEVBQTRCLFFBQTVCO0FBRlosR0FuQ1k7QUF1QzVCLHdCQUFzQjtBQUNwQlIsSUFBQUEsUUFBUSxFQUFFO0FBRFU7QUF2Q00sQ0FBOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWRVJCT1NJVFkgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5cbmNvbnN0IGRlc2lyZWRDYXBDb25zdHJhaW50cyA9IHtcbiAgYnJvd3Nlck5hbWU6IHtcbiAgICBpc1N0cmluZzogdHJ1ZVxuICB9LFxuICBicm93c2VyVmVyc2lvbjoge1xuICAgIGlzU3RyaW5nOiB0cnVlXG4gIH0sXG4gIGFjY2VwdEluc2VjdXJlQ2VydHM6IHtcbiAgICBpc0Jvb2xlYW46IHRydWVcbiAgfSxcbiAgcGFnZUxvYWRTdHJhdGVneToge1xuICAgIGlzU3RyaW5nOiB0cnVlXG4gIH0sXG4gIHByb3h5OiB7XG4gICAgaXNPYmplY3Q6IHRydWVcbiAgfSxcbiAgc2V0V2luZG93UmVjdDoge1xuICAgIGlzQm9vbGVhbjogdHJ1ZVxuICB9LFxuICB0aW1lb3V0czoge1xuICAgIGlzT2JqZWN0OiB0cnVlXG4gIH0sXG4gIHVuaGFuZGxlZFByb21wdEJlaGF2aW9yOiB7XG4gICAgaXNTdHJpbmc6IHRydWVcbiAgfSxcbiAgc3lzdGVtUG9ydDoge1xuICAgIGlzTnVtYmVyOiB0cnVlXG4gIH0sXG4gIG1hcmlvbmV0dGVQb3J0OiB7XG4gICAgaXNOdW1iZXI6IHRydWVcbiAgfSxcbiAgdmVyYm9zaXR5OiB7XG4gICAgaXNTdHJpbmc6IHRydWUsXG4gICAgaW5jbHVzaW9uQ2FzZUluc2Vuc2l0aXZlOiBPYmplY3QudmFsdWVzKFZFUkJPU0lUWSlcbiAgfSxcbiAgYW5kcm9pZFN0b3JhZ2U6IHtcbiAgICBpc1N0cmluZzogdHJ1ZSxcbiAgICBpbmNsdXNpb25DYXNlSW5zZW5zaXRpdmU6IFsnYXV0bycsICdhcHAnLCAnaW50ZXJuYWwnLCAnc2RjYXJkJ11cbiAgfSxcbiAgJ21vejpmaXJlZm94T3B0aW9ucyc6IHtcbiAgICBpc09iamVjdDogdHJ1ZVxuICB9XG59O1xuXG5leHBvcnQgeyBkZXNpcmVkQ2FwQ29uc3RyYWludHMgfTtcbiJdLCJmaWxlIjoibGliL2Rlc2lyZWQtY2Fwcy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
@@ -11,9 +11,7 @@ require("source-map-support/register");
11
11
 
12
12
  var _lodash = _interopRequireDefault(require("lodash"));
13
13
 
14
- var _appiumBaseDriver = require("appium-base-driver");
15
-
16
- var _logger = _interopRequireDefault(require("./logger"));
14
+ var _baseDriver = require("@appium/base-driver");
17
15
 
18
16
  var _gecko = _interopRequireDefault(require("./gecko"));
19
17
 
@@ -25,7 +23,7 @@ var _utils = require("./utils");
25
23
 
26
24
  const NO_PROXY = [['GET', new RegExp('^/session/[^/]+/appium')], ['POST', new RegExp('^/session/[^/]+/appium')], ['POST', new RegExp('^/session/[^/]+/element/[^/]+/elements?$')], ['POST', new RegExp('^/session/[^/]+/elements?$')]];
27
25
 
28
- class GeckoDriver extends _appiumBaseDriver.BaseDriver {
26
+ class GeckoDriver extends _baseDriver.BaseDriver {
29
27
  constructor(opts = {}) {
30
28
  super(opts);
31
29
  this.desiredCapConstraints = _desiredCaps.desiredCapConstraints;
@@ -57,7 +55,7 @@ class GeckoDriver extends _appiumBaseDriver.BaseDriver {
57
55
 
58
56
  async createSession(...args) {
59
57
  const [sessionId, caps] = await super.createSession(...args);
60
- this.gecko = new _gecko.default(caps);
58
+ this.gecko = new _gecko.default(this.log, caps);
61
59
 
62
60
  try {
63
61
  await this.gecko.start((0, _utils.formatCapsForServer)(caps));
@@ -72,8 +70,7 @@ class GeckoDriver extends _appiumBaseDriver.BaseDriver {
72
70
  }
73
71
 
74
72
  async deleteSession() {
75
- _logger.default.info('Ending Gecko Driver session');
76
-
73
+ this.log.info('Ending Gecko Driver session');
77
74
  await this.gecko.stop();
78
75
  this.resetState();
79
76
  await super.deleteSession();
@@ -85,4 +82,4 @@ var _default = GeckoDriver;
85
82
  exports.default = _default;require('source-map-support').install();
86
83
 
87
84
 
88
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXIuanMiXSwibmFtZXMiOlsiTk9fUFJPWFkiLCJSZWdFeHAiLCJHZWNrb0RyaXZlciIsIkJhc2VEcml2ZXIiLCJjb25zdHJ1Y3RvciIsIm9wdHMiLCJkZXNpcmVkQ2FwQ29uc3RyYWludHMiLCJsb2NhdG9yU3RyYXRlZ2llcyIsInJlc2V0U3RhdGUiLCJjbWQiLCJmbiIsIl8iLCJ0b1BhaXJzIiwiY29tbWFuZHMiLCJwcm90b3R5cGUiLCJnZWNrbyIsInByb3h5UmVxUmVzIiwiaXNQcm94eUFjdGl2ZSIsInByb3h5QWN0aXZlIiwiZ2V0UHJveHlBdm9pZExpc3QiLCJjYW5Qcm94eSIsImNyZWF0ZVNlc3Npb24iLCJhcmdzIiwic2Vzc2lvbklkIiwiY2FwcyIsIkdlY2tvRHJpdmVyU2VydmVyIiwic3RhcnQiLCJlIiwiZGVsZXRlU2Vzc2lvbiIsInByb3h5IiwiYmluZCIsImxvZyIsImluZm8iLCJzdG9wIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLFFBQVEsR0FBRyxDQUNmLENBQUMsS0FBRCxFQUFRLElBQUlDLE1BQUosQ0FBVyx3QkFBWCxDQUFSLENBRGUsRUFFZixDQUFDLE1BQUQsRUFBUyxJQUFJQSxNQUFKLENBQVcsd0JBQVgsQ0FBVCxDQUZlLEVBR2YsQ0FBQyxNQUFELEVBQVMsSUFBSUEsTUFBSixDQUFXLDBDQUFYLENBQVQsQ0FIZSxFQUlmLENBQUMsTUFBRCxFQUFTLElBQUlBLE1BQUosQ0FBVyw0QkFBWCxDQUFULENBSmUsQ0FBakI7O0FBT0EsTUFBTUMsV0FBTixTQUEwQkMsNEJBQTFCLENBQXFDO0FBQ25DQyxFQUFBQSxXQUFXLENBQUVDLElBQUksR0FBRyxFQUFULEVBQWE7QUFDdEIsVUFBTUEsSUFBTjtBQUNBLFNBQUtDLHFCQUFMLEdBQTZCQSxrQ0FBN0I7QUFDQSxTQUFLQyxpQkFBTCxHQUF5QixDQUN2QixPQUR1QixFQUV2QixVQUZ1QixFQUd2QixXQUh1QixFQUl2QixtQkFKdUIsRUFLdkIsY0FMdUIsRUFPdkIsSUFQdUIsRUFRdkIsTUFSdUIsQ0FBekI7QUFVQSxTQUFLQyxVQUFMOztBQUVBLFNBQUssTUFBTSxDQUFDQyxHQUFELEVBQU1DLEVBQU4sQ0FBWCxJQUF3QkMsZ0JBQUVDLE9BQUYsQ0FBVUMsY0FBVixDQUF4QixFQUE2QztBQUMzQ1gsTUFBQUEsV0FBVyxDQUFDWSxTQUFaLENBQXNCTCxHQUF0QixJQUE2QkMsRUFBN0I7QUFDRDtBQUNGOztBQUVERixFQUFBQSxVQUFVLEdBQUk7QUFDWixTQUFLTyxLQUFMLEdBQWEsSUFBYjtBQUNBLFNBQUtDLFdBQUwsR0FBbUIsSUFBbkI7QUFDQSxTQUFLQyxhQUFMLEdBQXFCLEtBQXJCO0FBQ0Q7O0FBRURDLEVBQUFBLFdBQVcsR0FBSTtBQUNiLFdBQU8sS0FBS0QsYUFBWjtBQUNEOztBQUVERSxFQUFBQSxpQkFBaUIsR0FBSTtBQUNuQixXQUFPbkIsUUFBUDtBQUNEOztBQUVEb0IsRUFBQUEsUUFBUSxHQUFJO0FBQ1YsV0FBTyxJQUFQO0FBQ0Q7O0FBRUQsUUFBTUMsYUFBTixDQUFxQixHQUFHQyxJQUF4QixFQUE4QjtBQUM1QixVQUFNLENBQUNDLFNBQUQsRUFBWUMsSUFBWixJQUFvQixNQUFNLE1BQU1ILGFBQU4sQ0FBb0IsR0FBR0MsSUFBdkIsQ0FBaEM7QUFDQSxTQUFLUCxLQUFMLEdBQWEsSUFBSVUsY0FBSixDQUFzQkQsSUFBdEIsQ0FBYjs7QUFDQSxRQUFJO0FBQ0YsWUFBTSxLQUFLVCxLQUFMLENBQVdXLEtBQVgsQ0FBaUIsZ0NBQW9CRixJQUFwQixDQUFqQixDQUFOO0FBQ0QsS0FGRCxDQUVFLE9BQU9HLENBQVAsRUFBVTtBQUNWLFlBQU0sS0FBS0MsYUFBTCxFQUFOO0FBQ0EsWUFBTUQsQ0FBTjtBQUNEOztBQUNELFNBQUtYLFdBQUwsR0FBbUIsS0FBS0QsS0FBTCxDQUFXYyxLQUFYLENBQWlCYixXQUFqQixDQUE2QmMsSUFBN0IsQ0FBa0MsS0FBS2YsS0FBTCxDQUFXYyxLQUE3QyxDQUFuQjtBQUNBLFNBQUtaLGFBQUwsR0FBcUIsSUFBckI7QUFDQSxXQUFPLENBQUNNLFNBQUQsRUFBWUMsSUFBWixDQUFQO0FBQ0Q7O0FBRUQsUUFBTUksYUFBTixHQUF1QjtBQUNyQkcsb0JBQUlDLElBQUosQ0FBUyw2QkFBVDs7QUFDQSxVQUFNLEtBQUtqQixLQUFMLENBQVdrQixJQUFYLEVBQU47QUFDQSxTQUFLekIsVUFBTDtBQUVBLFVBQU0sTUFBTW9CLGFBQU4sRUFBTjtBQUNEOztBQTNEa0M7O2VBOER0QjFCLFciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgQmFzZURyaXZlciB9IGZyb20gJ2FwcGl1bS1iYXNlLWRyaXZlcic7XG5pbXBvcnQgbG9nIGZyb20gJy4vbG9nZ2VyJztcbmltcG9ydCBHZWNrb0RyaXZlclNlcnZlciBmcm9tICcuL2dlY2tvJztcbmltcG9ydCB7IGRlc2lyZWRDYXBDb25zdHJhaW50cyB9IGZyb20gJy4vZGVzaXJlZC1jYXBzJztcbmltcG9ydCBjb21tYW5kcyBmcm9tICcuL2NvbW1hbmRzL2luZGV4JztcbmltcG9ydCB7IGZvcm1hdENhcHNGb3JTZXJ2ZXIgfSBmcm9tICcuL3V0aWxzJztcblxuY29uc3QgTk9fUFJPWFkgPSBbXG4gIFsnR0VUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnQvW14vXSsvZWxlbWVudHM/JCcpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnRzPyQnKV0sXG5dO1xuXG5jbGFzcyBHZWNrb0RyaXZlciBleHRlbmRzIEJhc2VEcml2ZXIge1xuICBjb25zdHJ1Y3RvciAob3B0cyA9IHt9KSB7XG4gICAgc3VwZXIob3B0cyk7XG4gICAgdGhpcy5kZXNpcmVkQ2FwQ29uc3RyYWludHMgPSBkZXNpcmVkQ2FwQ29uc3RyYWludHM7XG4gICAgdGhpcy5sb2NhdG9yU3RyYXRlZ2llcyA9IFtcbiAgICAgICd4cGF0aCcsXG4gICAgICAndGFnIG5hbWUnLFxuICAgICAgJ2xpbmsgdGV4dCcsXG4gICAgICAncGFydGlhbCBsaW5rIHRleHQnLFxuICAgICAgJ2NzcyBzZWxlY3RvcicsXG4gICAgICAvLyBMZXQgdGhlc2UgdHdvIHJlYWNoIEdlY2tvIERyaXZlciBhbmQgZmFpbCB0aGVyZSB3aXRoIGEgcHJvcGVyIGVycm9yIG1lc3NhZ2VcbiAgICAgICdpZCcsXG4gICAgICAnbmFtZScsXG4gICAgXTtcbiAgICB0aGlzLnJlc2V0U3RhdGUoKTtcblxuICAgIGZvciAoY29uc3QgW2NtZCwgZm5dIG9mIF8udG9QYWlycyhjb21tYW5kcykpIHtcbiAgICAgIEdlY2tvRHJpdmVyLnByb3RvdHlwZVtjbWRdID0gZm47XG4gICAgfVxuICB9XG5cbiAgcmVzZXRTdGF0ZSAoKSB7XG4gICAgdGhpcy5nZWNrbyA9IG51bGw7XG4gICAgdGhpcy5wcm94eVJlcVJlcyA9IG51bGw7XG4gICAgdGhpcy5pc1Byb3h5QWN0aXZlID0gZmFsc2U7XG4gIH1cblxuICBwcm94eUFjdGl2ZSAoKSB7XG4gICAgcmV0dXJuIHRoaXMuaXNQcm94eUFjdGl2ZTtcbiAgfVxuXG4gIGdldFByb3h5QXZvaWRMaXN0ICgpIHtcbiAgICByZXR1cm4gTk9fUFJPWFk7XG4gIH1cblxuICBjYW5Qcm94eSAoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBhc3luYyBjcmVhdGVTZXNzaW9uICguLi5hcmdzKSB7XG4gICAgY29uc3QgW3Nlc3Npb25JZCwgY2Fwc10gPSBhd2FpdCBzdXBlci5jcmVhdGVTZXNzaW9uKC4uLmFyZ3MpO1xuICAgIHRoaXMuZ2Vja28gPSBuZXcgR2Vja29Ecml2ZXJTZXJ2ZXIoY2Fwcyk7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IHRoaXMuZ2Vja28uc3RhcnQoZm9ybWF0Q2Fwc0ZvclNlcnZlcihjYXBzKSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgYXdhaXQgdGhpcy5kZWxldGVTZXNzaW9uKCk7XG4gICAgICB0aHJvdyBlO1xuICAgIH1cbiAgICB0aGlzLnByb3h5UmVxUmVzID0gdGhpcy5nZWNrby5wcm94eS5wcm94eVJlcVJlcy5iaW5kKHRoaXMuZ2Vja28ucHJveHkpO1xuICAgIHRoaXMuaXNQcm94eUFjdGl2ZSA9IHRydWU7XG4gICAgcmV0dXJuIFtzZXNzaW9uSWQsIGNhcHNdO1xuICB9XG5cbiAgYXN5bmMgZGVsZXRlU2Vzc2lvbiAoKSB7XG4gICAgbG9nLmluZm8oJ0VuZGluZyBHZWNrbyBEcml2ZXIgc2Vzc2lvbicpO1xuICAgIGF3YWl0IHRoaXMuZ2Vja28uc3RvcCgpO1xuICAgIHRoaXMucmVzZXRTdGF0ZSgpO1xuXG4gICAgYXdhaXQgc3VwZXIuZGVsZXRlU2Vzc2lvbigpO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IEdlY2tvRHJpdmVyO1xuIl0sImZpbGUiOiJsaWIvZHJpdmVyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
85
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXIuanMiXSwibmFtZXMiOlsiTk9fUFJPWFkiLCJSZWdFeHAiLCJHZWNrb0RyaXZlciIsIkJhc2VEcml2ZXIiLCJjb25zdHJ1Y3RvciIsIm9wdHMiLCJkZXNpcmVkQ2FwQ29uc3RyYWludHMiLCJsb2NhdG9yU3RyYXRlZ2llcyIsInJlc2V0U3RhdGUiLCJjbWQiLCJmbiIsIl8iLCJ0b1BhaXJzIiwiY29tbWFuZHMiLCJwcm90b3R5cGUiLCJnZWNrbyIsInByb3h5UmVxUmVzIiwiaXNQcm94eUFjdGl2ZSIsInByb3h5QWN0aXZlIiwiZ2V0UHJveHlBdm9pZExpc3QiLCJjYW5Qcm94eSIsImNyZWF0ZVNlc3Npb24iLCJhcmdzIiwic2Vzc2lvbklkIiwiY2FwcyIsIkdlY2tvRHJpdmVyU2VydmVyIiwibG9nIiwic3RhcnQiLCJlIiwiZGVsZXRlU2Vzc2lvbiIsInByb3h5IiwiYmluZCIsImluZm8iLCJzdG9wIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLFFBQVEsR0FBRyxDQUNmLENBQUMsS0FBRCxFQUFRLElBQUlDLE1BQUosQ0FBVyx3QkFBWCxDQUFSLENBRGUsRUFFZixDQUFDLE1BQUQsRUFBUyxJQUFJQSxNQUFKLENBQVcsd0JBQVgsQ0FBVCxDQUZlLEVBR2YsQ0FBQyxNQUFELEVBQVMsSUFBSUEsTUFBSixDQUFXLDBDQUFYLENBQVQsQ0FIZSxFQUlmLENBQUMsTUFBRCxFQUFTLElBQUlBLE1BQUosQ0FBVyw0QkFBWCxDQUFULENBSmUsQ0FBakI7O0FBT0EsTUFBTUMsV0FBTixTQUEwQkMsc0JBQTFCLENBQXFDO0FBQ25DQyxFQUFBQSxXQUFXLENBQUVDLElBQUksR0FBRyxFQUFULEVBQWE7QUFDdEIsVUFBTUEsSUFBTjtBQUNBLFNBQUtDLHFCQUFMLEdBQTZCQSxrQ0FBN0I7QUFDQSxTQUFLQyxpQkFBTCxHQUF5QixDQUN2QixPQUR1QixFQUV2QixVQUZ1QixFQUd2QixXQUh1QixFQUl2QixtQkFKdUIsRUFLdkIsY0FMdUIsRUFPdkIsSUFQdUIsRUFRdkIsTUFSdUIsQ0FBekI7QUFVQSxTQUFLQyxVQUFMOztBQUVBLFNBQUssTUFBTSxDQUFDQyxHQUFELEVBQU1DLEVBQU4sQ0FBWCxJQUF3QkMsZ0JBQUVDLE9BQUYsQ0FBVUMsY0FBVixDQUF4QixFQUE2QztBQUMzQ1gsTUFBQUEsV0FBVyxDQUFDWSxTQUFaLENBQXNCTCxHQUF0QixJQUE2QkMsRUFBN0I7QUFDRDtBQUNGOztBQUVERixFQUFBQSxVQUFVLEdBQUk7QUFDWixTQUFLTyxLQUFMLEdBQWEsSUFBYjtBQUNBLFNBQUtDLFdBQUwsR0FBbUIsSUFBbkI7QUFDQSxTQUFLQyxhQUFMLEdBQXFCLEtBQXJCO0FBQ0Q7O0FBRURDLEVBQUFBLFdBQVcsR0FBSTtBQUNiLFdBQU8sS0FBS0QsYUFBWjtBQUNEOztBQUVERSxFQUFBQSxpQkFBaUIsR0FBSTtBQUNuQixXQUFPbkIsUUFBUDtBQUNEOztBQUVEb0IsRUFBQUEsUUFBUSxHQUFJO0FBQ1YsV0FBTyxJQUFQO0FBQ0Q7O0FBRWtCLFFBQWJDLGFBQWEsQ0FBRSxHQUFHQyxJQUFMLEVBQVc7QUFDNUIsVUFBTSxDQUFDQyxTQUFELEVBQVlDLElBQVosSUFBb0IsTUFBTSxNQUFNSCxhQUFOLENBQW9CLEdBQUdDLElBQXZCLENBQWhDO0FBQ0EsU0FBS1AsS0FBTCxHQUFhLElBQUlVLGNBQUosQ0FBc0IsS0FBS0MsR0FBM0IsRUFBZ0NGLElBQWhDLENBQWI7O0FBQ0EsUUFBSTtBQUNGLFlBQU0sS0FBS1QsS0FBTCxDQUFXWSxLQUFYLENBQWlCLGdDQUFvQkgsSUFBcEIsQ0FBakIsQ0FBTjtBQUNELEtBRkQsQ0FFRSxPQUFPSSxDQUFQLEVBQVU7QUFDVixZQUFNLEtBQUtDLGFBQUwsRUFBTjtBQUNBLFlBQU1ELENBQU47QUFDRDs7QUFDRCxTQUFLWixXQUFMLEdBQW1CLEtBQUtELEtBQUwsQ0FBV2UsS0FBWCxDQUFpQmQsV0FBakIsQ0FBNkJlLElBQTdCLENBQWtDLEtBQUtoQixLQUFMLENBQVdlLEtBQTdDLENBQW5CO0FBQ0EsU0FBS2IsYUFBTCxHQUFxQixJQUFyQjtBQUNBLFdBQU8sQ0FBQ00sU0FBRCxFQUFZQyxJQUFaLENBQVA7QUFDRDs7QUFFa0IsUUFBYkssYUFBYSxHQUFJO0FBQ3JCLFNBQUtILEdBQUwsQ0FBU00sSUFBVCxDQUFjLDZCQUFkO0FBQ0EsVUFBTSxLQUFLakIsS0FBTCxDQUFXa0IsSUFBWCxFQUFOO0FBQ0EsU0FBS3pCLFVBQUw7QUFFQSxVQUFNLE1BQU1xQixhQUFOLEVBQU47QUFDRDs7QUEzRGtDOztlQThEdEIzQixXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IEJhc2VEcml2ZXIgfSBmcm9tICdAYXBwaXVtL2Jhc2UtZHJpdmVyJztcbmltcG9ydCBHZWNrb0RyaXZlclNlcnZlciBmcm9tICcuL2dlY2tvJztcbmltcG9ydCB7IGRlc2lyZWRDYXBDb25zdHJhaW50cyB9IGZyb20gJy4vZGVzaXJlZC1jYXBzJztcbmltcG9ydCBjb21tYW5kcyBmcm9tICcuL2NvbW1hbmRzL2luZGV4JztcbmltcG9ydCB7IGZvcm1hdENhcHNGb3JTZXJ2ZXIgfSBmcm9tICcuL3V0aWxzJztcblxuY29uc3QgTk9fUFJPWFkgPSBbXG4gIFsnR0VUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnQvW14vXSsvZWxlbWVudHM/JCcpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnRzPyQnKV0sXG5dO1xuXG5jbGFzcyBHZWNrb0RyaXZlciBleHRlbmRzIEJhc2VEcml2ZXIge1xuICBjb25zdHJ1Y3RvciAob3B0cyA9IHt9KSB7XG4gICAgc3VwZXIob3B0cyk7XG4gICAgdGhpcy5kZXNpcmVkQ2FwQ29uc3RyYWludHMgPSBkZXNpcmVkQ2FwQ29uc3RyYWludHM7XG4gICAgdGhpcy5sb2NhdG9yU3RyYXRlZ2llcyA9IFtcbiAgICAgICd4cGF0aCcsXG4gICAgICAndGFnIG5hbWUnLFxuICAgICAgJ2xpbmsgdGV4dCcsXG4gICAgICAncGFydGlhbCBsaW5rIHRleHQnLFxuICAgICAgJ2NzcyBzZWxlY3RvcicsXG4gICAgICAvLyBMZXQgdGhlc2UgdHdvIHJlYWNoIEdlY2tvIERyaXZlciBhbmQgZmFpbCB0aGVyZSB3aXRoIGEgcHJvcGVyIGVycm9yIG1lc3NhZ2VcbiAgICAgICdpZCcsXG4gICAgICAnbmFtZScsXG4gICAgXTtcbiAgICB0aGlzLnJlc2V0U3RhdGUoKTtcblxuICAgIGZvciAoY29uc3QgW2NtZCwgZm5dIG9mIF8udG9QYWlycyhjb21tYW5kcykpIHtcbiAgICAgIEdlY2tvRHJpdmVyLnByb3RvdHlwZVtjbWRdID0gZm47XG4gICAgfVxuICB9XG5cbiAgcmVzZXRTdGF0ZSAoKSB7XG4gICAgdGhpcy5nZWNrbyA9IG51bGw7XG4gICAgdGhpcy5wcm94eVJlcVJlcyA9IG51bGw7XG4gICAgdGhpcy5pc1Byb3h5QWN0aXZlID0gZmFsc2U7XG4gIH1cblxuICBwcm94eUFjdGl2ZSAoKSB7XG4gICAgcmV0dXJuIHRoaXMuaXNQcm94eUFjdGl2ZTtcbiAgfVxuXG4gIGdldFByb3h5QXZvaWRMaXN0ICgpIHtcbiAgICByZXR1cm4gTk9fUFJPWFk7XG4gIH1cblxuICBjYW5Qcm94eSAoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBhc3luYyBjcmVhdGVTZXNzaW9uICguLi5hcmdzKSB7XG4gICAgY29uc3QgW3Nlc3Npb25JZCwgY2Fwc10gPSBhd2FpdCBzdXBlci5jcmVhdGVTZXNzaW9uKC4uLmFyZ3MpO1xuICAgIHRoaXMuZ2Vja28gPSBuZXcgR2Vja29Ecml2ZXJTZXJ2ZXIodGhpcy5sb2csIGNhcHMpO1xuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0aGlzLmdlY2tvLnN0YXJ0KGZvcm1hdENhcHNGb3JTZXJ2ZXIoY2FwcykpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGF3YWl0IHRoaXMuZGVsZXRlU2Vzc2lvbigpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG4gICAgdGhpcy5wcm94eVJlcVJlcyA9IHRoaXMuZ2Vja28ucHJveHkucHJveHlSZXFSZXMuYmluZCh0aGlzLmdlY2tvLnByb3h5KTtcbiAgICB0aGlzLmlzUHJveHlBY3RpdmUgPSB0cnVlO1xuICAgIHJldHVybiBbc2Vzc2lvbklkLCBjYXBzXTtcbiAgfVxuXG4gIGFzeW5jIGRlbGV0ZVNlc3Npb24gKCkge1xuICAgIHRoaXMubG9nLmluZm8oJ0VuZGluZyBHZWNrbyBEcml2ZXIgc2Vzc2lvbicpO1xuICAgIGF3YWl0IHRoaXMuZ2Vja28uc3RvcCgpO1xuICAgIHRoaXMucmVzZXRTdGF0ZSgpO1xuXG4gICAgYXdhaXQgc3VwZXIuZGVsZXRlU2Vzc2lvbigpO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IEdlY2tvRHJpdmVyO1xuIl0sImZpbGUiOiJsaWIvZHJpdmVyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
@@ -15,9 +15,9 @@ var _os = _interopRequireDefault(require("os"));
15
15
 
16
16
  var _path = _interopRequireDefault(require("path"));
17
17
 
18
- var _appiumBaseDriver = require("appium-base-driver");
18
+ var _baseDriver = require("@appium/base-driver");
19
19
 
20
- var _appiumSupport = require("appium-support");
20
+ var _support = require("@appium/support");
21
21
 
22
22
  var _teen_process = require("teen_process");
23
23
 
@@ -29,21 +29,28 @@ var _child_process = require("child_process");
29
29
 
30
30
  var _constants = require("./constants");
31
31
 
32
- const log = _appiumSupport.logger.getLogger('GeckoDriverServer');
33
-
34
- const GD_BINARY = `geckodriver${_appiumSupport.system.isWindows() ? '.exe' : ''}`;
32
+ const GD_BINARY = `geckodriver${_support.system.isWindows() ? '.exe' : ''}`;
35
33
  const STARTUP_TIMEOUT_MS = 10000;
36
34
  const GECKO_PORT_RANGE = [5200, 5300];
37
35
 
38
- const GECKO_SERVER_GUARD = _appiumSupport.util.getLockFileGuard(_path.default.resolve(_os.default.tmpdir(), 'gecko_server_guard.lock'), {
36
+ const GECKO_SERVER_GUARD = _support.util.getLockFileGuard(_path.default.resolve(_os.default.tmpdir(), 'gecko_server_guard.lock'), {
39
37
  timeout: 5,
40
38
  tryRecovery: true
41
39
  });
42
40
 
43
- class GeckoProxy extends _appiumBaseDriver.JWProxy {
41
+ const DEFAULT_MARIONETTE_PORT = 2828;
42
+ const PROCESS_SPECIFIC_OPTION_NAMES_MAP = Object.freeze({
43
+ noReset: 'noReset',
44
+ verbosity: 'verbosity',
45
+ androidStorage: 'androidStorage',
46
+ marionettePort: 'marionettePort',
47
+ systemPort: 'port'
48
+ });
49
+
50
+ class GeckoProxy extends _baseDriver.JWProxy {
44
51
  async proxyCommand(url, method, body = null) {
45
52
  if (this.didProcessExit) {
46
- throw new _appiumBaseDriver.errors.InvalidContextError(`'${method} ${url}' cannot be proxied to Gecko Driver server because ` + 'its process is not running (probably crashed). Check the Appium log for more details');
53
+ throw new _baseDriver.errors.InvalidContextError(`'${method} ${url}' cannot be proxied to Gecko Driver server because ` + 'its process is not running (probably crashed). Check the Appium log for more details');
47
54
  }
48
55
 
49
56
  return await super.proxyCommand(url, method, body);
@@ -52,19 +59,19 @@ class GeckoProxy extends _appiumBaseDriver.JWProxy {
52
59
  }
53
60
 
54
61
  class GeckoDriverProcess {
55
- constructor(opts = {}) {
56
- for (const optName of ['noReset', 'verbosity', 'androidStorage']) {
57
- this[optName] = opts[optName];
62
+ constructor(log, opts = {}) {
63
+ for (const [optName, propName] of _lodash.default.toPairs(PROCESS_SPECIFIC_OPTION_NAMES_MAP)) {
64
+ this[propName] = opts[optName];
58
65
  }
59
66
 
60
- this.port = opts.systemPort;
67
+ this.log = log;
61
68
  this.proc = null;
62
69
  }
63
70
 
64
71
  get isRunning() {
65
72
  var _this$proc;
66
73
 
67
- return !!((_this$proc = this.proc) === null || _this$proc === void 0 ? void 0 : _this$proc.isRunning);
74
+ return !!((_this$proc = this.proc) !== null && _this$proc !== void 0 && _this$proc.isRunning);
68
75
  }
69
76
 
70
77
  async init() {
@@ -87,7 +94,7 @@ class GeckoDriverProcess {
87
94
  let driverBin;
88
95
 
89
96
  try {
90
- driverBin = await _appiumSupport.fs.which(GD_BINARY);
97
+ driverBin = await _support.fs.which(GD_BINARY);
91
98
  } catch (e) {
92
99
  throw new Error(`${GD_BINARY} binary cannot be found in PATH. ` + `Please make sure it is present on your system`);
93
100
  }
@@ -105,7 +112,18 @@ class GeckoDriverProcess {
105
112
  }
106
113
 
107
114
  if (this.noReset) {
115
+ var _this$marionettePort;
116
+
108
117
  args.push('--connect-existing');
118
+
119
+ if (_lodash.default.isNil(this.marionettePort)) {
120
+ this.log.info(`'marionettePort' capability value is not provided while 'noReset' is enabled`);
121
+ this.log.info(`Assigning 'marionettePort' to the default value (${DEFAULT_MARIONETTE_PORT})`);
122
+ }
123
+
124
+ args.push('--marionette-port', (_this$marionettePort = this.marionettePort) !== null && _this$marionettePort !== void 0 ? _this$marionettePort : DEFAULT_MARIONETTE_PORT);
125
+ } else if (!_lodash.default.isNil(this.marionettePort)) {
126
+ args.push('--marionette-port', this.marionettePort);
109
127
  }
110
128
 
111
129
  args.push('-p', this.port);
@@ -119,13 +137,13 @@ class GeckoDriverProcess {
119
137
  const line = _lodash.default.trim(stdout || stderr);
120
138
 
121
139
  if (line) {
122
- log.debug(`[${GD_BINARY}] ${line}`);
140
+ this.log.debug(`[${GD_BINARY}] ${line}`);
123
141
  }
124
142
  });
125
143
  this.proc.on('exit', (code, signal) => {
126
- log.info(`${GD_BINARY} has exited with code ${code}, signal ${signal}`);
144
+ this.log.info(`${GD_BINARY} has exited with code ${code}, signal ${signal}`);
127
145
  });
128
- log.info(`Starting '${driverBin}' with args ${JSON.stringify(args)}`);
146
+ this.log.info(`Starting '${driverBin}' with args ${JSON.stringify(args)}`);
129
147
  await this.proc.start(0);
130
148
  }
131
149
 
@@ -147,25 +165,28 @@ class GeckoDriverProcess {
147
165
 
148
166
  const RUNNING_PROCESS_IDS = [];
149
167
  process.once('exit', () => {
150
- for (const pid of RUNNING_PROCESS_IDS) {
151
- const command = _appiumSupport.system.isWindows() ? `taskkill.exe /PID ${pid}` : `kill ${pid}`;
152
-
153
- try {
154
- (0, _child_process.execSync)(command);
155
- } catch (ign) {}
168
+ if (_lodash.default.isEmpty(RUNNING_PROCESS_IDS)) {
169
+ return;
156
170
  }
171
+
172
+ const command = _support.system.isWindows() ? 'taskkill.exe ' + RUNNING_PROCESS_IDS.map(pid => `/PID ${pid}`).join(' ') : `kill ${RUNNING_PROCESS_IDS.join(' ')}`;
173
+
174
+ try {
175
+ (0, _child_process.execSync)(command);
176
+ } catch (ign) {}
157
177
  });
158
178
 
159
179
  class GeckoDriverServer {
160
- constructor(caps) {
161
- this.process = new GeckoDriverProcess(caps);
180
+ constructor(log, caps) {
181
+ this.process = new GeckoDriverProcess(log, caps);
182
+ this.log = log;
162
183
  this.proxy = null;
163
184
  }
164
185
 
165
186
  get isRunning() {
166
187
  var _this$process;
167
188
 
168
- return !!((_this$process = this.process) === null || _this$process === void 0 ? void 0 : _this$process.isRunning);
189
+ return !!((_this$process = this.process) !== null && _this$process !== void 0 && _this$process.isRunning);
169
190
  }
170
191
 
171
192
  async start(geckoCaps) {
@@ -173,6 +194,7 @@ class GeckoDriverServer {
173
194
  this.proxy = new GeckoProxy({
174
195
  server: '127.0.0.1',
175
196
  port: this.process.port,
197
+ log: this.log,
176
198
  base: '',
177
199
  keepAlive: true
178
200
  });
@@ -224,22 +246,22 @@ class GeckoDriverServer {
224
246
  var _this$proxy;
225
247
 
226
248
  if (!this.isRunning) {
227
- log.info(`Gecko Driver session cannot be stopped, because the server is not running`);
249
+ this.log.info(`Gecko Driver session cannot be stopped, because the server is not running`);
228
250
  return;
229
251
  }
230
252
 
231
- if ((_this$proxy = this.proxy) === null || _this$proxy === void 0 ? void 0 : _this$proxy.sessionId) {
253
+ if ((_this$proxy = this.proxy) !== null && _this$proxy !== void 0 && _this$proxy.sessionId) {
232
254
  try {
233
255
  await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');
234
256
  } catch (e) {
235
- log.info(`Gecko Driver session cannot be deleted. Original error: ${e.message}`);
257
+ this.log.info(`Gecko Driver session cannot be deleted. Original error: ${e.message}`);
236
258
  }
237
259
  }
238
260
 
239
261
  try {
240
262
  await this.process.stop();
241
263
  } catch (e) {
242
- log.warn(`Gecko Driver process cannot be stopped (${e.message}). Killing it forcefully`);
264
+ this.log.warn(`Gecko Driver process cannot be stopped (${e.message}). Killing it forcefully`);
243
265
  await this.process.kill();
244
266
  }
245
267
  }
@@ -250,4 +272,4 @@ var _default = GeckoDriverServer;
250
272
  exports.default = _default;require('source-map-support').install();
251
273
 
252
274
 
253
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/gecko.js"],"names":["log","logger","getLogger","GD_BINARY","system","isWindows","STARTUP_TIMEOUT_MS","GECKO_PORT_RANGE","GECKO_SERVER_GUARD","util","getLockFileGuard","path","resolve","os","tmpdir","timeout","tryRecovery","GeckoProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","GeckoDriverProcess","constructor","opts","optName","port","systemPort","proc","isRunning","init","startPort","endPort","e","Error","driverBin","fs","which","args","_","toLower","verbosity","VERBOSITY","DEBUG","push","TRACE","noReset","androidStorage","SubProcess","on","stdout","stderr","line","trim","debug","code","signal","info","JSON","stringify","start","stop","kill","ign","RUNNING_PROCESS_IDS","process","once","pid","command","GeckoDriverServer","caps","proxy","geckoCaps","server","base","keepAlive","err","message","waitMs","intervalMs","test","pull","capabilities","firstMatch","alwaysMatch","sessionId","warn"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport os from 'os';\nimport path from 'path';\nimport { JWProxy, errors } from 'appium-base-driver';\nimport { fs, logger, util, system } from 'appium-support';\nimport { SubProcess } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { findAPortNotInUse } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { VERBOSITY } from './constants';\n\nconst log = logger.getLogger('GeckoDriverServer');\n\nconst GD_BINARY = `geckodriver${system.isWindows() ? '.exe' : ''}`;\nconst STARTUP_TIMEOUT_MS = 10000; // 10 seconds\nconst GECKO_PORT_RANGE = [5200, 5300];\nconst GECKO_SERVER_GUARD = util.getLockFileGuard(\n  path.resolve(os.tmpdir(), 'gecko_server_guard.lock'),\n  {timeout: 5, tryRecovery: true}\n);\n\n\nclass GeckoProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Gecko Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass GeckoDriverProcess {\n  constructor (opts = {}) {\n    for (const optName of ['noReset', 'verbosity', 'androidStorage']) {\n      this[optName] = opts[optName];\n    }\n    this.port = opts.systemPort;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  async init () {\n    if (this.isRunning) {\n      return;\n    }\n\n    if (!this.port) {\n      await GECKO_SERVER_GUARD(async () => {\n        const [startPort, endPort] = GECKO_PORT_RANGE;\n        try {\n          this.port = await findAPortNotInUse(startPort, endPort);\n        } catch (e) {\n          throw new Error(\n            `Cannot find any free port in range ${startPort}..${endPort}. ` +\n            `Double check the processes that are locking ports within this range and terminate ` +\n            `these which are not needed anymore or set any free port number to the 'systemPort' capability`);\n        }\n      });\n    }\n\n    let driverBin;\n    try {\n      driverBin = await fs.which(GD_BINARY);\n    } catch (e) {\n      throw new Error(`${GD_BINARY} binary cannot be found in PATH. ` +\n        `Please make sure it is present on your system`);\n    }\n    const args = [];\n    /* #region Options */\n    switch (_.toLower(this.verbosity)) {\n      case VERBOSITY.DEBUG:\n        args.push('-v');\n        break;\n      case VERBOSITY.TRACE:\n        args.push('-vv');\n        break;\n    }\n    if (this.noReset) {\n      args.push('--connect-existing');\n    }\n    /* #endregion */\n\n    args.push('-p', this.port);\n    if (this.androidStorage) {\n      args.push('--android-storage', this.androidStorage);\n    }\n    this.proc = new SubProcess(driverBin, args);\n    this.proc.on('output', (stdout, stderr) => {\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        log.debug(`[${GD_BINARY}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      log.info(`${GD_BINARY} has exited with code ${code}, signal ${signal}`);\n    });\n    log.info(`Starting '${driverBin}' with args ${JSON.stringify(args)}`);\n    await this.proc.start(0);\n  }\n\n  async stop () {\n    if (this.isRunning) {\n      await this.proc.stop('SIGTERM');\n    }\n  }\n\n  async kill () {\n    if (this.isRunning) {\n      try {\n        await this.proc.stop('SIGKILL');\n      } catch (ign) {}\n    }\n  }\n}\n\nconst RUNNING_PROCESS_IDS = [];\nprocess.once('exit', () => {\n  for (const pid of RUNNING_PROCESS_IDS) {\n    const command = system.isWindows() ? `taskkill.exe /PID ${pid}` : `kill ${pid}`;\n    try {\n      execSync(command);\n    } catch (ign) {}\n  }\n});\n\nclass GeckoDriverServer {\n  constructor (caps) {\n    this.process = new GeckoDriverProcess(caps);\n    this.proxy = null;\n  }\n\n  get isRunning () {\n    return !!(this.process?.isRunning);\n  }\n\n  async start (geckoCaps) {\n    await this.process.init();\n\n    this.proxy = new GeckoProxy({\n      server: '127.0.0.1',\n      port: this.process.port,\n      base: '',\n      keepAlive: true,\n    });\n    this.proxy.didProcessExit = false;\n    this.process.proc.on('exit', () => {\n      this.proxy.didProcessExit = true;\n    });\n\n    try {\n      await waitForCondition(async () => {\n        try {\n          await this.proxy.command('/status', 'GET');\n          return true;\n        } catch (err) {\n          if (this.proxy.didProcessExit) {\n            throw new Error(err.message);\n          }\n          return false;\n        }\n      }, {\n        waitMs: STARTUP_TIMEOUT_MS,\n        intervalMs: 1000,\n      });\n    } catch (e) {\n      if (this.process.isRunning) {\n        // avoid \"frozen\" processes,\n        await this.process.kill();\n      }\n      if (/Condition unmet/.test(e.message)) {\n        throw new Error(`Gecko Driver server is not listening within ${STARTUP_TIMEOUT_MS}ms timeout. ` +\n          `Make sure it could be started manually from a terminal`);\n      }\n      throw e;\n    }\n    const pid = this.process.proc.pid;\n    RUNNING_PROCESS_IDS.push(pid);\n    this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: geckoCaps,\n      }\n    });\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      log.info(`Gecko Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        log.info(`Gecko Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n\n    try {\n      await this.process.stop();\n    } catch (e) {\n      log.warn(`Gecko Driver process cannot be stopped (${e.message}). Killing it forcefully`);\n      await this.process.kill();\n    }\n  }\n}\n\nexport default GeckoDriverServer;\n"],"file":"lib/gecko.js","sourceRoot":"../.."}
275
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/gecko.js"],"names":["GD_BINARY","system","isWindows","STARTUP_TIMEOUT_MS","GECKO_PORT_RANGE","GECKO_SERVER_GUARD","util","getLockFileGuard","path","resolve","os","tmpdir","timeout","tryRecovery","DEFAULT_MARIONETTE_PORT","PROCESS_SPECIFIC_OPTION_NAMES_MAP","Object","freeze","noReset","verbosity","androidStorage","marionettePort","systemPort","GeckoProxy","JWProxy","proxyCommand","url","method","body","didProcessExit","errors","InvalidContextError","GeckoDriverProcess","constructor","log","opts","optName","propName","_","toPairs","proc","isRunning","init","port","startPort","endPort","e","Error","driverBin","fs","which","args","toLower","VERBOSITY","DEBUG","push","TRACE","isNil","info","SubProcess","on","stdout","stderr","line","trim","debug","code","signal","JSON","stringify","start","stop","kill","ign","RUNNING_PROCESS_IDS","process","once","isEmpty","command","map","pid","join","GeckoDriverServer","caps","proxy","geckoCaps","server","base","keepAlive","err","message","waitMs","intervalMs","test","pull","capabilities","firstMatch","alwaysMatch","sessionId","warn"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,MAAMA,SAAS,GAAI,cAAaC,gBAAOC,SAAP,KAAqB,MAArB,GAA8B,EAAG,EAAjE;AACA,MAAMC,kBAAkB,GAAG,KAA3B;AACA,MAAMC,gBAAgB,GAAG,CAAC,IAAD,EAAO,IAAP,CAAzB;;AACA,MAAMC,kBAAkB,GAAGC,cAAKC,gBAAL,CACzBC,cAAKC,OAAL,CAAaC,YAAGC,MAAH,EAAb,EAA0B,yBAA1B,CADyB,EAEzB;AAACC,EAAAA,OAAO,EAAE,CAAV;AAAaC,EAAAA,WAAW,EAAE;AAA1B,CAFyB,CAA3B;;AAIA,MAAMC,uBAAuB,GAAG,IAAhC;AACA,MAAMC,iCAAiC,GAAGC,MAAM,CAACC,MAAP,CAAc;AACtDC,EAAAA,OAAO,EAAE,SAD6C;AAEtDC,EAAAA,SAAS,EAAE,WAF2C;AAGtDC,EAAAA,cAAc,EAAE,gBAHsC;AAItDC,EAAAA,cAAc,EAAE,gBAJsC;AAKtDC,EAAAA,UAAU,EAAE;AAL0C,CAAd,CAA1C;;AASA,MAAMC,UAAN,SAAyBC,mBAAzB,CAAiC;AACb,QAAZC,YAAY,CAAEC,GAAF,EAAOC,MAAP,EAAeC,IAAI,GAAG,IAAtB,EAA4B;AAC5C,QAAI,KAAKC,cAAT,EAAyB;AACvB,YAAM,IAAIC,mBAAOC,mBAAX,CACH,IAAGJ,MAAO,IAAGD,GAAI,qDAAlB,GACA,sFAFI,CAAN;AAGD;;AACD,WAAO,MAAM,MAAMD,YAAN,CAAmBC,GAAnB,EAAwBC,MAAxB,EAAgCC,IAAhC,CAAb;AACD;;AAR8B;;AAWjC,MAAMI,kBAAN,CAAyB;AACvBC,EAAAA,WAAW,CAAEC,GAAF,EAAOC,IAAI,GAAG,EAAd,EAAkB;AAC3B,SAAK,MAAM,CAACC,OAAD,EAAUC,QAAV,CAAX,IAAkCC,gBAAEC,OAAF,CAAUxB,iCAAV,CAAlC,EAAgF;AAC9E,WAAKsB,QAAL,IAAiBF,IAAI,CAACC,OAAD,CAArB;AACD;;AACD,SAAKF,GAAL,GAAWA,GAAX;AACA,SAAKM,IAAL,GAAY,IAAZ;AACD;;AAEY,MAATC,SAAS,GAAI;AAAA;;AACf,WAAO,CAAC,gBAAE,KAAKD,IAAP,uCAAE,WAAWC,SAAb,CAAR;AACD;;AAES,QAAJC,IAAI,GAAI;AACZ,QAAI,KAAKD,SAAT,EAAoB;AAClB;AACD;;AAED,QAAI,CAAC,KAAKE,IAAV,EAAgB;AACd,YAAMtC,kBAAkB,CAAC,YAAY;AACnC,cAAM,CAACuC,SAAD,EAAYC,OAAZ,IAAuBzC,gBAA7B;;AACA,YAAI;AACF,eAAKuC,IAAL,GAAY,MAAM,oCAAkBC,SAAlB,EAA6BC,OAA7B,CAAlB;AACD,SAFD,CAEE,OAAOC,CAAP,EAAU;AACV,gBAAM,IAAIC,KAAJ,CACH,sCAAqCH,SAAU,KAAIC,OAAQ,IAA5D,GACC,oFADD,GAEC,+FAHG,CAAN;AAID;AACF,OAVuB,CAAxB;AAWD;;AAED,QAAIG,SAAJ;;AACA,QAAI;AACFA,MAAAA,SAAS,GAAG,MAAMC,YAAGC,KAAH,CAASlD,SAAT,CAAlB;AACD,KAFD,CAEE,OAAO8C,CAAP,EAAU;AACV,YAAM,IAAIC,KAAJ,CAAW,GAAE/C,SAAU,mCAAb,GACb,+CADG,CAAN;AAED;;AACD,UAAMmD,IAAI,GAAG,EAAb;;AAEA,YAAQb,gBAAEc,OAAF,CAAU,KAAKjC,SAAf,CAAR;AACE,WAAKkC,qBAAUC,KAAf;AACEH,QAAAA,IAAI,CAACI,IAAL,CAAU,IAAV;AACA;;AACF,WAAKF,qBAAUG,KAAf;AACEL,QAAAA,IAAI,CAACI,IAAL,CAAU,KAAV;AACA;AANJ;;AAQA,QAAI,KAAKrC,OAAT,EAAkB;AAAA;;AAChBiC,MAAAA,IAAI,CAACI,IAAL,CAAU,oBAAV;;AAEA,UAAIjB,gBAAEmB,KAAF,CAAQ,KAAKpC,cAAb,CAAJ,EAAkC;AAChC,aAAKa,GAAL,CAASwB,IAAT,CAAe,8EAAf;AACA,aAAKxB,GAAL,CAASwB,IAAT,CAAe,oDAAmD5C,uBAAwB,GAA1F;AACD;;AACDqC,MAAAA,IAAI,CAACI,IAAL,CAAU,mBAAV,0BAA+B,KAAKlC,cAApC,uEAAsDP,uBAAtD;AACD,KARD,MAQO,IAAI,CAACwB,gBAAEmB,KAAF,CAAQ,KAAKpC,cAAb,CAAL,EAAmC;AACxC8B,MAAAA,IAAI,CAACI,IAAL,CAAU,mBAAV,EAA+B,KAAKlC,cAApC;AACD;;AAGD8B,IAAAA,IAAI,CAACI,IAAL,CAAU,IAAV,EAAgB,KAAKZ,IAArB;;AACA,QAAI,KAAKvB,cAAT,EAAyB;AACvB+B,MAAAA,IAAI,CAACI,IAAL,CAAU,mBAAV,EAA+B,KAAKnC,cAApC;AACD;;AACD,SAAKoB,IAAL,GAAY,IAAImB,wBAAJ,CAAeX,SAAf,EAA0BG,IAA1B,CAAZ;AACA,SAAKX,IAAL,CAAUoB,EAAV,CAAa,QAAb,EAAuB,CAACC,MAAD,EAASC,MAAT,KAAoB;AACzC,YAAMC,IAAI,GAAGzB,gBAAE0B,IAAF,CAAOH,MAAM,IAAIC,MAAjB,CAAb;;AACA,UAAIC,IAAJ,EAAU;AACR,aAAK7B,GAAL,CAAS+B,KAAT,CAAgB,IAAGjE,SAAU,KAAI+D,IAAK,EAAtC;AACD;AACF,KALD;AAMA,SAAKvB,IAAL,CAAUoB,EAAV,CAAa,MAAb,EAAqB,CAACM,IAAD,EAAOC,MAAP,KAAkB;AACrC,WAAKjC,GAAL,CAASwB,IAAT,CAAe,GAAE1D,SAAU,yBAAwBkE,IAAK,YAAWC,MAAO,EAA1E;AACD,KAFD;AAGA,SAAKjC,GAAL,CAASwB,IAAT,CAAe,aAAYV,SAAU,eAAcoB,IAAI,CAACC,SAAL,CAAelB,IAAf,CAAqB,EAAxE;AACA,UAAM,KAAKX,IAAL,CAAU8B,KAAV,CAAgB,CAAhB,CAAN;AACD;;AAES,QAAJC,IAAI,GAAI;AACZ,QAAI,KAAK9B,SAAT,EAAoB;AAClB,YAAM,KAAKD,IAAL,CAAU+B,IAAV,CAAe,SAAf,CAAN;AACD;AACF;;AAES,QAAJC,IAAI,GAAI;AACZ,QAAI,KAAK/B,SAAT,EAAoB;AAClB,UAAI;AACF,cAAM,KAAKD,IAAL,CAAU+B,IAAV,CAAe,SAAf,CAAN;AACD,OAFD,CAEE,OAAOE,GAAP,EAAY,CAAE;AACjB;AACF;;AA5FsB;;AA+FzB,MAAMC,mBAAmB,GAAG,EAA5B;AACAC,OAAO,CAACC,IAAR,CAAa,MAAb,EAAqB,MAAM;AACzB,MAAItC,gBAAEuC,OAAF,CAAUH,mBAAV,CAAJ,EAAoC;AAClC;AACD;;AAED,QAAMI,OAAO,GAAG7E,gBAAOC,SAAP,KACX,kBAAkBwE,mBAAmB,CAACK,GAApB,CAAyBC,GAAD,IAAU,QAAOA,GAAI,EAA7C,EAAgDC,IAAhD,CAAqD,GAArD,CADP,GAEX,QAAOP,mBAAmB,CAACO,IAApB,CAAyB,GAAzB,CAA8B,EAF1C;;AAGA,MAAI;AACF,iCAASH,OAAT;AACD,GAFD,CAEE,OAAOL,GAAP,EAAY,CAAE;AACjB,CAXD;;AAaA,MAAMS,iBAAN,CAAwB;AACtBjD,EAAAA,WAAW,CAAEC,GAAF,EAAOiD,IAAP,EAAa;AACtB,SAAKR,OAAL,GAAe,IAAI3C,kBAAJ,CAAuBE,GAAvB,EAA4BiD,IAA5B,CAAf;AACA,SAAKjD,GAAL,GAAWA,GAAX;AACA,SAAKkD,KAAL,GAAa,IAAb;AACD;;AAEY,MAAT3C,SAAS,GAAI;AAAA;;AACf,WAAO,CAAC,mBAAE,KAAKkC,OAAP,0CAAE,cAAclC,SAAhB,CAAR;AACD;;AAEU,QAAL6B,KAAK,CAAEe,SAAF,EAAa;AACtB,UAAM,KAAKV,OAAL,CAAajC,IAAb,EAAN;AAEA,SAAK0C,KAAL,GAAa,IAAI7D,UAAJ,CAAe;AAC1B+D,MAAAA,MAAM,EAAE,WADkB;AAE1B3C,MAAAA,IAAI,EAAE,KAAKgC,OAAL,CAAahC,IAFO;AAG1BT,MAAAA,GAAG,EAAE,KAAKA,GAHgB;AAI1BqD,MAAAA,IAAI,EAAE,EAJoB;AAK1BC,MAAAA,SAAS,EAAE;AALe,KAAf,CAAb;AAOA,SAAKJ,KAAL,CAAWvD,cAAX,GAA4B,KAA5B;AACA,SAAK8C,OAAL,CAAanC,IAAb,CAAkBoB,EAAlB,CAAqB,MAArB,EAA6B,MAAM;AACjC,WAAKwB,KAAL,CAAWvD,cAAX,GAA4B,IAA5B;AACD,KAFD;;AAIA,QAAI;AACF,YAAM,gCAAiB,YAAY;AACjC,YAAI;AACF,gBAAM,KAAKuD,KAAL,CAAWN,OAAX,CAAmB,SAAnB,EAA8B,KAA9B,CAAN;AACA,iBAAO,IAAP;AACD,SAHD,CAGE,OAAOW,GAAP,EAAY;AACZ,cAAI,KAAKL,KAAL,CAAWvD,cAAf,EAA+B;AAC7B,kBAAM,IAAIkB,KAAJ,CAAU0C,GAAG,CAACC,OAAd,CAAN;AACD;;AACD,iBAAO,KAAP;AACD;AACF,OAVK,EAUH;AACDC,QAAAA,MAAM,EAAExF,kBADP;AAEDyF,QAAAA,UAAU,EAAE;AAFX,OAVG,CAAN;AAcD,KAfD,CAeE,OAAO9C,CAAP,EAAU;AACV,UAAI,KAAK6B,OAAL,CAAalC,SAAjB,EAA4B;AAE1B,cAAM,KAAKkC,OAAL,CAAaH,IAAb,EAAN;AACD;;AACD,UAAI,kBAAkBqB,IAAlB,CAAuB/C,CAAC,CAAC4C,OAAzB,CAAJ,EAAuC;AACrC,cAAM,IAAI3C,KAAJ,CAAW,+CAA8C5C,kBAAmB,cAAlE,GACb,wDADG,CAAN;AAED;;AACD,YAAM2C,CAAN;AACD;;AACD,UAAMkC,GAAG,GAAG,KAAKL,OAAL,CAAanC,IAAb,CAAkBwC,GAA9B;AACAN,IAAAA,mBAAmB,CAACnB,IAApB,CAAyByB,GAAzB;AACA,SAAKL,OAAL,CAAanC,IAAb,CAAkBoB,EAAlB,CAAqB,MAArB,EAA6B,MAAM,KAAKtB,gBAAEwD,IAAF,CAAOpB,mBAAP,EAA4BM,GAA5B,CAAxC;AAEA,UAAM,KAAKI,KAAL,CAAWN,OAAX,CAAmB,UAAnB,EAA+B,MAA/B,EAAuC;AAC3CiB,MAAAA,YAAY,EAAE;AACZC,QAAAA,UAAU,EAAE,CAAC,EAAD,CADA;AAEZC,QAAAA,WAAW,EAAEZ;AAFD;AAD6B,KAAvC,CAAN;AAMD;;AAES,QAAJd,IAAI,GAAI;AAAA;;AACZ,QAAI,CAAC,KAAK9B,SAAV,EAAqB;AACnB,WAAKP,GAAL,CAASwB,IAAT,CAAe,2EAAf;AACA;AACD;;AAED,uBAAI,KAAK0B,KAAT,wCAAI,YAAYc,SAAhB,EAA2B;AACzB,UAAI;AACF,cAAM,KAAKd,KAAL,CAAWN,OAAX,CAAoB,YAAW,KAAKM,KAAL,CAAWc,SAAU,EAApD,EAAuD,QAAvD,CAAN;AACD,OAFD,CAEE,OAAOpD,CAAP,EAAU;AACV,aAAKZ,GAAL,CAASwB,IAAT,CAAe,2DAA0DZ,CAAC,CAAC4C,OAAQ,EAAnF;AACD;AACF;;AAED,QAAI;AACF,YAAM,KAAKf,OAAL,CAAaJ,IAAb,EAAN;AACD,KAFD,CAEE,OAAOzB,CAAP,EAAU;AACV,WAAKZ,GAAL,CAASiE,IAAT,CAAe,2CAA0CrD,CAAC,CAAC4C,OAAQ,0BAAnE;AACA,YAAM,KAAKf,OAAL,CAAaH,IAAb,EAAN;AACD;AACF;;AApFqB;;eAuFTU,iB","sourcesContent":["import _ from 'lodash';\nimport os from 'os';\nimport path from 'path';\nimport { JWProxy, errors } from '@appium/base-driver';\nimport { fs, util, system } from '@appium/support';\nimport { SubProcess } from 'teen_process';\nimport { waitForCondition } from 'asyncbox';\nimport { findAPortNotInUse } from 'portscanner';\nimport { execSync } from 'child_process';\nimport { VERBOSITY } from './constants';\n\nconst GD_BINARY = `geckodriver${system.isWindows() ? '.exe' : ''}`;\nconst STARTUP_TIMEOUT_MS = 10000; // 10 seconds\nconst GECKO_PORT_RANGE = [5200, 5300];\nconst GECKO_SERVER_GUARD = util.getLockFileGuard(\n  path.resolve(os.tmpdir(), 'gecko_server_guard.lock'),\n  {timeout: 5, tryRecovery: true}\n);\nconst DEFAULT_MARIONETTE_PORT = 2828;\nconst PROCESS_SPECIFIC_OPTION_NAMES_MAP = Object.freeze({\n  noReset: 'noReset',\n  verbosity: 'verbosity',\n  androidStorage: 'androidStorage',\n  marionettePort: 'marionettePort',\n  systemPort: 'port',\n});\n\n\nclass GeckoProxy extends JWProxy {\n  async proxyCommand (url, method, body = null) {\n    if (this.didProcessExit) {\n      throw new errors.InvalidContextError(\n        `'${method} ${url}' cannot be proxied to Gecko Driver server because ` +\n        'its process is not running (probably crashed). Check the Appium log for more details');\n    }\n    return await super.proxyCommand(url, method, body);\n  }\n}\n\nclass GeckoDriverProcess {\n  constructor (log, opts = {}) {\n    for (const [optName, propName] of _.toPairs(PROCESS_SPECIFIC_OPTION_NAMES_MAP)) {\n      this[propName] = opts[optName];\n    }\n    this.log = log;\n    this.proc = null;\n  }\n\n  get isRunning () {\n    return !!(this.proc?.isRunning);\n  }\n\n  async init () {\n    if (this.isRunning) {\n      return;\n    }\n\n    if (!this.port) {\n      await GECKO_SERVER_GUARD(async () => {\n        const [startPort, endPort] = GECKO_PORT_RANGE;\n        try {\n          this.port = await findAPortNotInUse(startPort, endPort);\n        } catch (e) {\n          throw new Error(\n            `Cannot find any free port in range ${startPort}..${endPort}. ` +\n            `Double check the processes that are locking ports within this range and terminate ` +\n            `these which are not needed anymore or set any free port number to the 'systemPort' capability`);\n        }\n      });\n    }\n\n    let driverBin;\n    try {\n      driverBin = await fs.which(GD_BINARY);\n    } catch (e) {\n      throw new Error(`${GD_BINARY} binary cannot be found in PATH. ` +\n        `Please make sure it is present on your system`);\n    }\n    const args = [];\n    /* #region Options */\n    switch (_.toLower(this.verbosity)) {\n      case VERBOSITY.DEBUG:\n        args.push('-v');\n        break;\n      case VERBOSITY.TRACE:\n        args.push('-vv');\n        break;\n    }\n    if (this.noReset) {\n      args.push('--connect-existing');\n      // https://firefox-source-docs.mozilla.org/testing/geckodriver/Flags.html#code-connect-existing-code\n      if (_.isNil(this.marionettePort)) {\n        this.log.info(`'marionettePort' capability value is not provided while 'noReset' is enabled`);\n        this.log.info(`Assigning 'marionettePort' to the default value (${DEFAULT_MARIONETTE_PORT})`);\n      }\n      args.push('--marionette-port', this.marionettePort ?? DEFAULT_MARIONETTE_PORT);\n    } else if (!_.isNil(this.marionettePort)) {\n      args.push('--marionette-port', this.marionettePort);\n    }\n    /* #endregion */\n\n    args.push('-p', this.port);\n    if (this.androidStorage) {\n      args.push('--android-storage', this.androidStorage);\n    }\n    this.proc = new SubProcess(driverBin, args);\n    this.proc.on('output', (stdout, stderr) => {\n      const line = _.trim(stdout || stderr);\n      if (line) {\n        this.log.debug(`[${GD_BINARY}] ${line}`);\n      }\n    });\n    this.proc.on('exit', (code, signal) => {\n      this.log.info(`${GD_BINARY} has exited with code ${code}, signal ${signal}`);\n    });\n    this.log.info(`Starting '${driverBin}' with args ${JSON.stringify(args)}`);\n    await this.proc.start(0);\n  }\n\n  async stop () {\n    if (this.isRunning) {\n      await this.proc.stop('SIGTERM');\n    }\n  }\n\n  async kill () {\n    if (this.isRunning) {\n      try {\n        await this.proc.stop('SIGKILL');\n      } catch (ign) {}\n    }\n  }\n}\n\nconst RUNNING_PROCESS_IDS = [];\nprocess.once('exit', () => {\n  if (_.isEmpty(RUNNING_PROCESS_IDS)) {\n    return;\n  }\n\n  const command = system.isWindows()\n    ? ('taskkill.exe ' + RUNNING_PROCESS_IDS.map((pid) => `/PID ${pid}`).join(' '))\n    : `kill ${RUNNING_PROCESS_IDS.join(' ')}`;\n  try {\n    execSync(command);\n  } catch (ign) {}\n});\n\nclass GeckoDriverServer {\n  constructor (log, caps) {\n    this.process = new GeckoDriverProcess(log, caps);\n    this.log = log;\n    this.proxy = null;\n  }\n\n  get isRunning () {\n    return !!(this.process?.isRunning);\n  }\n\n  async start (geckoCaps) {\n    await this.process.init();\n\n    this.proxy = new GeckoProxy({\n      server: '127.0.0.1',\n      port: this.process.port,\n      log: this.log,\n      base: '',\n      keepAlive: true,\n    });\n    this.proxy.didProcessExit = false;\n    this.process.proc.on('exit', () => {\n      this.proxy.didProcessExit = true;\n    });\n\n    try {\n      await waitForCondition(async () => {\n        try {\n          await this.proxy.command('/status', 'GET');\n          return true;\n        } catch (err) {\n          if (this.proxy.didProcessExit) {\n            throw new Error(err.message);\n          }\n          return false;\n        }\n      }, {\n        waitMs: STARTUP_TIMEOUT_MS,\n        intervalMs: 1000,\n      });\n    } catch (e) {\n      if (this.process.isRunning) {\n        // avoid \"frozen\" processes,\n        await this.process.kill();\n      }\n      if (/Condition unmet/.test(e.message)) {\n        throw new Error(`Gecko Driver server is not listening within ${STARTUP_TIMEOUT_MS}ms timeout. ` +\n          `Make sure it could be started manually from a terminal`);\n      }\n      throw e;\n    }\n    const pid = this.process.proc.pid;\n    RUNNING_PROCESS_IDS.push(pid);\n    this.process.proc.on('exit', () => void _.pull(RUNNING_PROCESS_IDS, pid));\n\n    await this.proxy.command('/session', 'POST', {\n      capabilities: {\n        firstMatch: [{}],\n        alwaysMatch: geckoCaps,\n      }\n    });\n  }\n\n  async stop () {\n    if (!this.isRunning) {\n      this.log.info(`Gecko Driver session cannot be stopped, because the server is not running`);\n      return;\n    }\n\n    if (this.proxy?.sessionId) {\n      try {\n        await this.proxy.command(`/session/${this.proxy.sessionId}`, 'DELETE');\n      } catch (e) {\n        this.log.info(`Gecko Driver session cannot be deleted. Original error: ${e.message}`);\n      }\n    }\n\n    try {\n      await this.process.stop();\n    } catch (e) {\n      this.log.warn(`Gecko Driver process cannot be stopped (${e.message}). Killing it forcefully`);\n      await this.process.kill();\n    }\n  }\n}\n\nexport default GeckoDriverServer;\n"],"file":"lib/gecko.js","sourceRoot":"../.."}
@@ -7,12 +7,12 @@ exports.default = void 0;
7
7
 
8
8
  require("source-map-support/register");
9
9
 
10
- var _appiumSupport = require("appium-support");
10
+ var _support = require("@appium/support");
11
11
 
12
- const log = _appiumSupport.logger.getLogger('GeckoDriver');
12
+ const log = _support.logger.getLogger('GeckoDriver');
13
13
 
14
14
  var _default = log;
15
15
  exports.default = _default;require('source-map-support').install();
16
16
 
17
17
 
18
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9sb2dnZXIuanMiXSwibmFtZXMiOlsibG9nIiwibG9nZ2VyIiwiZ2V0TG9nZ2VyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxHQUFHLEdBQUdDLHNCQUFPQyxTQUFQLENBQWlCLGFBQWpCLENBQVo7O2VBRWVGLEciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdhcHBpdW0tc3VwcG9ydCc7XG5cbmNvbnN0IGxvZyA9IGxvZ2dlci5nZXRMb2dnZXIoJ0dlY2tvRHJpdmVyJyk7XG5cbmV4cG9ydCBkZWZhdWx0IGxvZztcbiJdLCJmaWxlIjoibGliL2xvZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
18
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9sb2dnZXIuanMiXSwibmFtZXMiOlsibG9nIiwibG9nZ2VyIiwiZ2V0TG9nZ2VyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxHQUFHLEdBQUdDLGdCQUFPQyxTQUFQLENBQWlCLGFBQWpCLENBQVo7O2VBRWVGLEciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAYXBwaXVtL3N1cHBvcnQnO1xuXG5jb25zdCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdHZWNrb0RyaXZlcicpO1xuXG5leHBvcnQgZGVmYXVsdCBsb2c7XG4iXSwiZmlsZSI6ImxpYi9sb2dnZXIuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
@@ -11,7 +11,7 @@ require("source-map-support/register");
11
11
 
12
12
  var _logger = _interopRequireDefault(require("./logger"));
13
13
 
14
- var _appiumBaseDriver = require("appium-base-driver");
14
+ var _baseDriver = require("@appium/base-driver");
15
15
 
16
16
  var _driver = _interopRequireDefault(require("./driver"));
17
17
 
@@ -20,8 +20,8 @@ async function startServer(port, address) {
20
20
  port,
21
21
  address
22
22
  });
23
- let routeConfiguringFunction = (0, _appiumBaseDriver.routeConfiguringFunction)(d);
24
- let server = await (0, _appiumBaseDriver.server)({
23
+ let routeConfiguringFunction = (0, _baseDriver.routeConfiguringFunction)(d);
24
+ let server = await (0, _baseDriver.server)({
25
25
  routeConfiguringFunction,
26
26
  port,
27
27
  hostname: address
@@ -33,4 +33,4 @@ async function startServer(port, address) {
33
33
  }require('source-map-support').install();
34
34
 
35
35
 
36
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9zZXJ2ZXIuanMiXSwibmFtZXMiOlsic3RhcnRTZXJ2ZXIiLCJwb3J0IiwiYWRkcmVzcyIsImQiLCJHZWNrb0RyaXZlciIsInJvdXRlQ29uZmlndXJpbmdGdW5jdGlvbiIsInNlcnZlciIsImhvc3RuYW1lIiwibG9nIiwiaW5mbyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFFQSxlQUFlQSxXQUFmLENBQTRCQyxJQUE1QixFQUFrQ0MsT0FBbEMsRUFBMkM7QUFDekMsTUFBSUMsQ0FBQyxHQUFHLElBQUlDLGVBQUosQ0FBZ0I7QUFBQ0gsSUFBQUEsSUFBRDtBQUFPQyxJQUFBQTtBQUFQLEdBQWhCLENBQVI7QUFDQSxNQUFJRyx3QkFBd0IsR0FBRyxnREFBV0YsQ0FBWCxDQUEvQjtBQUNBLE1BQUlHLE1BQU0sR0FBRyxNQUFNLDhCQUFXO0FBQUNELElBQUFBLHdCQUFEO0FBQTJCSixJQUFBQSxJQUEzQjtBQUFpQ00sSUFBQUEsUUFBUSxFQUFFTDtBQUEzQyxHQUFYLENBQW5COztBQUNBTSxrQkFBSUMsSUFBSixDQUFVLDJDQUEwQ1AsT0FBUSxJQUFHRCxJQUFLLEVBQXBFOztBQUNBLFNBQU9LLE1BQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBsb2cgZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHsgc2VydmVyIGFzIGJhc2VTZXJ2ZXIsIHJvdXRlQ29uZmlndXJpbmdGdW5jdGlvbiBhcyBtYWtlUm91dGVyIH0gZnJvbSAnYXBwaXVtLWJhc2UtZHJpdmVyJztcbmltcG9ydCBHZWNrb0RyaXZlciBmcm9tICcuL2RyaXZlcic7XG5cbmFzeW5jIGZ1bmN0aW9uIHN0YXJ0U2VydmVyIChwb3J0LCBhZGRyZXNzKSB7XG4gIGxldCBkID0gbmV3IEdlY2tvRHJpdmVyKHtwb3J0LCBhZGRyZXNzfSk7XG4gIGxldCByb3V0ZUNvbmZpZ3VyaW5nRnVuY3Rpb24gPSBtYWtlUm91dGVyKGQpO1xuICBsZXQgc2VydmVyID0gYXdhaXQgYmFzZVNlcnZlcih7cm91dGVDb25maWd1cmluZ0Z1bmN0aW9uLCBwb3J0LCBob3N0bmFtZTogYWRkcmVzc30pO1xuICBsb2cuaW5mbyhgR2Vja28gRHJpdmVyIHNlcnZlciBsaXN0ZW5pbmcgb24gaHR0cDovLyR7YWRkcmVzc306JHtwb3J0fWApO1xuICByZXR1cm4gc2VydmVyO1xufVxuXG5leHBvcnQgeyBzdGFydFNlcnZlciB9O1xuIl0sImZpbGUiOiJsaWIvc2VydmVyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
36
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9zZXJ2ZXIuanMiXSwibmFtZXMiOlsic3RhcnRTZXJ2ZXIiLCJwb3J0IiwiYWRkcmVzcyIsImQiLCJHZWNrb0RyaXZlciIsInJvdXRlQ29uZmlndXJpbmdGdW5jdGlvbiIsInNlcnZlciIsImhvc3RuYW1lIiwibG9nIiwiaW5mbyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFHQTs7QUFFQSxlQUFlQSxXQUFmLENBQTRCQyxJQUE1QixFQUFrQ0MsT0FBbEMsRUFBMkM7QUFDekMsTUFBSUMsQ0FBQyxHQUFHLElBQUlDLGVBQUosQ0FBZ0I7QUFBQ0gsSUFBQUEsSUFBRDtBQUFPQyxJQUFBQTtBQUFQLEdBQWhCLENBQVI7QUFDQSxNQUFJRyx3QkFBd0IsR0FBRywwQ0FBV0YsQ0FBWCxDQUEvQjtBQUNBLE1BQUlHLE1BQU0sR0FBRyxNQUFNLHdCQUFXO0FBQUNELElBQUFBLHdCQUFEO0FBQTJCSixJQUFBQSxJQUEzQjtBQUFpQ00sSUFBQUEsUUFBUSxFQUFFTDtBQUEzQyxHQUFYLENBQW5COztBQUNBTSxrQkFBSUMsSUFBSixDQUFVLDJDQUEwQ1AsT0FBUSxJQUFHRCxJQUFLLEVBQXBFOztBQUNBLFNBQU9LLE1BQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBsb2cgZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHtcbiAgc2VydmVyIGFzIGJhc2VTZXJ2ZXIsIHJvdXRlQ29uZmlndXJpbmdGdW5jdGlvbiBhcyBtYWtlUm91dGVyXG59IGZyb20gJ0BhcHBpdW0vYmFzZS1kcml2ZXInO1xuaW1wb3J0IEdlY2tvRHJpdmVyIGZyb20gJy4vZHJpdmVyJztcblxuYXN5bmMgZnVuY3Rpb24gc3RhcnRTZXJ2ZXIgKHBvcnQsIGFkZHJlc3MpIHtcbiAgbGV0IGQgPSBuZXcgR2Vja29Ecml2ZXIoe3BvcnQsIGFkZHJlc3N9KTtcbiAgbGV0IHJvdXRlQ29uZmlndXJpbmdGdW5jdGlvbiA9IG1ha2VSb3V0ZXIoZCk7XG4gIGxldCBzZXJ2ZXIgPSBhd2FpdCBiYXNlU2VydmVyKHtyb3V0ZUNvbmZpZ3VyaW5nRnVuY3Rpb24sIHBvcnQsIGhvc3RuYW1lOiBhZGRyZXNzfSk7XG4gIGxvZy5pbmZvKGBHZWNrbyBEcml2ZXIgc2VydmVyIGxpc3RlbmluZyBvbiBodHRwOi8vJHthZGRyZXNzfToke3BvcnR9YCk7XG4gIHJldHVybiBzZXJ2ZXI7XG59XG5cbmV4cG9ydCB7IHN0YXJ0U2VydmVyIH07XG4iXSwiZmlsZSI6ImxpYi9zZXJ2ZXIuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
@@ -4,7 +4,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
 
5
5
  require("source-map-support/register");
6
6
 
7
- var _wd = _interopRequireDefault(require("wd"));
7
+ var _webdriverio = require("webdriverio");
8
8
 
9
9
  var _ = require("../..");
10
10
 
@@ -36,21 +36,24 @@ describe('Desktop Gecko Driver', function () {
36
36
  }
37
37
  });
38
38
  beforeEach(async function () {
39
- driver = _wd.default.promiseChainRemote(_utils.HOST, _utils.PORT);
40
- await driver.init(CAPS);
39
+ driver = await (0, _webdriverio.remote)({
40
+ hostname: _utils.HOST,
41
+ port: _utils.PORT,
42
+ capabilities: CAPS
43
+ });
41
44
  });
42
45
  afterEach(async function () {
43
46
  if (driver) {
44
- await driver.quit();
47
+ await driver.deleteSession();
45
48
  driver = null;
46
49
  }
47
50
  });
48
51
  it('should start and stop a session', async function () {
49
- await driver.get('https://appium.io/');
50
- const button = await driver.elementByCss('#downloadLink');
51
- await button.text().should.eventually.eql('Download Appium');
52
+ await driver.url('https://appium.io/');
53
+ const button = await driver.$('#downloadLink');
54
+ await button.getText().should.eventually.eql('Download Appium');
52
55
  });
53
56
  });require('source-map-support').install();
54
57
 
55
58
 
56
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvZnVuY3Rpb25hbC9kZXNrdG9wLWRyaXZlci1lMmUtc3BlY3MuanMiXSwibmFtZXMiOlsiY2hhaSIsInNob3VsZCIsInVzZSIsImNoYWlBc1Byb21pc2VkIiwiQ0FQUyIsImJyb3dzZXJOYW1lIiwicGxhdGZvcm1OYW1lIiwiZGVzY3JpYmUiLCJ0aW1lb3V0IiwiTU9DSEFfVElNRU9VVCIsInNlcnZlciIsImRyaXZlciIsImJlZm9yZSIsIlBPUlQiLCJIT1NUIiwiYWZ0ZXIiLCJjbG9zZSIsImJlZm9yZUVhY2giLCJ3ZCIsInByb21pc2VDaGFpblJlbW90ZSIsImluaXQiLCJhZnRlckVhY2giLCJxdWl0IiwiaXQiLCJnZXQiLCJidXR0b24iLCJlbGVtZW50QnlDc3MiLCJ0ZXh0IiwiZXZlbnR1YWxseSIsImVxbCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBRUFBLGNBQUtDLE1BQUw7O0FBQ0FELGNBQUtFLEdBQUwsQ0FBU0MsdUJBQVQ7O0FBRUEsTUFBTUMsSUFBSSxHQUFHO0FBQ1hDLEVBQUFBLFdBQVcsRUFBRSxnQkFERjtBQUVYQyxFQUFBQSxZQUFZLEVBQUU7QUFGSCxDQUFiO0FBS0FDLFFBQVEsQ0FBQyxzQkFBRCxFQUF5QixZQUFZO0FBQzNDLE9BQUtDLE9BQUwsQ0FBYUMsb0JBQWI7QUFFQSxNQUFJQyxNQUFKO0FBQ0EsTUFBSUMsTUFBSjtBQUNBQyxFQUFBQSxNQUFNLENBQUMsa0JBQWtCO0FBQ3ZCRixJQUFBQSxNQUFNLEdBQUcsTUFBTSxtQkFBWUcsV0FBWixFQUFrQkMsV0FBbEIsQ0FBZjtBQUNELEdBRkssQ0FBTjtBQUdBQyxFQUFBQSxLQUFLLENBQUMsa0JBQWtCO0FBQ3RCLFFBQUlMLE1BQUosRUFBWTtBQUNWLFlBQU1BLE1BQU0sQ0FBQ00sS0FBUCxFQUFOO0FBQ0FOLE1BQUFBLE1BQU0sR0FBRyxJQUFUO0FBQ0Q7QUFDRixHQUxJLENBQUw7QUFNQU8sRUFBQUEsVUFBVSxDQUFDLGtCQUFrQjtBQUMzQk4sSUFBQUEsTUFBTSxHQUFHTyxZQUFHQyxrQkFBSCxDQUFzQkwsV0FBdEIsRUFBNEJELFdBQTVCLENBQVQ7QUFDQSxVQUFNRixNQUFNLENBQUNTLElBQVAsQ0FBWWhCLElBQVosQ0FBTjtBQUNELEdBSFMsQ0FBVjtBQUlBaUIsRUFBQUEsU0FBUyxDQUFDLGtCQUFrQjtBQUMxQixRQUFJVixNQUFKLEVBQVk7QUFDVixZQUFNQSxNQUFNLENBQUNXLElBQVAsRUFBTjtBQUNBWCxNQUFBQSxNQUFNLEdBQUcsSUFBVDtBQUNEO0FBQ0YsR0FMUSxDQUFUO0FBT0FZLEVBQUFBLEVBQUUsQ0FBQyxpQ0FBRCxFQUFvQyxrQkFBa0I7QUFDdEQsVUFBTVosTUFBTSxDQUFDYSxHQUFQLENBQVcsb0JBQVgsQ0FBTjtBQUNBLFVBQU1DLE1BQU0sR0FBRyxNQUFNZCxNQUFNLENBQUNlLFlBQVAsQ0FBb0IsZUFBcEIsQ0FBckI7QUFDQSxVQUFNRCxNQUFNLENBQUNFLElBQVAsR0FBYzFCLE1BQWQsQ0FBcUIyQixVQUFyQixDQUFnQ0MsR0FBaEMsQ0FBb0MsaUJBQXBDLENBQU47QUFDRCxHQUpDLENBQUY7QUFLRCxDQTlCTyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHdkIGZyb20gJ3dkJztcbmltcG9ydCB7IHN0YXJ0U2VydmVyIH0gZnJvbSAnLi4vLi4nO1xuaW1wb3J0IGNoYWlBc1Byb21pc2VkIGZyb20gJ2NoYWktYXMtcHJvbWlzZWQnO1xuaW1wb3J0IGNoYWkgZnJvbSAnY2hhaSc7XG5pbXBvcnQgeyBIT1NULCBQT1JULCBNT0NIQV9USU1FT1VUIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jaGFpLnNob3VsZCgpO1xuY2hhaS51c2UoY2hhaUFzUHJvbWlzZWQpO1xuXG5jb25zdCBDQVBTID0ge1xuICBicm93c2VyTmFtZTogJ01vemlsbGFGaXJlZm94JyxcbiAgcGxhdGZvcm1OYW1lOiAnbGludXgnLFxufTtcblxuZGVzY3JpYmUoJ0Rlc2t0b3AgR2Vja28gRHJpdmVyJywgZnVuY3Rpb24gKCkge1xuICB0aGlzLnRpbWVvdXQoTU9DSEFfVElNRU9VVCk7XG5cbiAgbGV0IHNlcnZlcjtcbiAgbGV0IGRyaXZlcjtcbiAgYmVmb3JlKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBzZXJ2ZXIgPSBhd2FpdCBzdGFydFNlcnZlcihQT1JULCBIT1NUKTtcbiAgfSk7XG4gIGFmdGVyKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBpZiAoc2VydmVyKSB7XG4gICAgICBhd2FpdCBzZXJ2ZXIuY2xvc2UoKTtcbiAgICAgIHNlcnZlciA9IG51bGw7XG4gICAgfVxuICB9KTtcbiAgYmVmb3JlRWFjaChhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgZHJpdmVyID0gd2QucHJvbWlzZUNoYWluUmVtb3RlKEhPU1QsIFBPUlQpO1xuICAgIGF3YWl0IGRyaXZlci5pbml0KENBUFMpO1xuICB9KTtcbiAgYWZ0ZXJFYWNoKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBpZiAoZHJpdmVyKSB7XG4gICAgICBhd2FpdCBkcml2ZXIucXVpdCgpO1xuICAgICAgZHJpdmVyID0gbnVsbDtcbiAgICB9XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgc3RhcnQgYW5kIHN0b3AgYSBzZXNzaW9uJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgIGF3YWl0IGRyaXZlci5nZXQoJ2h0dHBzOi8vYXBwaXVtLmlvLycpO1xuICAgIGNvbnN0IGJ1dHRvbiA9IGF3YWl0IGRyaXZlci5lbGVtZW50QnlDc3MoJyNkb3dubG9hZExpbmsnKTtcbiAgICBhd2FpdCBidXR0b24udGV4dCgpLnNob3VsZC5ldmVudHVhbGx5LmVxbCgnRG93bmxvYWQgQXBwaXVtJyk7XG4gIH0pO1xufSk7XG5cblxuIl0sImZpbGUiOiJ0ZXN0L2Z1bmN0aW9uYWwvZGVza3RvcC1kcml2ZXItZTJlLXNwZWNzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uIn0=
59
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvZnVuY3Rpb25hbC9kZXNrdG9wLWRyaXZlci1lMmUtc3BlY3MuanMiXSwibmFtZXMiOlsiY2hhaSIsInNob3VsZCIsInVzZSIsImNoYWlBc1Byb21pc2VkIiwiQ0FQUyIsImJyb3dzZXJOYW1lIiwicGxhdGZvcm1OYW1lIiwiZGVzY3JpYmUiLCJ0aW1lb3V0IiwiTU9DSEFfVElNRU9VVCIsInNlcnZlciIsImRyaXZlciIsImJlZm9yZSIsIlBPUlQiLCJIT1NUIiwiYWZ0ZXIiLCJjbG9zZSIsImJlZm9yZUVhY2giLCJob3N0bmFtZSIsInBvcnQiLCJjYXBhYmlsaXRpZXMiLCJhZnRlckVhY2giLCJkZWxldGVTZXNzaW9uIiwiaXQiLCJ1cmwiLCJidXR0b24iLCIkIiwiZ2V0VGV4dCIsImV2ZW50dWFsbHkiLCJlcWwiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBQSxjQUFLQyxNQUFMOztBQUNBRCxjQUFLRSxHQUFMLENBQVNDLHVCQUFUOztBQUVBLE1BQU1DLElBQUksR0FBRztBQUNYQyxFQUFBQSxXQUFXLEVBQUUsZ0JBREY7QUFFWEMsRUFBQUEsWUFBWSxFQUFFO0FBRkgsQ0FBYjtBQUtBQyxRQUFRLENBQUMsc0JBQUQsRUFBeUIsWUFBWTtBQUMzQyxPQUFLQyxPQUFMLENBQWFDLG9CQUFiO0FBRUEsTUFBSUMsTUFBSjtBQUNBLE1BQUlDLE1BQUo7QUFDQUMsRUFBQUEsTUFBTSxDQUFDLGtCQUFrQjtBQUN2QkYsSUFBQUEsTUFBTSxHQUFHLE1BQU0sbUJBQVlHLFdBQVosRUFBa0JDLFdBQWxCLENBQWY7QUFDRCxHQUZLLENBQU47QUFHQUMsRUFBQUEsS0FBSyxDQUFDLGtCQUFrQjtBQUN0QixRQUFJTCxNQUFKLEVBQVk7QUFDVixZQUFNQSxNQUFNLENBQUNNLEtBQVAsRUFBTjtBQUNBTixNQUFBQSxNQUFNLEdBQUcsSUFBVDtBQUNEO0FBQ0YsR0FMSSxDQUFMO0FBTUFPLEVBQUFBLFVBQVUsQ0FBQyxrQkFBa0I7QUFDM0JOLElBQUFBLE1BQU0sR0FBRyxNQUFNLHlCQUFPO0FBQ3BCTyxNQUFBQSxRQUFRLEVBQUVKLFdBRFU7QUFFcEJLLE1BQUFBLElBQUksRUFBRU4sV0FGYztBQUdwQk8sTUFBQUEsWUFBWSxFQUFFaEI7QUFITSxLQUFQLENBQWY7QUFLRCxHQU5TLENBQVY7QUFPQWlCLEVBQUFBLFNBQVMsQ0FBQyxrQkFBa0I7QUFDMUIsUUFBSVYsTUFBSixFQUFZO0FBQ1YsWUFBTUEsTUFBTSxDQUFDVyxhQUFQLEVBQU47QUFDQVgsTUFBQUEsTUFBTSxHQUFHLElBQVQ7QUFDRDtBQUNGLEdBTFEsQ0FBVDtBQU9BWSxFQUFBQSxFQUFFLENBQUMsaUNBQUQsRUFBb0Msa0JBQWtCO0FBQ3RELFVBQU1aLE1BQU0sQ0FBQ2EsR0FBUCxDQUFXLG9CQUFYLENBQU47QUFDQSxVQUFNQyxNQUFNLEdBQUcsTUFBTWQsTUFBTSxDQUFDZSxDQUFQLENBQVMsZUFBVCxDQUFyQjtBQUNBLFVBQU1ELE1BQU0sQ0FBQ0UsT0FBUCxHQUFpQjFCLE1BQWpCLENBQXdCMkIsVUFBeEIsQ0FBbUNDLEdBQW5DLENBQXVDLGlCQUF2QyxDQUFOO0FBQ0QsR0FKQyxDQUFGO0FBS0QsQ0FqQ08sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlbW90ZSB9IGZyb20gJ3dlYmRyaXZlcmlvJztcbmltcG9ydCB7IHN0YXJ0U2VydmVyIH0gZnJvbSAnLi4vLi4nO1xuaW1wb3J0IGNoYWlBc1Byb21pc2VkIGZyb20gJ2NoYWktYXMtcHJvbWlzZWQnO1xuaW1wb3J0IGNoYWkgZnJvbSAnY2hhaSc7XG5pbXBvcnQgeyBIT1NULCBQT1JULCBNT0NIQV9USU1FT1VUIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jaGFpLnNob3VsZCgpO1xuY2hhaS51c2UoY2hhaUFzUHJvbWlzZWQpO1xuXG5jb25zdCBDQVBTID0ge1xuICBicm93c2VyTmFtZTogJ01vemlsbGFGaXJlZm94JyxcbiAgcGxhdGZvcm1OYW1lOiAnbGludXgnLFxufTtcblxuZGVzY3JpYmUoJ0Rlc2t0b3AgR2Vja28gRHJpdmVyJywgZnVuY3Rpb24gKCkge1xuICB0aGlzLnRpbWVvdXQoTU9DSEFfVElNRU9VVCk7XG5cbiAgbGV0IHNlcnZlcjtcbiAgbGV0IGRyaXZlcjtcbiAgYmVmb3JlKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBzZXJ2ZXIgPSBhd2FpdCBzdGFydFNlcnZlcihQT1JULCBIT1NUKTtcbiAgfSk7XG4gIGFmdGVyKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBpZiAoc2VydmVyKSB7XG4gICAgICBhd2FpdCBzZXJ2ZXIuY2xvc2UoKTtcbiAgICAgIHNlcnZlciA9IG51bGw7XG4gICAgfVxuICB9KTtcbiAgYmVmb3JlRWFjaChhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgZHJpdmVyID0gYXdhaXQgcmVtb3RlKHtcbiAgICAgIGhvc3RuYW1lOiBIT1NULFxuICAgICAgcG9ydDogUE9SVCxcbiAgICAgIGNhcGFiaWxpdGllczogQ0FQUyxcbiAgICB9KTtcbiAgfSk7XG4gIGFmdGVyRWFjaChhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgaWYgKGRyaXZlcikge1xuICAgICAgYXdhaXQgZHJpdmVyLmRlbGV0ZVNlc3Npb24oKTtcbiAgICAgIGRyaXZlciA9IG51bGw7XG4gICAgfVxuICB9KTtcblxuICBpdCgnc2hvdWxkIHN0YXJ0IGFuZCBzdG9wIGEgc2Vzc2lvbicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBhd2FpdCBkcml2ZXIudXJsKCdodHRwczovL2FwcGl1bS5pby8nKTtcbiAgICBjb25zdCBidXR0b24gPSBhd2FpdCBkcml2ZXIuJCgnI2Rvd25sb2FkTGluaycpO1xuICAgIGF3YWl0IGJ1dHRvbi5nZXRUZXh0KCkuc2hvdWxkLmV2ZW50dWFsbHkuZXFsKCdEb3dubG9hZCBBcHBpdW0nKTtcbiAgfSk7XG59KTtcblxuXG4iXSwiZmlsZSI6InRlc3QvZnVuY3Rpb25hbC9kZXNrdG9wLWRyaXZlci1lMmUtc3BlY3MuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4ifQ==