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 +1 -1
- package/.github/workflows/publish.js.yml +30 -0
- package/.releaserc +18 -0
- package/README.md +14 -7
- package/build/index.js +1 -1
- package/build/lib/commands/find.js +3 -3
- package/build/lib/desired-caps.js +4 -1
- package/build/lib/driver.js +5 -8
- package/build/lib/gecko.js +53 -31
- package/build/lib/logger.js +3 -3
- package/build/lib/server.js +4 -4
- package/build/test/functional/desktop-driver-e2e-specs.js +11 -8
- package/build/test/functional/mobile-driver-e2e-specs.js +11 -8
- package/build/test/utils.js +1 -1
- package/gulpfile.js +2 -1
- package/lib/commands/find.js +1 -1
- package/lib/desired-caps.js +3 -0
- package/lib/driver.js +3 -4
- package/lib/gecko.js +41 -21
- package/lib/logger.js +1 -1
- package/lib/server.js +3 -1
- package/npm-shrinkwrap.json +2383 -0
- package/package.json +13 -9
- package/test/functional/desktop-driver-e2e-specs.js +10 -7
- package/test/functional/mobile-driver-e2e-specs.js +10 -7
package/.eslintrc
CHANGED
|
@@ -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
|
-
|
|
1
|
+
Appium Geckodriver
|
|
2
2
|
====
|
|
3
3
|
|
|
4
|
+
[](https://npmjs.org/package/appium-geckodriver)
|
|
5
|
+
[](https://npmjs.org/package/appium-geckodriver)
|
|
6
|
+
|
|
7
|
+
[](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
|
-
|
|
31
|
-
|
|
32
|
-
|
|
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
|
|
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 =
|
|
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,
|
|
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,
|
|
58
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kZXNpcmVkLWNhcHMuanMiXSwibmFtZXMiOlsiZGVzaXJlZENhcENvbnN0cmFpbnRzIiwiYnJvd3Nlck5hbWUiLCJpc1N0cmluZyIsImJyb3dzZXJWZXJzaW9uIiwiYWNjZXB0SW5zZWN1cmVDZXJ0cyIsImlzQm9vbGVhbiIsInBhZ2VMb2FkU3RyYXRlZ3kiLCJwcm94eSIsImlzT2JqZWN0Iiwic2V0V2luZG93UmVjdCIsInRpbWVvdXRzIiwidW5oYW5kbGVkUHJvbXB0QmVoYXZpb3IiLCJzeXN0ZW1Qb3J0IiwiaXNOdW1iZXIiLCJtYXJpb25ldHRlUG9ydCIsInZlcmJvc2l0eSIsImluY2x1c2lvbkNhc2VJbnNlbnNpdGl2ZSIsIk9iamVjdCIsInZhbHVlcyIsIlZFUkJPU0lUWSIsImFuZHJvaWRTdG9yYWdlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxxQkFBcUIsR0FBRztBQUM1QkMsRUFBQUEsV0FBVyxFQUFFO0FBQ1hDLElBQUFBLFFBQVEsRUFBRTtBQURDLEdBRGU7QUFJNUJDLEVBQUFBLGNBQWMsRUFBRTtBQUNkRCxJQUFBQSxRQUFRLEVBQUU7QUFESSxHQUpZO0FBTzVCRSxFQUFBQSxtQkFBbUIsRUFBRTtBQUNuQkMsSUFBQUEsU0FBUyxFQUFFO0FBRFEsR0FQTztBQVU1QkMsRUFBQUEsZ0JBQWdCLEVBQUU7QUFDaEJKLElBQUFBLFFBQVEsRUFBRTtBQURNLEdBVlU7QUFhNUJLLEVBQUFBLEtBQUssRUFBRTtBQUNMQyxJQUFBQSxRQUFRLEVBQUU7QUFETCxHQWJxQjtBQWdCNUJDLEVBQUFBLGFBQWEsRUFBRTtBQUNiSixJQUFBQSxTQUFTLEVBQUU7QUFERSxHQWhCYTtBQW1CNUJLLEVBQUFBLFFBQVEsRUFBRTtBQUNSRixJQUFBQSxRQUFRLEVBQUU7QUFERixHQW5Ca0I7QUFzQjVCRyxFQUFBQSx1QkFBdUIsRUFBRTtBQUN2QlQsSUFBQUEsUUFBUSxFQUFFO0FBRGEsR0F0Qkc7QUF5QjVCVSxFQUFBQSxVQUFVLEVBQUU7QUFDVkMsSUFBQUEsUUFBUSxFQUFFO0FBREEsR0F6QmdCO0FBNEI1QkMsRUFBQUEsY0FBYyxFQUFFO0FBQ2RELElBQUFBLFFBQVEsRUFBRTtBQURJLEdBNUJZO0FBK0I1QkUsRUFBQUEsU0FBUyxFQUFFO0FBQ1RiLElBQUFBLFFBQVEsRUFBRSxJQUREO0FBRVRjLElBQUFBLHdCQUF3QixFQUFFQyxNQUFNLENBQUNDLE1BQVAsQ0FBY0Msb0JBQWQ7QUFGakIsR0EvQmlCO0FBbUM1QkMsRUFBQUEsY0FBYyxFQUFFO0FBQ2RsQixJQUFBQSxRQUFRLEVBQUUsSUFESTtBQUVkYyxJQUFBQSx3QkFBd0IsRUFBRSxDQUFDLE1BQUQsRUFBUyxLQUFULEVBQWdCLFVBQWhCLEVBQTRCLFFBQTVCO0FBRlosR0FuQ1k7QUF1QzVCLHdCQUFzQjtBQUNwQlIsSUFBQUEsUUFBUSxFQUFFO0FBRFU7QUF2Q00sQ0FBOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWRVJCT1NJVFkgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5cbmNvbnN0IGRlc2lyZWRDYXBDb25zdHJhaW50cyA9IHtcbiAgYnJvd3Nlck5hbWU6IHtcbiAgICBpc1N0cmluZzogdHJ1ZVxuICB9LFxuICBicm93c2VyVmVyc2lvbjoge1xuICAgIGlzU3RyaW5nOiB0cnVlXG4gIH0sXG4gIGFjY2VwdEluc2VjdXJlQ2VydHM6IHtcbiAgICBpc0Jvb2xlYW46IHRydWVcbiAgfSxcbiAgcGFnZUxvYWRTdHJhdGVneToge1xuICAgIGlzU3RyaW5nOiB0cnVlXG4gIH0sXG4gIHByb3h5OiB7XG4gICAgaXNPYmplY3Q6IHRydWVcbiAgfSxcbiAgc2V0V2luZG93UmVjdDoge1xuICAgIGlzQm9vbGVhbjogdHJ1ZVxuICB9LFxuICB0aW1lb3V0czoge1xuICAgIGlzT2JqZWN0OiB0cnVlXG4gIH0sXG4gIHVuaGFuZGxlZFByb21wdEJlaGF2aW9yOiB7XG4gICAgaXNTdHJpbmc6IHRydWVcbiAgfSxcbiAgc3lzdGVtUG9ydDoge1xuICAgIGlzTnVtYmVyOiB0cnVlXG4gIH0sXG4gIG1hcmlvbmV0dGVQb3J0OiB7XG4gICAgaXNOdW1iZXI6IHRydWVcbiAgfSxcbiAgdmVyYm9zaXR5OiB7XG4gICAgaXNTdHJpbmc6IHRydWUsXG4gICAgaW5jbHVzaW9uQ2FzZUluc2Vuc2l0aXZlOiBPYmplY3QudmFsdWVzKFZFUkJPU0lUWSlcbiAgfSxcbiAgYW5kcm9pZFN0b3JhZ2U6IHtcbiAgICBpc1N0cmluZzogdHJ1ZSxcbiAgICBpbmNsdXNpb25DYXNlSW5zZW5zaXRpdmU6IFsnYXV0bycsICdhcHAnLCAnaW50ZXJuYWwnLCAnc2RjYXJkJ11cbiAgfSxcbiAgJ21vejpmaXJlZm94T3B0aW9ucyc6IHtcbiAgICBpc09iamVjdDogdHJ1ZVxuICB9XG59O1xuXG5leHBvcnQgeyBkZXNpcmVkQ2FwQ29uc3RyYWludHMgfTtcbiJdLCJmaWxlIjoibGliL2Rlc2lyZWQtY2Fwcy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
|
package/build/lib/driver.js
CHANGED
|
@@ -11,9 +11,7 @@ require("source-map-support/register");
|
|
|
11
11
|
|
|
12
12
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
13
|
|
|
14
|
-
var
|
|
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
|
|
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
|
-
|
|
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,
|
|
85
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9kcml2ZXIuanMiXSwibmFtZXMiOlsiTk9fUFJPWFkiLCJSZWdFeHAiLCJHZWNrb0RyaXZlciIsIkJhc2VEcml2ZXIiLCJjb25zdHJ1Y3RvciIsIm9wdHMiLCJkZXNpcmVkQ2FwQ29uc3RyYWludHMiLCJsb2NhdG9yU3RyYXRlZ2llcyIsInJlc2V0U3RhdGUiLCJjbWQiLCJmbiIsIl8iLCJ0b1BhaXJzIiwiY29tbWFuZHMiLCJwcm90b3R5cGUiLCJnZWNrbyIsInByb3h5UmVxUmVzIiwiaXNQcm94eUFjdGl2ZSIsInByb3h5QWN0aXZlIiwiZ2V0UHJveHlBdm9pZExpc3QiLCJjYW5Qcm94eSIsImNyZWF0ZVNlc3Npb24iLCJhcmdzIiwic2Vzc2lvbklkIiwiY2FwcyIsIkdlY2tvRHJpdmVyU2VydmVyIiwibG9nIiwic3RhcnQiLCJlIiwiZGVsZXRlU2Vzc2lvbiIsInByb3h5IiwiYmluZCIsImluZm8iLCJzdG9wIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBLE1BQU1BLFFBQVEsR0FBRyxDQUNmLENBQUMsS0FBRCxFQUFRLElBQUlDLE1BQUosQ0FBVyx3QkFBWCxDQUFSLENBRGUsRUFFZixDQUFDLE1BQUQsRUFBUyxJQUFJQSxNQUFKLENBQVcsd0JBQVgsQ0FBVCxDQUZlLEVBR2YsQ0FBQyxNQUFELEVBQVMsSUFBSUEsTUFBSixDQUFXLDBDQUFYLENBQVQsQ0FIZSxFQUlmLENBQUMsTUFBRCxFQUFTLElBQUlBLE1BQUosQ0FBVyw0QkFBWCxDQUFULENBSmUsQ0FBakI7O0FBT0EsTUFBTUMsV0FBTixTQUEwQkMsc0JBQTFCLENBQXFDO0FBQ25DQyxFQUFBQSxXQUFXLENBQUVDLElBQUksR0FBRyxFQUFULEVBQWE7QUFDdEIsVUFBTUEsSUFBTjtBQUNBLFNBQUtDLHFCQUFMLEdBQTZCQSxrQ0FBN0I7QUFDQSxTQUFLQyxpQkFBTCxHQUF5QixDQUN2QixPQUR1QixFQUV2QixVQUZ1QixFQUd2QixXQUh1QixFQUl2QixtQkFKdUIsRUFLdkIsY0FMdUIsRUFPdkIsSUFQdUIsRUFRdkIsTUFSdUIsQ0FBekI7QUFVQSxTQUFLQyxVQUFMOztBQUVBLFNBQUssTUFBTSxDQUFDQyxHQUFELEVBQU1DLEVBQU4sQ0FBWCxJQUF3QkMsZ0JBQUVDLE9BQUYsQ0FBVUMsY0FBVixDQUF4QixFQUE2QztBQUMzQ1gsTUFBQUEsV0FBVyxDQUFDWSxTQUFaLENBQXNCTCxHQUF0QixJQUE2QkMsRUFBN0I7QUFDRDtBQUNGOztBQUVERixFQUFBQSxVQUFVLEdBQUk7QUFDWixTQUFLTyxLQUFMLEdBQWEsSUFBYjtBQUNBLFNBQUtDLFdBQUwsR0FBbUIsSUFBbkI7QUFDQSxTQUFLQyxhQUFMLEdBQXFCLEtBQXJCO0FBQ0Q7O0FBRURDLEVBQUFBLFdBQVcsR0FBSTtBQUNiLFdBQU8sS0FBS0QsYUFBWjtBQUNEOztBQUVERSxFQUFBQSxpQkFBaUIsR0FBSTtBQUNuQixXQUFPbkIsUUFBUDtBQUNEOztBQUVEb0IsRUFBQUEsUUFBUSxHQUFJO0FBQ1YsV0FBTyxJQUFQO0FBQ0Q7O0FBRWtCLFFBQWJDLGFBQWEsQ0FBRSxHQUFHQyxJQUFMLEVBQVc7QUFDNUIsVUFBTSxDQUFDQyxTQUFELEVBQVlDLElBQVosSUFBb0IsTUFBTSxNQUFNSCxhQUFOLENBQW9CLEdBQUdDLElBQXZCLENBQWhDO0FBQ0EsU0FBS1AsS0FBTCxHQUFhLElBQUlVLGNBQUosQ0FBc0IsS0FBS0MsR0FBM0IsRUFBZ0NGLElBQWhDLENBQWI7O0FBQ0EsUUFBSTtBQUNGLFlBQU0sS0FBS1QsS0FBTCxDQUFXWSxLQUFYLENBQWlCLGdDQUFvQkgsSUFBcEIsQ0FBakIsQ0FBTjtBQUNELEtBRkQsQ0FFRSxPQUFPSSxDQUFQLEVBQVU7QUFDVixZQUFNLEtBQUtDLGFBQUwsRUFBTjtBQUNBLFlBQU1ELENBQU47QUFDRDs7QUFDRCxTQUFLWixXQUFMLEdBQW1CLEtBQUtELEtBQUwsQ0FBV2UsS0FBWCxDQUFpQmQsV0FBakIsQ0FBNkJlLElBQTdCLENBQWtDLEtBQUtoQixLQUFMLENBQVdlLEtBQTdDLENBQW5CO0FBQ0EsU0FBS2IsYUFBTCxHQUFxQixJQUFyQjtBQUNBLFdBQU8sQ0FBQ00sU0FBRCxFQUFZQyxJQUFaLENBQVA7QUFDRDs7QUFFa0IsUUFBYkssYUFBYSxHQUFJO0FBQ3JCLFNBQUtILEdBQUwsQ0FBU00sSUFBVCxDQUFjLDZCQUFkO0FBQ0EsVUFBTSxLQUFLakIsS0FBTCxDQUFXa0IsSUFBWCxFQUFOO0FBQ0EsU0FBS3pCLFVBQUw7QUFFQSxVQUFNLE1BQU1xQixhQUFOLEVBQU47QUFDRDs7QUEzRGtDOztlQThEdEIzQixXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IEJhc2VEcml2ZXIgfSBmcm9tICdAYXBwaXVtL2Jhc2UtZHJpdmVyJztcbmltcG9ydCBHZWNrb0RyaXZlclNlcnZlciBmcm9tICcuL2dlY2tvJztcbmltcG9ydCB7IGRlc2lyZWRDYXBDb25zdHJhaW50cyB9IGZyb20gJy4vZGVzaXJlZC1jYXBzJztcbmltcG9ydCBjb21tYW5kcyBmcm9tICcuL2NvbW1hbmRzL2luZGV4JztcbmltcG9ydCB7IGZvcm1hdENhcHNGb3JTZXJ2ZXIgfSBmcm9tICcuL3V0aWxzJztcblxuY29uc3QgTk9fUFJPWFkgPSBbXG4gIFsnR0VUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2FwcGl1bScpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnQvW14vXSsvZWxlbWVudHM/JCcpXSxcbiAgWydQT1NUJywgbmV3IFJlZ0V4cCgnXi9zZXNzaW9uL1teL10rL2VsZW1lbnRzPyQnKV0sXG5dO1xuXG5jbGFzcyBHZWNrb0RyaXZlciBleHRlbmRzIEJhc2VEcml2ZXIge1xuICBjb25zdHJ1Y3RvciAob3B0cyA9IHt9KSB7XG4gICAgc3VwZXIob3B0cyk7XG4gICAgdGhpcy5kZXNpcmVkQ2FwQ29uc3RyYWludHMgPSBkZXNpcmVkQ2FwQ29uc3RyYWludHM7XG4gICAgdGhpcy5sb2NhdG9yU3RyYXRlZ2llcyA9IFtcbiAgICAgICd4cGF0aCcsXG4gICAgICAndGFnIG5hbWUnLFxuICAgICAgJ2xpbmsgdGV4dCcsXG4gICAgICAncGFydGlhbCBsaW5rIHRleHQnLFxuICAgICAgJ2NzcyBzZWxlY3RvcicsXG4gICAgICAvLyBMZXQgdGhlc2UgdHdvIHJlYWNoIEdlY2tvIERyaXZlciBhbmQgZmFpbCB0aGVyZSB3aXRoIGEgcHJvcGVyIGVycm9yIG1lc3NhZ2VcbiAgICAgICdpZCcsXG4gICAgICAnbmFtZScsXG4gICAgXTtcbiAgICB0aGlzLnJlc2V0U3RhdGUoKTtcblxuICAgIGZvciAoY29uc3QgW2NtZCwgZm5dIG9mIF8udG9QYWlycyhjb21tYW5kcykpIHtcbiAgICAgIEdlY2tvRHJpdmVyLnByb3RvdHlwZVtjbWRdID0gZm47XG4gICAgfVxuICB9XG5cbiAgcmVzZXRTdGF0ZSAoKSB7XG4gICAgdGhpcy5nZWNrbyA9IG51bGw7XG4gICAgdGhpcy5wcm94eVJlcVJlcyA9IG51bGw7XG4gICAgdGhpcy5pc1Byb3h5QWN0aXZlID0gZmFsc2U7XG4gIH1cblxuICBwcm94eUFjdGl2ZSAoKSB7XG4gICAgcmV0dXJuIHRoaXMuaXNQcm94eUFjdGl2ZTtcbiAgfVxuXG4gIGdldFByb3h5QXZvaWRMaXN0ICgpIHtcbiAgICByZXR1cm4gTk9fUFJPWFk7XG4gIH1cblxuICBjYW5Qcm94eSAoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBhc3luYyBjcmVhdGVTZXNzaW9uICguLi5hcmdzKSB7XG4gICAgY29uc3QgW3Nlc3Npb25JZCwgY2Fwc10gPSBhd2FpdCBzdXBlci5jcmVhdGVTZXNzaW9uKC4uLmFyZ3MpO1xuICAgIHRoaXMuZ2Vja28gPSBuZXcgR2Vja29Ecml2ZXJTZXJ2ZXIodGhpcy5sb2csIGNhcHMpO1xuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0aGlzLmdlY2tvLnN0YXJ0KGZvcm1hdENhcHNGb3JTZXJ2ZXIoY2FwcykpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGF3YWl0IHRoaXMuZGVsZXRlU2Vzc2lvbigpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG4gICAgdGhpcy5wcm94eVJlcVJlcyA9IHRoaXMuZ2Vja28ucHJveHkucHJveHlSZXFSZXMuYmluZCh0aGlzLmdlY2tvLnByb3h5KTtcbiAgICB0aGlzLmlzUHJveHlBY3RpdmUgPSB0cnVlO1xuICAgIHJldHVybiBbc2Vzc2lvbklkLCBjYXBzXTtcbiAgfVxuXG4gIGFzeW5jIGRlbGV0ZVNlc3Npb24gKCkge1xuICAgIHRoaXMubG9nLmluZm8oJ0VuZGluZyBHZWNrbyBEcml2ZXIgc2Vzc2lvbicpO1xuICAgIGF3YWl0IHRoaXMuZ2Vja28uc3RvcCgpO1xuICAgIHRoaXMucmVzZXRTdGF0ZSgpO1xuXG4gICAgYXdhaXQgc3VwZXIuZGVsZXRlU2Vzc2lvbigpO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IEdlY2tvRHJpdmVyO1xuIl0sImZpbGUiOiJsaWIvZHJpdmVyLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
|
package/build/lib/gecko.js
CHANGED
|
@@ -15,9 +15,9 @@ var _os = _interopRequireDefault(require("os"));
|
|
|
15
15
|
|
|
16
16
|
var _path = _interopRequireDefault(require("path"));
|
|
17
17
|
|
|
18
|
-
var
|
|
18
|
+
var _baseDriver = require("@appium/base-driver");
|
|
19
19
|
|
|
20
|
-
var
|
|
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
|
|
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 =
|
|
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
|
-
|
|
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
|
|
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
|
|
57
|
-
this[
|
|
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.
|
|
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)
|
|
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
|
|
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
|
-
|
|
151
|
-
|
|
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)
|
|
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)
|
|
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":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,MAAMA,GAAG,GAAGC,sBAAOC,SAAP,CAAiB,mBAAjB,CAAZ;;AAEA,MAAMC,SAAS,GAAI,cAAaC,sBAAOC,SAAP,KAAqB,MAArB,GAA8B,EAAG,EAAjE;AACA,MAAMC,kBAAkB,GAAG,KAA3B;AACA,MAAMC,gBAAgB,GAAG,CAAC,IAAD,EAAO,IAAP,CAAzB;;AACA,MAAMC,kBAAkB,GAAGC,oBAAKC,gBAAL,CACzBC,cAAKC,OAAL,CAAaC,YAAGC,MAAH,EAAb,EAA0B,yBAA1B,CADyB,EAEzB;AAACC,EAAAA,OAAO,EAAE,CAAV;AAAaC,EAAAA,WAAW,EAAE;AAA1B,CAFyB,CAA3B;;AAMA,MAAMC,UAAN,SAAyBC,yBAAzB,CAAiC;AAC/B,QAAMC,YAAN,CAAoBC,GAApB,EAAyBC,MAAzB,EAAiCC,IAAI,GAAG,IAAxC,EAA8C;AAC5C,QAAI,KAAKC,cAAT,EAAyB;AACvB,YAAM,IAAIC,yBAAOC,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,IAAI,GAAG,EAAT,EAAa;AACtB,SAAK,MAAMC,OAAX,IAAsB,CAAC,SAAD,EAAY,WAAZ,EAAyB,gBAAzB,CAAtB,EAAkE;AAChE,WAAKA,OAAL,IAAgBD,IAAI,CAACC,OAAD,CAApB;AACD;;AACD,SAAKC,IAAL,GAAYF,IAAI,CAACG,UAAjB;AACA,SAAKC,IAAL,GAAY,IAAZ;AACD;;AAED,MAAIC,SAAJ,GAAiB;AAAA;;AACf,WAAO,CAAC,gBAAE,KAAKD,IAAP,+CAAE,WAAWC,SAAb,CAAR;AACD;;AAED,QAAMC,IAAN,GAAc;AACZ,QAAI,KAAKD,SAAT,EAAoB;AAClB;AACD;;AAED,QAAI,CAAC,KAAKH,IAAV,EAAgB;AACd,YAAMtB,kBAAkB,CAAC,YAAY;AACnC,cAAM,CAAC2B,SAAD,EAAYC,OAAZ,IAAuB7B,gBAA7B;;AACA,YAAI;AACF,eAAKuB,IAAL,GAAY,MAAM,oCAAkBK,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,kBAAGC,KAAH,CAAStC,SAAT,CAAlB;AACD,KAFD,CAEE,OAAOkC,CAAP,EAAU;AACV,YAAM,IAAIC,KAAJ,CAAW,GAAEnC,SAAU,mCAAb,GACb,+CADG,CAAN;AAED;;AACD,UAAMuC,IAAI,GAAG,EAAb;;AAEA,YAAQC,gBAAEC,OAAF,CAAU,KAAKC,SAAf,CAAR;AACE,WAAKC,qBAAUC,KAAf;AACEL,QAAAA,IAAI,CAACM,IAAL,CAAU,IAAV;AACA;;AACF,WAAKF,qBAAUG,KAAf;AACEP,QAAAA,IAAI,CAACM,IAAL,CAAU,KAAV;AACA;AANJ;;AAQA,QAAI,KAAKE,OAAT,EAAkB;AAChBR,MAAAA,IAAI,CAACM,IAAL,CAAU,oBAAV;AACD;;AAGDN,IAAAA,IAAI,CAACM,IAAL,CAAU,IAAV,EAAgB,KAAKlB,IAArB;;AACA,QAAI,KAAKqB,cAAT,EAAyB;AACvBT,MAAAA,IAAI,CAACM,IAAL,CAAU,mBAAV,EAA+B,KAAKG,cAApC;AACD;;AACD,SAAKnB,IAAL,GAAY,IAAIoB,wBAAJ,CAAeb,SAAf,EAA0BG,IAA1B,CAAZ;AACA,SAAKV,IAAL,CAAUqB,EAAV,CAAa,QAAb,EAAuB,CAACC,MAAD,EAASC,MAAT,KAAoB;AACzC,YAAMC,IAAI,GAAGb,gBAAEc,IAAF,CAAOH,MAAM,IAAIC,MAAjB,CAAb;;AACA,UAAIC,IAAJ,EAAU;AACRxD,QAAAA,GAAG,CAAC0D,KAAJ,CAAW,IAAGvD,SAAU,KAAIqD,IAAK,EAAjC;AACD;AACF,KALD;AAMA,SAAKxB,IAAL,CAAUqB,EAAV,CAAa,MAAb,EAAqB,CAACM,IAAD,EAAOC,MAAP,KAAkB;AACrC5D,MAAAA,GAAG,CAAC6D,IAAJ,CAAU,GAAE1D,SAAU,yBAAwBwD,IAAK,YAAWC,MAAO,EAArE;AACD,KAFD;AAGA5D,IAAAA,GAAG,CAAC6D,IAAJ,CAAU,aAAYtB,SAAU,eAAcuB,IAAI,CAACC,SAAL,CAAerB,IAAf,CAAqB,EAAnE;AACA,UAAM,KAAKV,IAAL,CAAUgC,KAAV,CAAgB,CAAhB,CAAN;AACD;;AAED,QAAMC,IAAN,GAAc;AACZ,QAAI,KAAKhC,SAAT,EAAoB;AAClB,YAAM,KAAKD,IAAL,CAAUiC,IAAV,CAAe,SAAf,CAAN;AACD;AACF;;AAED,QAAMC,IAAN,GAAc;AACZ,QAAI,KAAKjC,SAAT,EAAoB;AAClB,UAAI;AACF,cAAM,KAAKD,IAAL,CAAUiC,IAAV,CAAe,SAAf,CAAN;AACD,OAFD,CAEE,OAAOE,GAAP,EAAY,CAAE;AACjB;AACF;;AApFsB;;AAuFzB,MAAMC,mBAAmB,GAAG,EAA5B;AACAC,OAAO,CAACC,IAAR,CAAa,MAAb,EAAqB,MAAM;AACzB,OAAK,MAAMC,GAAX,IAAkBH,mBAAlB,EAAuC;AACrC,UAAMI,OAAO,GAAGpE,sBAAOC,SAAP,KAAsB,qBAAoBkE,GAAI,EAA9C,GAAmD,QAAOA,GAAI,EAA9E;;AACA,QAAI;AACF,mCAASC,OAAT;AACD,KAFD,CAEE,OAAOL,GAAP,EAAY,CAAE;AACjB;AACF,CAPD;;AASA,MAAMM,iBAAN,CAAwB;AACtB9C,EAAAA,WAAW,CAAE+C,IAAF,EAAQ;AACjB,SAAKL,OAAL,GAAe,IAAI3C,kBAAJ,CAAuBgD,IAAvB,CAAf;AACA,SAAKC,KAAL,GAAa,IAAb;AACD;;AAED,MAAI1C,SAAJ,GAAiB;AAAA;;AACf,WAAO,CAAC,mBAAE,KAAKoC,OAAP,kDAAE,cAAcpC,SAAhB,CAAR;AACD;;AAED,QAAM+B,KAAN,CAAaY,SAAb,EAAwB;AACtB,UAAM,KAAKP,OAAL,CAAanC,IAAb,EAAN;AAEA,SAAKyC,KAAL,GAAa,IAAI1D,UAAJ,CAAe;AAC1B4D,MAAAA,MAAM,EAAE,WADkB;AAE1B/C,MAAAA,IAAI,EAAE,KAAKuC,OAAL,CAAavC,IAFO;AAG1BgD,MAAAA,IAAI,EAAE,EAHoB;AAI1BC,MAAAA,SAAS,EAAE;AAJe,KAAf,CAAb;AAMA,SAAKJ,KAAL,CAAWpD,cAAX,GAA4B,KAA5B;AACA,SAAK8C,OAAL,CAAarC,IAAb,CAAkBqB,EAAlB,CAAqB,MAArB,EAA6B,MAAM;AACjC,WAAKsB,KAAL,CAAWpD,cAAX,GAA4B,IAA5B;AACD,KAFD;;AAIA,QAAI;AACF,YAAM,gCAAiB,YAAY;AACjC,YAAI;AACF,gBAAM,KAAKoD,KAAL,CAAWH,OAAX,CAAmB,SAAnB,EAA8B,KAA9B,CAAN;AACA,iBAAO,IAAP;AACD,SAHD,CAGE,OAAOQ,GAAP,EAAY;AACZ,cAAI,KAAKL,KAAL,CAAWpD,cAAf,EAA+B;AAC7B,kBAAM,IAAIe,KAAJ,CAAU0C,GAAG,CAACC,OAAd,CAAN;AACD;;AACD,iBAAO,KAAP;AACD;AACF,OAVK,EAUH;AACDC,QAAAA,MAAM,EAAE5E,kBADP;AAED6E,QAAAA,UAAU,EAAE;AAFX,OAVG,CAAN;AAcD,KAfD,CAeE,OAAO9C,CAAP,EAAU;AACV,UAAI,KAAKgC,OAAL,CAAapC,SAAjB,EAA4B;AAE1B,cAAM,KAAKoC,OAAL,CAAaH,IAAb,EAAN;AACD;;AACD,UAAI,kBAAkBkB,IAAlB,CAAuB/C,CAAC,CAAC4C,OAAzB,CAAJ,EAAuC;AACrC,cAAM,IAAI3C,KAAJ,CAAW,+CAA8ChC,kBAAmB,cAAlE,GACb,wDADG,CAAN;AAED;;AACD,YAAM+B,CAAN;AACD;;AACD,UAAMkC,GAAG,GAAG,KAAKF,OAAL,CAAarC,IAAb,CAAkBuC,GAA9B;AACAH,IAAAA,mBAAmB,CAACpB,IAApB,CAAyBuB,GAAzB;AACA,SAAKF,OAAL,CAAarC,IAAb,CAAkBqB,EAAlB,CAAqB,MAArB,EAA6B,MAAM,KAAKV,gBAAE0C,IAAF,CAAOjB,mBAAP,EAA4BG,GAA5B,CAAxC;AAEA,UAAM,KAAKI,KAAL,CAAWH,OAAX,CAAmB,UAAnB,EAA+B,MAA/B,EAAuC;AAC3Cc,MAAAA,YAAY,EAAE;AACZC,QAAAA,UAAU,EAAE,CAAC,EAAD,CADA;AAEZC,QAAAA,WAAW,EAAEZ;AAFD;AAD6B,KAAvC,CAAN;AAMD;;AAED,QAAMX,IAAN,GAAc;AAAA;;AACZ,QAAI,CAAC,KAAKhC,SAAV,EAAqB;AACnBjC,MAAAA,GAAG,CAAC6D,IAAJ,CAAU,2EAAV;AACA;AACD;;AAED,uBAAI,KAAKc,KAAT,gDAAI,YAAYc,SAAhB,EAA2B;AACzB,UAAI;AACF,cAAM,KAAKd,KAAL,CAAWH,OAAX,CAAoB,YAAW,KAAKG,KAAL,CAAWc,SAAU,EAApD,EAAuD,QAAvD,CAAN;AACD,OAFD,CAEE,OAAOpD,CAAP,EAAU;AACVrC,QAAAA,GAAG,CAAC6D,IAAJ,CAAU,2DAA0DxB,CAAC,CAAC4C,OAAQ,EAA9E;AACD;AACF;;AAED,QAAI;AACF,YAAM,KAAKZ,OAAL,CAAaJ,IAAb,EAAN;AACD,KAFD,CAEE,OAAO5B,CAAP,EAAU;AACVrC,MAAAA,GAAG,CAAC0F,IAAJ,CAAU,2CAA0CrD,CAAC,CAAC4C,OAAQ,0BAA9D;AACA,YAAM,KAAKZ,OAAL,CAAaH,IAAb,EAAN;AACD;AACF;;AAlFqB;;eAqFTO,iB","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":"../.."}
|
package/build/lib/logger.js
CHANGED
|
@@ -7,12 +7,12 @@ exports.default = void 0;
|
|
|
7
7
|
|
|
8
8
|
require("source-map-support/register");
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var _support = require("@appium/support");
|
|
11
11
|
|
|
12
|
-
const log =
|
|
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,
|
|
18
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9sb2dnZXIuanMiXSwibmFtZXMiOlsibG9nIiwibG9nZ2VyIiwiZ2V0TG9nZ2VyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxHQUFHLEdBQUdDLGdCQUFPQyxTQUFQLENBQWlCLGFBQWpCLENBQVo7O2VBRWVGLEciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAYXBwaXVtL3N1cHBvcnQnO1xuXG5jb25zdCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdHZWNrb0RyaXZlcicpO1xuXG5leHBvcnQgZGVmYXVsdCBsb2c7XG4iXSwiZmlsZSI6ImxpYi9sb2dnZXIuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
|
package/build/lib/server.js
CHANGED
|
@@ -11,7 +11,7 @@ require("source-map-support/register");
|
|
|
11
11
|
|
|
12
12
|
var _logger = _interopRequireDefault(require("./logger"));
|
|
13
13
|
|
|
14
|
-
var
|
|
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,
|
|
24
|
-
let server = await (0,
|
|
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,
|
|
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
|
|
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 =
|
|
40
|
-
|
|
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.
|
|
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.
|
|
50
|
-
const button = await driver
|
|
51
|
-
await button.
|
|
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,
|
|
59
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvZnVuY3Rpb25hbC9kZXNrdG9wLWRyaXZlci1lMmUtc3BlY3MuanMiXSwibmFtZXMiOlsiY2hhaSIsInNob3VsZCIsInVzZSIsImNoYWlBc1Byb21pc2VkIiwiQ0FQUyIsImJyb3dzZXJOYW1lIiwicGxhdGZvcm1OYW1lIiwiZGVzY3JpYmUiLCJ0aW1lb3V0IiwiTU9DSEFfVElNRU9VVCIsInNlcnZlciIsImRyaXZlciIsImJlZm9yZSIsIlBPUlQiLCJIT1NUIiwiYWZ0ZXIiLCJjbG9zZSIsImJlZm9yZUVhY2giLCJob3N0bmFtZSIsInBvcnQiLCJjYXBhYmlsaXRpZXMiLCJhZnRlckVhY2giLCJkZWxldGVTZXNzaW9uIiwiaXQiLCJ1cmwiLCJidXR0b24iLCIkIiwiZ2V0VGV4dCIsImV2ZW50dWFsbHkiLCJlcWwiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBQSxjQUFLQyxNQUFMOztBQUNBRCxjQUFLRSxHQUFMLENBQVNDLHVCQUFUOztBQUVBLE1BQU1DLElBQUksR0FBRztBQUNYQyxFQUFBQSxXQUFXLEVBQUUsZ0JBREY7QUFFWEMsRUFBQUEsWUFBWSxFQUFFO0FBRkgsQ0FBYjtBQUtBQyxRQUFRLENBQUMsc0JBQUQsRUFBeUIsWUFBWTtBQUMzQyxPQUFLQyxPQUFMLENBQWFDLG9CQUFiO0FBRUEsTUFBSUMsTUFBSjtBQUNBLE1BQUlDLE1BQUo7QUFDQUMsRUFBQUEsTUFBTSxDQUFDLGtCQUFrQjtBQUN2QkYsSUFBQUEsTUFBTSxHQUFHLE1BQU0sbUJBQVlHLFdBQVosRUFBa0JDLFdBQWxCLENBQWY7QUFDRCxHQUZLLENBQU47QUFHQUMsRUFBQUEsS0FBSyxDQUFDLGtCQUFrQjtBQUN0QixRQUFJTCxNQUFKLEVBQVk7QUFDVixZQUFNQSxNQUFNLENBQUNNLEtBQVAsRUFBTjtBQUNBTixNQUFBQSxNQUFNLEdBQUcsSUFBVDtBQUNEO0FBQ0YsR0FMSSxDQUFMO0FBTUFPLEVBQUFBLFVBQVUsQ0FBQyxrQkFBa0I7QUFDM0JOLElBQUFBLE1BQU0sR0FBRyxNQUFNLHlCQUFPO0FBQ3BCTyxNQUFBQSxRQUFRLEVBQUVKLFdBRFU7QUFFcEJLLE1BQUFBLElBQUksRUFBRU4sV0FGYztBQUdwQk8sTUFBQUEsWUFBWSxFQUFFaEI7QUFITSxLQUFQLENBQWY7QUFLRCxHQU5TLENBQVY7QUFPQWlCLEVBQUFBLFNBQVMsQ0FBQyxrQkFBa0I7QUFDMUIsUUFBSVYsTUFBSixFQUFZO0FBQ1YsWUFBTUEsTUFBTSxDQUFDVyxhQUFQLEVBQU47QUFDQVgsTUFBQUEsTUFBTSxHQUFHLElBQVQ7QUFDRDtBQUNGLEdBTFEsQ0FBVDtBQU9BWSxFQUFBQSxFQUFFLENBQUMsaUNBQUQsRUFBb0Msa0JBQWtCO0FBQ3RELFVBQU1aLE1BQU0sQ0FBQ2EsR0FBUCxDQUFXLG9CQUFYLENBQU47QUFDQSxVQUFNQyxNQUFNLEdBQUcsTUFBTWQsTUFBTSxDQUFDZSxDQUFQLENBQVMsZUFBVCxDQUFyQjtBQUNBLFVBQU1ELE1BQU0sQ0FBQ0UsT0FBUCxHQUFpQjFCLE1BQWpCLENBQXdCMkIsVUFBeEIsQ0FBbUNDLEdBQW5DLENBQXVDLGlCQUF2QyxDQUFOO0FBQ0QsR0FKQyxDQUFGO0FBS0QsQ0FqQ08sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlbW90ZSB9IGZyb20gJ3dlYmRyaXZlcmlvJztcbmltcG9ydCB7IHN0YXJ0U2VydmVyIH0gZnJvbSAnLi4vLi4nO1xuaW1wb3J0IGNoYWlBc1Byb21pc2VkIGZyb20gJ2NoYWktYXMtcHJvbWlzZWQnO1xuaW1wb3J0IGNoYWkgZnJvbSAnY2hhaSc7XG5pbXBvcnQgeyBIT1NULCBQT1JULCBNT0NIQV9USU1FT1VUIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jaGFpLnNob3VsZCgpO1xuY2hhaS51c2UoY2hhaUFzUHJvbWlzZWQpO1xuXG5jb25zdCBDQVBTID0ge1xuICBicm93c2VyTmFtZTogJ01vemlsbGFGaXJlZm94JyxcbiAgcGxhdGZvcm1OYW1lOiAnbGludXgnLFxufTtcblxuZGVzY3JpYmUoJ0Rlc2t0b3AgR2Vja28gRHJpdmVyJywgZnVuY3Rpb24gKCkge1xuICB0aGlzLnRpbWVvdXQoTU9DSEFfVElNRU9VVCk7XG5cbiAgbGV0IHNlcnZlcjtcbiAgbGV0IGRyaXZlcjtcbiAgYmVmb3JlKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBzZXJ2ZXIgPSBhd2FpdCBzdGFydFNlcnZlcihQT1JULCBIT1NUKTtcbiAgfSk7XG4gIGFmdGVyKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBpZiAoc2VydmVyKSB7XG4gICAgICBhd2FpdCBzZXJ2ZXIuY2xvc2UoKTtcbiAgICAgIHNlcnZlciA9IG51bGw7XG4gICAgfVxuICB9KTtcbiAgYmVmb3JlRWFjaChhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgZHJpdmVyID0gYXdhaXQgcmVtb3RlKHtcbiAgICAgIGhvc3RuYW1lOiBIT1NULFxuICAgICAgcG9ydDogUE9SVCxcbiAgICAgIGNhcGFiaWxpdGllczogQ0FQUyxcbiAgICB9KTtcbiAgfSk7XG4gIGFmdGVyRWFjaChhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgaWYgKGRyaXZlcikge1xuICAgICAgYXdhaXQgZHJpdmVyLmRlbGV0ZVNlc3Npb24oKTtcbiAgICAgIGRyaXZlciA9IG51bGw7XG4gICAgfVxuICB9KTtcblxuICBpdCgnc2hvdWxkIHN0YXJ0IGFuZCBzdG9wIGEgc2Vzc2lvbicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBhd2FpdCBkcml2ZXIudXJsKCdodHRwczovL2FwcGl1bS5pby8nKTtcbiAgICBjb25zdCBidXR0b24gPSBhd2FpdCBkcml2ZXIuJCgnI2Rvd25sb2FkTGluaycpO1xuICAgIGF3YWl0IGJ1dHRvbi5nZXRUZXh0KCkuc2hvdWxkLmV2ZW50dWFsbHkuZXFsKCdEb3dubG9hZCBBcHBpdW0nKTtcbiAgfSk7XG59KTtcblxuXG4iXSwiZmlsZSI6InRlc3QvZnVuY3Rpb25hbC9kZXNrdG9wLWRyaXZlci1lMmUtc3BlY3MuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4ifQ==
|