appium-uiautomator2-driver 1.70.1 → 1.74.0

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/README.md CHANGED
@@ -29,7 +29,7 @@ platformName | Could be set to `android`. Appium itself is not strict about this
29
29
  appium:automationName | Must always be set to `uiautomator2`. Values of `automationName` are compared case-insensitively.
30
30
  appium:deviceName | The name of the device under test (actually, it is not used to select a device under test). Consider setting `udid` for real devices and `avd` for emulators instead
31
31
  appium:platformVersion | The platform version of an emulator or a real device. This capability is used for device autodetection if `udid` is not provided
32
- appium:udid | UDID of the device to be tested. Could ve retrieved from `adb devices -l` output. If unset then the driver will try to use the first connected device. Always set this capability if you run parallel tests.
32
+ appium:udid | UDID of the device to be tested. Could be retrieved from `adb devices -l` output. If unset then the driver will try to use the first connected device. Always set this capability if you run parallel tests.
33
33
  appium:noReset | Prevents the device to be reset before the session startup if set to `true`. This means that the application under test is not going to be terminated neither its data cleaned. `false` by default
34
34
  appium:fullReset | Being set to `true` always enforces the application under test to be fully uninstalled before starting a new session. `false` by default
35
35
  appium:printPageSourceOnFindFailure | Enforces the server to dump the actual XML page source into the log if any error happens. `false` by default.
@@ -161,6 +161,7 @@ appium:extractChromeAndroidPackageFromContextName | If set to `true`, tell chrom
161
161
  appium:showChromedriverLog | If set to `true` then all the output from chromedriver binary will be forwarded to the Appium server log. `false` by default.
162
162
  pageLoadStrategy | One of the available page load strategies. See https://www.w3.org/TR/webdriver/#capabilities
163
163
  appium:chromeOptions | A mapping, that allows to customize chromedriver options. See https://chromedriver.chromium.org/capabilities for the list of available entries.
164
+ appium:chromeLoggingPrefs | Chrome logging preferences mapping. Basically the same as [goog:loggingPrefs](https://newbedev.com/getting-console-log-output-from-chrome-with-selenium-python-api-bindings). It is set to `{"browser": "ALL"}` by default.
164
165
 
165
166
  ### Other
166
167
 
@@ -209,7 +210,7 @@ Name | Description | Example
209
210
  id | This strategy is mapped to the native UiAutomator's `By.res` [locator](https://developer.android.com/reference/androidx/test/uiautomator/BySelector#res(java.lang.String)) (exact match of element's resource name). Package identifier prefix is added automatically if unset and is equal to the identifier of the current application under test. | 'com.mycompany:id/resourceId'
210
211
  accessibilityId | This strategy is mapped to the native UiAutomator's `By.desc` [locator](https://developer.android.com/reference/androidx/test/uiautomator/BySelector#desc(java.lang.String)) (exact match of element's content description). | 'my description'
211
212
  className | This strategy is mapped to the native UiAutomator's `By.clazz` [locator](https://developer.android.com/reference/androidx/test/uiautomator/BySelector#clazz(java.lang.String)) (exact match of element's class). | 'android.view.View'
212
- android uiautomator | This strategy is mapped to the native UiAutomator's `UiSelector` [locator](https://developer.android.com/reference/androidx/test/uiautomator/UiSelector)). It is even possible to perform some advanced operations, like scrolling, with this locator type | `new UiScrollable(new UiSelector().resourceId(\"android:id/list\")).scrollIntoView(new UiSelector().text(\"Radio Group\"))`
213
+ `-android uiautomator` | This strategy is mapped to the native UiAutomator's `UiSelector` [locator](https://developer.android.com/reference/androidx/test/uiautomator/UiSelector)). It is even possible to perform some advanced operations, like scrolling, with this locator type | `new UiScrollable(new UiSelector().resourceId(\"android:id/list\")).scrollIntoView(new UiSelector().text(\"Radio Group\"))`
213
214
  xpath | For elements lookup Xpath strategy the driver uses the same XML tree that is generated by page source API. Only Xpath 1.0 is supported for appium-uiatomator2-server versions below 4.25.0. All server versions starting from 4.25.0 support both Xpath 1.0 and 2.0 | `By.xpath("//android.view.View[@text=\"Regular\" and @checkable=\"true\"]")`
214
215
 
215
216
 
@@ -316,6 +317,7 @@ UiAutomator2 provides several extensions that allow to automate popular mobile g
316
317
  - mobile: dragGesture
317
318
  - mobile: flingGesture
318
319
  - mobile: doubleClickGesture
320
+ - mobile: clickGesture
319
321
  - mobile: longClickGesture
320
322
  - mobile: pinchCloseGesture
321
323
  - mobile: pinchOpenGesture
@@ -562,14 +564,15 @@ text | string | yes | The text to type | testing
562
564
 
563
565
  ### mobile: sensorSet
564
566
 
565
- Emulate sensors values on the connected emulator.
567
+ Emulate changing of sensor values on the connected emulator.
568
+ This extension does not work on real devices.
566
569
 
567
570
  #### Arguments
568
571
 
569
572
  Name | Type | Required | Description | Example
570
573
  --- | --- | --- | --- | ---
571
- sensorType | string | yes | Supported sensor types are: `acceleration`, `light`, `proximity`, `temperature`, `pressure` and `humidity` | light
572
- value | string | yes | value to set to the sensor | 50
574
+ sensorType | string | yes | The set of all supported sensor types could be found in [adb-emu-commands.js](https://github.com/appium/appium-adb/blob/master/lib/tools/adb-emu-commands.js) (look for *SENSORS* object values). Check the output of `sensor status` command in the [emulator console](https://developer.android.com/studio/run/emulator-console) to see more details on the available sensor types | light
575
+ value | string | yes | Check the output of `sensor get <sensorType>` command in the [emulator console](https://developer.android.com/studio/run/emulator-console) to see the acceptable value format for the given sensor type | 50
573
576
 
574
577
  ### mobile: deleteFile
575
578
 
@@ -759,6 +762,24 @@ type | string | yes | The unlock type. See the documentation on [appium:unlockTy
759
762
  strategy | string | no | Unlock strategy. See the documentation on [appium:unlockStrategy](#device-locking) capability for more details | uiautomator
760
763
  timeoutMs | number | no | Unlock timeout. See the documentation on [appium:unlockSuccessTimeout](#device-locking) capability for more details | 5000
761
764
 
765
+ ### mobile: refreshGpsCache
766
+
767
+ Sends a request to refresh the GPS cache on the device under test.
768
+ By default the location tracking is configured for
769
+ [low battery consumption](https://github.com/appium/io.appium.settings/blob/master/app/src/main/java/io/appium/settings/LocationTracker.java),
770
+ so you might need to call this extension periodically to get the updated geo
771
+ location if the actual (or mocked) device location is changed too frequently.
772
+ The feature only works if the device under test has Google Play Services installed.
773
+ In case the vanilla
774
+ [LocationManager](https://developer.android.com/reference/android/location/LocationManager)
775
+ is used the device API level must be at version 30 (Android R) or higher.
776
+
777
+ #### Arguments
778
+
779
+ Name | Type | Required | Description | Example
780
+ --- | --- | --- | --- | ---
781
+ timeoutMs | number | no | The maximum number of milliseconds to block until GPS cache is refreshed. If the API call does not receive a confirmation about successful cache refresh within this timeout then an error is thrown. Providing zero or a negative value to it skips waiting completely and does not check for any errors. 20000 ms by default. | 60000
782
+
762
783
  ## Applications Management
763
784
 
764
785
  UiAutomator2 driver supports Appium endpoints for applications management:
@@ -11,8 +11,7 @@ require("source-map-support/register");
11
11
 
12
12
  var _cssConverter = _interopRequireDefault(require("../css-converter"));
13
13
 
14
- let helpers = {},
15
- extensions = {};
14
+ const helpers = {};
16
15
  exports.helpers = helpers;
17
16
  const MAGIC_FIRST_VIS_CHILD_SEL = /\/\*\[@firstVisible ?= ?('|")true\1\]/;
18
17
  const MAGIC_SCROLLABLE_SEL = /\/\/\*\[@scrollable ?= ?('|")true\1\]/;
@@ -31,19 +30,14 @@ helpers.doFindElementOrEls = async function (params) {
31
30
 
32
31
  if (params.strategy === 'css selector') {
33
32
  params.strategy = '-android uiautomator';
34
- params.selector = _cssConverter.default.toUiAutomatorSelector(params.selector);
33
+ params.selector = new _cssConverter.default(params.selector, this.opts.appPackage).toUiAutomatorSelector();
35
34
  }
36
35
 
37
- if (params.multiple) {
38
- return await this.uiautomator2.jwproxy.command(`/elements`, 'POST', params);
39
- } else {
40
- return await this.uiautomator2.jwproxy.command(`/element`, 'POST', params);
41
- }
36
+ return await this.uiautomator2.jwproxy.command(`/element${params.multiple ? 's' : ''}`, 'POST', params);
42
37
  };
43
38
 
44
- Object.assign(extensions, helpers);
45
- var _default = extensions;
39
+ var _default = helpers;
46
40
  exports.default = _default;require('source-map-support').install();
47
41
 
48
42
 
49
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9maW5kLmpzIl0sIm5hbWVzIjpbImhlbHBlcnMiLCJleHRlbnNpb25zIiwiTUFHSUNfRklSU1RfVklTX0NISUxEX1NFTCIsIk1BR0lDX1NDUk9MTEFCTEVfU0VMIiwiTUFHSUNfU0NST0xMQUJMRV9CWSIsImRvRmluZEVsZW1lbnRPckVscyIsInBhcmFtcyIsInN0cmF0ZWd5IiwidGVzdCIsInNlbGVjdG9yIiwiZWxlbWVudElkIiwiY29udGV4dCIsInVpYXV0b21hdG9yMiIsImp3cHJveHkiLCJjb21tYW5kIiwiQ3NzQ29udmVydGVyIiwidG9VaUF1dG9tYXRvclNlbGVjdG9yIiwibXVsdGlwbGUiLCJPYmplY3QiLCJhc3NpZ24iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBRUEsSUFBSUEsT0FBTyxHQUFHLEVBQWQ7QUFBQSxJQUFrQkMsVUFBVSxHQUFHLEVBQS9COztBQUlBLE1BQU1DLHlCQUF5QixHQUFHLHVDQUFsQztBQUVBLE1BQU1DLG9CQUFvQixHQUFHLHVDQUE3QjtBQUNBLE1BQU1DLG1CQUFtQixHQUFHLG1DQUE1Qjs7QUFNQUosT0FBTyxDQUFDSyxrQkFBUixHQUE2QixnQkFBZ0JDLE1BQWhCLEVBQXdCO0FBQ25ELE1BQUlBLE1BQU0sQ0FBQ0MsUUFBUCxLQUFvQixPQUFwQixJQUErQkwseUJBQXlCLENBQUNNLElBQTFCLENBQStCRixNQUFNLENBQUNHLFFBQXRDLENBQW5DLEVBQW9GO0FBQ2xGLFFBQUlDLFNBQVMsR0FBR0osTUFBTSxDQUFDSyxPQUF2QjtBQUNBLFdBQU8sTUFBTSxLQUFLQyxZQUFMLENBQWtCQyxPQUFsQixDQUEwQkMsT0FBMUIsQ0FBbUMsbUJBQWtCSixTQUFVLGdCQUEvRCxFQUFnRixLQUFoRixFQUF1RixFQUF2RixDQUFiO0FBQ0Q7O0FBQ0QsTUFBSUosTUFBTSxDQUFDQyxRQUFQLEtBQW9CLE9BQXBCLElBQStCSixvQkFBb0IsQ0FBQ0ssSUFBckIsQ0FBMEJGLE1BQU0sQ0FBQ0csUUFBakMsQ0FBbkMsRUFBK0U7QUFDN0VILElBQUFBLE1BQU0sQ0FBQ0MsUUFBUCxHQUFrQixzQkFBbEI7QUFDQUQsSUFBQUEsTUFBTSxDQUFDRyxRQUFQLEdBQWtCTCxtQkFBbEI7QUFDRDs7QUFDRCxNQUFJRSxNQUFNLENBQUNDLFFBQVAsS0FBb0IsY0FBeEIsRUFBd0M7QUFDdENELElBQUFBLE1BQU0sQ0FBQ0MsUUFBUCxHQUFrQixzQkFBbEI7QUFDQUQsSUFBQUEsTUFBTSxDQUFDRyxRQUFQLEdBQWtCTSxzQkFBYUMscUJBQWIsQ0FBbUNWLE1BQU0sQ0FBQ0csUUFBMUMsQ0FBbEI7QUFDRDs7QUFDRCxNQUFJSCxNQUFNLENBQUNXLFFBQVgsRUFBcUI7QUFDbkIsV0FBTyxNQUFNLEtBQUtMLFlBQUwsQ0FBa0JDLE9BQWxCLENBQTBCQyxPQUExQixDQUFtQyxXQUFuQyxFQUErQyxNQUEvQyxFQUF1RFIsTUFBdkQsQ0FBYjtBQUNELEdBRkQsTUFFTztBQUNMLFdBQU8sTUFBTSxLQUFLTSxZQUFMLENBQWtCQyxPQUFsQixDQUEwQkMsT0FBMUIsQ0FBbUMsVUFBbkMsRUFBOEMsTUFBOUMsRUFBc0RSLE1BQXRELENBQWI7QUFDRDtBQUNGLENBbEJEOztBQW9CQVksTUFBTSxDQUFDQyxNQUFQLENBQWNsQixVQUFkLEVBQTBCRCxPQUExQjtlQUVlQyxVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENzc0NvbnZlcnRlciBmcm9tICcuLi9jc3MtY29udmVydGVyJztcblxubGV0IGhlbHBlcnMgPSB7fSwgZXh0ZW5zaW9ucyA9IHt9O1xuXG4vLyB3ZSBvdmVycmlkZSB0aGUgeHBhdGggc2VhcmNoIGZvciB0aGlzIGZpcnN0LXZpc2libGUtY2hpbGQgc2VsZWN0b3IsIHdoaWNoXG4vLyBsb29rcyBsaWtlIC8qW0BmaXJzdFZpc2libGU9XCJ0cnVlXCJdXG5jb25zdCBNQUdJQ19GSVJTVF9WSVNfQ0hJTERfU0VMID0gL1xcL1xcKlxcW0BmaXJzdFZpc2libGUgPz0gPygnfFwiKXRydWVcXDFcXF0vO1xuXG5jb25zdCBNQUdJQ19TQ1JPTExBQkxFX1NFTCA9IC9cXC9cXC9cXCpcXFtAc2Nyb2xsYWJsZSA/PSA/KCd8XCIpdHJ1ZVxcMVxcXS87XG5jb25zdCBNQUdJQ19TQ1JPTExBQkxFX0JZID0gJ25ldyBVaVNlbGVjdG9yKCkuc2Nyb2xsYWJsZSh0cnVlKSc7XG5cbi8qKlxuICogT3ZlcnJpZGluZyBoZWxwZXJzLmRvRmluZEVsZW1lbnRPckVscyBmdW5jdGlvbmFsaXR5IG9mIGFwcGl1bS1hbmRyb2lkLWRyaXZlcixcbiAqIHRoaXMuZWxlbWVudCBpbml0aWFsaXplZCBpbiBmaW5kLmpzIG9mIGFwcGl1bS1hbmRyb2lkLWRyaXZlLlxuICovXG5oZWxwZXJzLmRvRmluZEVsZW1lbnRPckVscyA9IGFzeW5jIGZ1bmN0aW9uIChwYXJhbXMpIHtcbiAgaWYgKHBhcmFtcy5zdHJhdGVneSA9PT0gJ3hwYXRoJyAmJiBNQUdJQ19GSVJTVF9WSVNfQ0hJTERfU0VMLnRlc3QocGFyYW1zLnNlbGVjdG9yKSkge1xuICAgIGxldCBlbGVtZW50SWQgPSBwYXJhbXMuY29udGV4dDtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy51aWF1dG9tYXRvcjIuandwcm94eS5jb21tYW5kKGAvYXBwaXVtL2VsZW1lbnQvJHtlbGVtZW50SWR9L2ZpcnN0X3Zpc2libGVgLCAnR0VUJywge30pO1xuICB9XG4gIGlmIChwYXJhbXMuc3RyYXRlZ3kgPT09ICd4cGF0aCcgJiYgTUFHSUNfU0NST0xMQUJMRV9TRUwudGVzdChwYXJhbXMuc2VsZWN0b3IpKSB7XG4gICAgcGFyYW1zLnN0cmF0ZWd5ID0gJy1hbmRyb2lkIHVpYXV0b21hdG9yJztcbiAgICBwYXJhbXMuc2VsZWN0b3IgPSBNQUdJQ19TQ1JPTExBQkxFX0JZO1xuICB9XG4gIGlmIChwYXJhbXMuc3RyYXRlZ3kgPT09ICdjc3Mgc2VsZWN0b3InKSB7XG4gICAgcGFyYW1zLnN0cmF0ZWd5ID0gJy1hbmRyb2lkIHVpYXV0b21hdG9yJztcbiAgICBwYXJhbXMuc2VsZWN0b3IgPSBDc3NDb252ZXJ0ZXIudG9VaUF1dG9tYXRvclNlbGVjdG9yKHBhcmFtcy5zZWxlY3Rvcik7XG4gIH1cbiAgaWYgKHBhcmFtcy5tdWx0aXBsZSkge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLnVpYXV0b21hdG9yMi5qd3Byb3h5LmNvbW1hbmQoYC9lbGVtZW50c2AsICdQT1NUJywgcGFyYW1zKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy51aWF1dG9tYXRvcjIuandwcm94eS5jb21tYW5kKGAvZWxlbWVudGAsICdQT1NUJywgcGFyYW1zKTtcbiAgfVxufTtcblxuT2JqZWN0LmFzc2lnbihleHRlbnNpb25zLCBoZWxwZXJzKTtcbmV4cG9ydCB7IGhlbHBlcnMgfTtcbmV4cG9ydCBkZWZhdWx0IGV4dGVuc2lvbnM7XG4iXSwiZmlsZSI6ImxpYi9jb21tYW5kcy9maW5kLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uIn0=
43
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9maW5kLmpzIl0sIm5hbWVzIjpbImhlbHBlcnMiLCJNQUdJQ19GSVJTVF9WSVNfQ0hJTERfU0VMIiwiTUFHSUNfU0NST0xMQUJMRV9TRUwiLCJNQUdJQ19TQ1JPTExBQkxFX0JZIiwiZG9GaW5kRWxlbWVudE9yRWxzIiwicGFyYW1zIiwic3RyYXRlZ3kiLCJ0ZXN0Iiwic2VsZWN0b3IiLCJlbGVtZW50SWQiLCJjb250ZXh0IiwidWlhdXRvbWF0b3IyIiwiandwcm94eSIsImNvbW1hbmQiLCJDc3NDb252ZXJ0ZXIiLCJvcHRzIiwiYXBwUGFja2FnZSIsInRvVWlBdXRvbWF0b3JTZWxlY3RvciIsIm11bHRpcGxlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBOztBQUVBLE1BQU1BLE9BQU8sR0FBRyxFQUFoQjs7QUFJQSxNQUFNQyx5QkFBeUIsR0FBRyx1Q0FBbEM7QUFFQSxNQUFNQyxvQkFBb0IsR0FBRyx1Q0FBN0I7QUFDQSxNQUFNQyxtQkFBbUIsR0FBRyxtQ0FBNUI7O0FBTUFILE9BQU8sQ0FBQ0ksa0JBQVIsR0FBNkIsZ0JBQWdCQyxNQUFoQixFQUF3QjtBQUNuRCxNQUFJQSxNQUFNLENBQUNDLFFBQVAsS0FBb0IsT0FBcEIsSUFBK0JMLHlCQUF5QixDQUFDTSxJQUExQixDQUErQkYsTUFBTSxDQUFDRyxRQUF0QyxDQUFuQyxFQUFvRjtBQUNsRixRQUFJQyxTQUFTLEdBQUdKLE1BQU0sQ0FBQ0ssT0FBdkI7QUFDQSxXQUFPLE1BQU0sS0FBS0MsWUFBTCxDQUFrQkMsT0FBbEIsQ0FBMEJDLE9BQTFCLENBQW1DLG1CQUFrQkosU0FBVSxnQkFBL0QsRUFBZ0YsS0FBaEYsRUFBdUYsRUFBdkYsQ0FBYjtBQUNEOztBQUNELE1BQUlKLE1BQU0sQ0FBQ0MsUUFBUCxLQUFvQixPQUFwQixJQUErQkosb0JBQW9CLENBQUNLLElBQXJCLENBQTBCRixNQUFNLENBQUNHLFFBQWpDLENBQW5DLEVBQStFO0FBQzdFSCxJQUFBQSxNQUFNLENBQUNDLFFBQVAsR0FBa0Isc0JBQWxCO0FBQ0FELElBQUFBLE1BQU0sQ0FBQ0csUUFBUCxHQUFrQkwsbUJBQWxCO0FBQ0Q7O0FBQ0QsTUFBSUUsTUFBTSxDQUFDQyxRQUFQLEtBQW9CLGNBQXhCLEVBQXdDO0FBQ3RDRCxJQUFBQSxNQUFNLENBQUNDLFFBQVAsR0FBa0Isc0JBQWxCO0FBQ0FELElBQUFBLE1BQU0sQ0FBQ0csUUFBUCxHQUFrQixJQUFJTSxxQkFBSixDQUFpQlQsTUFBTSxDQUFDRyxRQUF4QixFQUFrQyxLQUFLTyxJQUFMLENBQVVDLFVBQTVDLEVBQ2ZDLHFCQURlLEVBQWxCO0FBRUQ7O0FBQ0QsU0FBTyxNQUFNLEtBQUtOLFlBQUwsQ0FBa0JDLE9BQWxCLENBQTBCQyxPQUExQixDQUFtQyxXQUFVUixNQUFNLENBQUNhLFFBQVAsR0FBa0IsR0FBbEIsR0FBd0IsRUFBRyxFQUF4RSxFQUEyRSxNQUEzRSxFQUFtRmIsTUFBbkYsQ0FBYjtBQUNELENBZkQ7O2VBa0JlTCxPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENzc0NvbnZlcnRlciBmcm9tICcuLi9jc3MtY29udmVydGVyJztcblxuY29uc3QgaGVscGVycyA9IHt9O1xuXG4vLyB3ZSBvdmVycmlkZSB0aGUgeHBhdGggc2VhcmNoIGZvciB0aGlzIGZpcnN0LXZpc2libGUtY2hpbGQgc2VsZWN0b3IsIHdoaWNoXG4vLyBsb29rcyBsaWtlIC8qW0BmaXJzdFZpc2libGU9XCJ0cnVlXCJdXG5jb25zdCBNQUdJQ19GSVJTVF9WSVNfQ0hJTERfU0VMID0gL1xcL1xcKlxcW0BmaXJzdFZpc2libGUgPz0gPygnfFwiKXRydWVcXDFcXF0vO1xuXG5jb25zdCBNQUdJQ19TQ1JPTExBQkxFX1NFTCA9IC9cXC9cXC9cXCpcXFtAc2Nyb2xsYWJsZSA/PSA/KCd8XCIpdHJ1ZVxcMVxcXS87XG5jb25zdCBNQUdJQ19TQ1JPTExBQkxFX0JZID0gJ25ldyBVaVNlbGVjdG9yKCkuc2Nyb2xsYWJsZSh0cnVlKSc7XG5cbi8qKlxuICogT3ZlcnJpZGluZyBoZWxwZXJzLmRvRmluZEVsZW1lbnRPckVscyBmdW5jdGlvbmFsaXR5IG9mIGFwcGl1bS1hbmRyb2lkLWRyaXZlcixcbiAqIHRoaXMuZWxlbWVudCBpbml0aWFsaXplZCBpbiBmaW5kLmpzIG9mIGFwcGl1bS1hbmRyb2lkLWRyaXZlLlxuICovXG5oZWxwZXJzLmRvRmluZEVsZW1lbnRPckVscyA9IGFzeW5jIGZ1bmN0aW9uIChwYXJhbXMpIHtcbiAgaWYgKHBhcmFtcy5zdHJhdGVneSA9PT0gJ3hwYXRoJyAmJiBNQUdJQ19GSVJTVF9WSVNfQ0hJTERfU0VMLnRlc3QocGFyYW1zLnNlbGVjdG9yKSkge1xuICAgIGxldCBlbGVtZW50SWQgPSBwYXJhbXMuY29udGV4dDtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy51aWF1dG9tYXRvcjIuandwcm94eS5jb21tYW5kKGAvYXBwaXVtL2VsZW1lbnQvJHtlbGVtZW50SWR9L2ZpcnN0X3Zpc2libGVgLCAnR0VUJywge30pO1xuICB9XG4gIGlmIChwYXJhbXMuc3RyYXRlZ3kgPT09ICd4cGF0aCcgJiYgTUFHSUNfU0NST0xMQUJMRV9TRUwudGVzdChwYXJhbXMuc2VsZWN0b3IpKSB7XG4gICAgcGFyYW1zLnN0cmF0ZWd5ID0gJy1hbmRyb2lkIHVpYXV0b21hdG9yJztcbiAgICBwYXJhbXMuc2VsZWN0b3IgPSBNQUdJQ19TQ1JPTExBQkxFX0JZO1xuICB9XG4gIGlmIChwYXJhbXMuc3RyYXRlZ3kgPT09ICdjc3Mgc2VsZWN0b3InKSB7XG4gICAgcGFyYW1zLnN0cmF0ZWd5ID0gJy1hbmRyb2lkIHVpYXV0b21hdG9yJztcbiAgICBwYXJhbXMuc2VsZWN0b3IgPSBuZXcgQ3NzQ29udmVydGVyKHBhcmFtcy5zZWxlY3RvciwgdGhpcy5vcHRzLmFwcFBhY2thZ2UpXG4gICAgICAudG9VaUF1dG9tYXRvclNlbGVjdG9yKCk7XG4gIH1cbiAgcmV0dXJuIGF3YWl0IHRoaXMudWlhdXRvbWF0b3IyLmp3cHJveHkuY29tbWFuZChgL2VsZW1lbnQke3BhcmFtcy5tdWx0aXBsZSA/ICdzJyA6ICcnfWAsICdQT1NUJywgcGFyYW1zKTtcbn07XG5cbmV4cG9ydCB7IGhlbHBlcnMgfTtcbmV4cG9ydCBkZWZhdWx0IGhlbHBlcnM7XG4iXSwiZmlsZSI6ImxpYi9jb21tYW5kcy9maW5kLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uIn0=
@@ -130,6 +130,7 @@ extensions.executeMobile = async function (mobileCommand, opts = {}) {
130
130
  dragGesture: 'mobileDragGesture',
131
131
  flingGesture: 'mobileFlingGesture',
132
132
  doubleClickGesture: 'mobileDoubleClickGesture',
133
+ clickGesture: 'mobileClickGesture',
133
134
  longClickGesture: 'mobileLongClickGesture',
134
135
  pinchCloseGesture: 'mobilePinchCloseGesture',
135
136
  pinchOpenGesture: 'mobilePinchOpenGesture',
@@ -164,7 +165,8 @@ extensions.executeMobile = async function (mobileCommand, opts = {}) {
164
165
  broadcast: 'mobileBroadcast',
165
166
  getContexts: 'mobileGetContexts',
166
167
  installMultipleApks: 'mobileInstallMultipleApks',
167
- unlock: 'mobileUnlock'
168
+ unlock: 'mobileUnlock',
169
+ refreshGpsCache: 'mobileRefreshGpsCache'
168
170
  };
169
171
 
170
172
  if (!_lodash.default.has(mobileCommandsMapping, mobileCommand)) {
@@ -243,6 +245,7 @@ helpers.wrapBootstrapDisconnect = async function (wrapped) {
243
245
  helpers.suspendChromedriverProxy = function () {
244
246
  this.chromedriver = null;
245
247
  this.proxyReqRes = this.uiautomator2.proxyReqRes.bind(this.uiautomator2);
248
+ this.proxyCommand = this.uiautomator2.proxyCommand.bind(this.uiautomator2);
246
249
  this.jwpProxyActive = true;
247
250
  };
248
251
 
@@ -276,4 +279,4 @@ var _default = extensions;
276
279
  exports.default = _default;require('source-map-support').install();
277
280
 
278
281
 
279
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/general.js"],"names":["extensions","commands","helpers","getPageSource","uiautomator2","jwproxy","command","getClipboard","adb","getApiLevel","doSendKeys","params","keyevent","keycode","metastate","log","debug","back","getStrings","language","getDeviceLanguage","info","preprocessStringsMap","mapping","result","key","value","_","toPairs","isString","JSON","stringify","apkStrings","opts","app","appPackage","errorAndThrow","tmpRoot","tempDir","openDir","pullApk","err","message","fs","exists","extractStringsFromApk","rimraf","getDisplayDensity","getWindowSize","getWindowRect","width","height","x","y","executeMobile","mobileCommand","mobileCommandsMapping","shell","execEmuConsoleCommand","dragGesture","flingGesture","doubleClickGesture","longClickGesture","pinchCloseGesture","pinchOpenGesture","swipeGesture","scrollGesture","scrollBackTo","scroll","viewportScreenshot","viewportRect","deepLink","startLogsBroadcast","stopLogsBroadcast","acceptAlert","dismissAlert","batteryInfo","deviceInfo","getDeviceTime","changePermissions","getPermissions","performEditorAction","startScreenStreaming","stopScreenStreaming","getNotifications","listSms","type","sensorSet","deleteFile","clearApp","startActivity","startService","stopService","broadcast","getContexts","installMultipleApks","unlock","has","errors","UnknownCommandError","keys","mobileViewportScreenshot","getViewportScreenshot","mobileViewPortRect","getViewPortRect","setUrl","url","startUri","mobileDeepLink","package","pkg","waitForLaunch","openNotifications","updateSettings","settings","driverOnlySettings","serverSettings","setting","BASEDRIVER_HANDLED_SETTINGS","includes","isEmpty","update","getSettings","wrapBootstrapDisconnect","wrapped","suspendChromedriverProxy","chromedriver","proxyReqRes","bind","jwpProxyActive","mobileGetDeviceInfo","mobileType","text","isUndefined","typeUnicode","mobileInstallMultipleApks","isArray","apks","InvalidArgumentError","B","all","map","configureApp","APK_EXTENSION","options","Object","assign"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport log from '../logger';\nimport B from 'bluebird';\nimport { errors, BASEDRIVER_HANDLED_SETTINGS } from 'appium-base-driver';\nimport { fs, tempDir } from 'appium-support';\nimport { APK_EXTENSION } from '../extensions';\n\nlet extensions = {},\n    commands = {},\n    helpers = {};\n\ncommands.getPageSource = async function () {\n  return await this.uiautomator2.jwproxy.command('/source', 'GET', {});\n};\n\ncommands.getClipboard = async function () {\n  return (await this.adb.getApiLevel() < 29)\n    ? (await this.uiautomator2.jwproxy.command('/appium/device/get_clipboard', 'POST', {}))\n    : (await this.adb.getClipboard());\n};\n\n// Need to override this for correct unicode support\ncommands.doSendKeys = async function (params) {\n  await this.uiautomator2.jwproxy.command('/keys', 'POST', params);\n};\n\n// uiautomator2 doesn't support metastate for keyevents\ncommands.keyevent = async function (keycode, metastate) {\n  log.debug(`Ignoring metastate ${metastate}`);\n  await this.adb.keyevent(keycode);\n};\n\n// Use ADB since we don't have UiAutomator\ncommands.back = async function () {\n  await this.adb.keyevent(4);\n};\n\ncommands.getStrings = async function (language) {\n  if (!language) {\n    language = await this.adb.getDeviceLanguage();\n    log.info(`No language specified, returning strings for: ${language}`);\n  }\n\n  // Clients require the resulting mapping to have both keys\n  // and values of type string\n  const preprocessStringsMap = function (mapping) {\n    const result = {};\n    for (const [key, value] of _.toPairs(mapping)) {\n      result[key] = _.isString(value) ? value : JSON.stringify(value);\n    }\n    return result;\n  };\n\n  if (this.apkStrings[language]) {\n    // Return cached strings\n    return preprocessStringsMap(this.apkStrings[language]);\n  }\n\n  if (!this.opts.app && !this.opts.appPackage) {\n    log.errorAndThrow(\"One of 'app' or 'appPackage' capabilities should must be specified\");\n  }\n\n  let app = this.opts.app;\n  const tmpRoot = await tempDir.openDir();\n  try {\n    if (!app) {\n      try {\n        app = await this.adb.pullApk(this.opts.appPackage, tmpRoot);\n      } catch (err) {\n        log.errorAndThrow(`Failed to pull an apk from '${this.opts.appPackage}'. Original error: ${err.message}`);\n      }\n    }\n\n    if (!await fs.exists(app)) {\n      log.errorAndThrow(`The app at '${app}' does not exist`);\n    }\n\n    try {\n      const {apkStrings} = await this.adb.extractStringsFromApk(app, language, tmpRoot);\n      this.apkStrings[language] = apkStrings;\n      return preprocessStringsMap(apkStrings);\n    } catch (err) {\n      log.errorAndThrow(`Cannot extract strings from '${app}'. Original error: ${err.message}`);\n    }\n  } finally {\n    await fs.rimraf(tmpRoot);\n  }\n};\n\ncommands.getDisplayDensity = async function getDisplayDensity () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/display_density', 'GET', {});\n};\n\n// memoized in constructor\ncommands.getWindowSize = async function () {\n  return await this.uiautomator2.jwproxy.command('/window/current/size', 'GET', {});\n};\n\n// For W3C\ncommands.getWindowRect = async function () {\n  const {width, height} = await this.getWindowSize();\n  return {\n    width,\n    height,\n    x: 0,\n    y: 0,\n  };\n};\n\nextensions.executeMobile = async function (mobileCommand, opts = {}) {\n  const mobileCommandsMapping = {\n    shell: 'mobileShell',\n\n    execEmuConsoleCommand: 'mobileExecEmuConsoleCommand',\n\n    dragGesture: 'mobileDragGesture',\n    flingGesture: 'mobileFlingGesture',\n    doubleClickGesture: 'mobileDoubleClickGesture',\n    longClickGesture: 'mobileLongClickGesture',\n    pinchCloseGesture: 'mobilePinchCloseGesture',\n    pinchOpenGesture: 'mobilePinchOpenGesture',\n    swipeGesture: 'mobileSwipeGesture',\n    scrollGesture: 'mobileScrollGesture',\n    scrollBackTo: 'mobileScrollBackTo',\n    scroll: 'mobileScroll',\n    viewportScreenshot: 'mobileViewportScreenshot',\n    viewportRect: 'mobileViewPortRect',\n\n    deepLink: 'mobileDeepLink',\n\n    startLogsBroadcast: 'mobileStartLogsBroadcast',\n    stopLogsBroadcast: 'mobileStopLogsBroadcast',\n\n    acceptAlert: 'mobileAcceptAlert',\n    dismissAlert: 'mobileDismissAlert',\n\n    batteryInfo: 'mobileGetBatteryInfo',\n\n    deviceInfo: 'mobileGetDeviceInfo',\n\n    getDeviceTime: 'mobileGetDeviceTime',\n\n    changePermissions: 'mobileChangePermissions',\n    getPermissions: 'mobileGetPermissions',\n\n    performEditorAction: 'mobilePerformEditorAction',\n\n    startScreenStreaming: 'mobileStartScreenStreaming',\n    stopScreenStreaming: 'mobileStopScreenStreaming',\n\n    getNotifications: 'mobileGetNotifications',\n\n    listSms: 'mobileListSms',\n\n    type: 'mobileType',\n    sensorSet: 'sensorSet',\n\n    deleteFile: 'mobileDeleteFile',\n\n    clearApp: 'mobileClearApp',\n\n    startActivity: 'mobileStartActivity',\n    startService: 'mobileStartService',\n    stopService: 'mobileStopService',\n    broadcast: 'mobileBroadcast',\n\n    getContexts: 'mobileGetContexts',\n\n    installMultipleApks: 'mobileInstallMultipleApks',\n\n    unlock: 'mobileUnlock',\n  };\n\n  if (!_.has(mobileCommandsMapping, mobileCommand)) {\n    throw new errors.UnknownCommandError(`Unknown mobile command \"${mobileCommand}\". ` +\n      `Only ${_.keys(mobileCommandsMapping)} commands are supported.`);\n  }\n  return await this[mobileCommandsMapping[mobileCommand]](opts);\n};\n\ncommands.mobileViewportScreenshot = async function () {\n  return await this.getViewportScreenshot();\n};\n\n/**\n * @typedef {object} Rectangle\n * @property {number} left - The left coordinate of the Rectangle.\n * @property {number} top - The top coordinate of the Rectangle.\n * @property {number} width - The width of Rectangle.\n * @property {number} height - The height of Rectangle.\n */\n\n/**\n * Returns the viewport coordinates.\n * @returns {Rectangle} The viewport coordinates.\n */\ncommands.mobileViewPortRect = async function mobileViewPortRect () {\n  return await this.getViewPortRect();\n};\n\ncommands.setUrl = async function (url) {\n  await this.adb.startUri(url, this.opts.appPackage);\n};\n\n/**\n * @typedef {object} DeepLinkOpts\n * @property {!string} url - The name of URL to start.\n * @property {!string} package - The name of the package to start the URI with.\n * @property {?boolean} waitForLaunch [true] - if `false` then adb won't wait\n * for the started activity to return the control\n */\n\n/**\n * Start URL that take users directly to specific content in the app\n * @param {DeepLinkOpts} opts\n */\ncommands.mobileDeepLink = async function (opts = {}) {\n  const {\n    url,\n    package: pkg,\n    waitForLaunch,\n  } = opts;\n  return await this.adb.startUri(url, pkg, { waitForLaunch });\n};\n\ncommands.openNotifications = async function () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/open_notifications', 'POST', {});\n};\n\ncommands.updateSettings = async function (settings) {\n  // we have some settings that are set on the settings object in the driver\n  // only, for example image finding settings. The uiauto2 server does not know\n  // what to do with them, so just set them on this driver's settings instance,\n  // and don't forward them to the server\n  let driverOnlySettings = {};\n  let serverSettings = {};\n  for (let [setting, value] of _.toPairs(settings)) {\n    if (BASEDRIVER_HANDLED_SETTINGS.includes(setting)) {\n      driverOnlySettings[setting] = value;\n    } else {\n      serverSettings[setting] = value;\n    }\n  }\n  if (!_.isEmpty(driverOnlySettings)) {\n    log.info(`Found some settings designed to be handled by BaseDriver: ` +\n             `${JSON.stringify(_.keys(driverOnlySettings))}. Not ` +\n             `sending these on to the UiAutomator2 server and instead ` +\n             `setting directly on the driver`);\n    await this.settings.update(driverOnlySettings);\n  }\n  if (!_.isEmpty(serverSettings)) {\n    log.info('Forwarding the following settings to the UiAutomator2 server: ' +\n             JSON.stringify(_.keys(serverSettings)));\n    await this.uiautomator2.jwproxy.command('/appium/settings', 'POST',\n      {settings: serverSettings});\n  }\n};\n\ncommands.getSettings = async function () {\n  // as above, we might have some driver-only settings to return as well\n  const driverOnlySettings = this.settings.getSettings();\n  const serverSettings = await this.uiautomator2.jwproxy.command('/appium/settings', 'GET');\n  return {...driverOnlySettings, ...serverSettings};\n};\n\n/**\n * Overriding appium-android-driver's wrapBootstrapDisconnect,\n * unlike in appium-android-driver avoiding adb restarting as it intern\n * kills UiAutomator2 server running in the device.\n **/\nhelpers.wrapBootstrapDisconnect = async function (wrapped) {\n  await wrapped();\n};\n\n// Stop proxying to any Chromedriver and redirect to uiautomator2\nhelpers.suspendChromedriverProxy = function () {\n  this.chromedriver = null;\n  this.proxyReqRes = this.uiautomator2.proxyReqRes.bind(this.uiautomator2);\n  this.jwpProxyActive = true;\n};\n\n/**\n * The list of available info entries can be found at\n * https://github.com/appium/appium-uiautomator2-server/blob/master/app/src/main/java/io/appium/uiautomator2/handler/GetDeviceInfo.java\n */\ncommands.mobileGetDeviceInfo = async function () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/info', 'GET');\n};\n\n/**\n * @typedef {Object} TypingOptions\n * @property {!string|number|boolean} text - The text to type\n */\n\n/**\n * Types the given Unicode string.\n * It is expected that the focus is already put\n * to the destination input field before this method is called.\n *\n * @param {TypingOptions} opts\n * @returns {boolean} `true` if the input text has been successfully sent to adb\n * @throws {Error} if `text` property has not been provided\n */\ncommands.mobileType = async function mobileType (opts = {}) {\n  const {\n    text,\n  } = opts;\n  if (_.isUndefined(text)) {\n    log.errorAndThrow(`The 'text' argument is mandatory`);\n  }\n  return await this.adb.typeUnicode(text);\n};\n\n\n/**\n * @typedef {Object} InstallOptions\n * @property {boolean} allowTestPackages [false] - Set to true in order to allow test\n *                                                 packages installation.\n * @property {boolean} useSdcard [false] - Set to true to install the app on sdcard\n *                                         instead of the device memory.\n * @property {boolean} grantPermissions [false] - Set to true in order to grant all the\n *                                                permissions requested in the application's manifest\n *                                                automatically after the installation is completed\n *                                                under Android 6+.\n * @property {boolean} replace [true] - Set it to false if you don't want\n *                                      the application to be upgraded/reinstalled\n *                                      if it is already present on the device.\n * @property {boolean} partialInstall [false] - Install apks partially. It is used for 'install-multiple'.\n *                                             https://android.stackexchange.com/questions/111064/what-is-a-partial-application-install-via-adb\n */\n\n/**\n * @typedef {Object} InstallMultipleApksOptions\n * @property {Array<string>} apks - The list of APKs to install. Each APK should be a path to a apk\n *                                  or downloadable URL as HTTP/HTTPS.\n * @property {InstallOptions} options\n */\n\n/**\n * Install multiple APKs with `install-multiple` option.\n *\n * @param {InstallMultipleApksOptions} opts\n * @throws {Error} if an error occured while installing the given APKs.\n */\ncommands.mobileInstallMultipleApks = async function (opts = {}) {\n  if (!_.isArray(opts.apks) || _.isEmpty(opts.apks)) {\n    throw new errors.InvalidArgumentError('No apks are given to install');\n  }\n  const apks = await B.all(opts.apks\n    .map((app) => this.helpers.configureApp(app, [APK_EXTENSION])));\n  await this.adb.installMultipleApks(apks, opts.options);\n};\n\nObject.assign(extensions, commands, helpers);\n\nexport default extensions;\n"],"file":"lib/commands/general.js","sourceRoot":"../../.."}
282
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/general.js"],"names":["extensions","commands","helpers","getPageSource","uiautomator2","jwproxy","command","getClipboard","adb","getApiLevel","doSendKeys","params","keyevent","keycode","metastate","log","debug","back","getStrings","language","getDeviceLanguage","info","preprocessStringsMap","mapping","result","key","value","_","toPairs","isString","JSON","stringify","apkStrings","opts","app","appPackage","errorAndThrow","tmpRoot","tempDir","openDir","pullApk","err","message","fs","exists","extractStringsFromApk","rimraf","getDisplayDensity","getWindowSize","getWindowRect","width","height","x","y","executeMobile","mobileCommand","mobileCommandsMapping","shell","execEmuConsoleCommand","dragGesture","flingGesture","doubleClickGesture","clickGesture","longClickGesture","pinchCloseGesture","pinchOpenGesture","swipeGesture","scrollGesture","scrollBackTo","scroll","viewportScreenshot","viewportRect","deepLink","startLogsBroadcast","stopLogsBroadcast","acceptAlert","dismissAlert","batteryInfo","deviceInfo","getDeviceTime","changePermissions","getPermissions","performEditorAction","startScreenStreaming","stopScreenStreaming","getNotifications","listSms","type","sensorSet","deleteFile","clearApp","startActivity","startService","stopService","broadcast","getContexts","installMultipleApks","unlock","refreshGpsCache","has","errors","UnknownCommandError","keys","mobileViewportScreenshot","getViewportScreenshot","mobileViewPortRect","getViewPortRect","setUrl","url","startUri","mobileDeepLink","package","pkg","waitForLaunch","openNotifications","updateSettings","settings","driverOnlySettings","serverSettings","setting","BASEDRIVER_HANDLED_SETTINGS","includes","isEmpty","update","getSettings","wrapBootstrapDisconnect","wrapped","suspendChromedriverProxy","chromedriver","proxyReqRes","bind","proxyCommand","jwpProxyActive","mobileGetDeviceInfo","mobileType","text","isUndefined","typeUnicode","mobileInstallMultipleApks","isArray","apks","InvalidArgumentError","B","all","map","configureApp","APK_EXTENSION","options","Object","assign"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport log from '../logger';\nimport B from 'bluebird';\nimport { errors, BASEDRIVER_HANDLED_SETTINGS } from 'appium-base-driver';\nimport { fs, tempDir } from 'appium-support';\nimport { APK_EXTENSION } from '../extensions';\n\nlet extensions = {},\n    commands = {},\n    helpers = {};\n\ncommands.getPageSource = async function () {\n  return await this.uiautomator2.jwproxy.command('/source', 'GET', {});\n};\n\ncommands.getClipboard = async function () {\n  return (await this.adb.getApiLevel() < 29)\n    ? (await this.uiautomator2.jwproxy.command('/appium/device/get_clipboard', 'POST', {}))\n    : (await this.adb.getClipboard());\n};\n\n// Need to override this for correct unicode support\ncommands.doSendKeys = async function (params) {\n  await this.uiautomator2.jwproxy.command('/keys', 'POST', params);\n};\n\n// uiautomator2 doesn't support metastate for keyevents\ncommands.keyevent = async function (keycode, metastate) {\n  log.debug(`Ignoring metastate ${metastate}`);\n  await this.adb.keyevent(keycode);\n};\n\n// Use ADB since we don't have UiAutomator\ncommands.back = async function () {\n  await this.adb.keyevent(4);\n};\n\ncommands.getStrings = async function (language) {\n  if (!language) {\n    language = await this.adb.getDeviceLanguage();\n    log.info(`No language specified, returning strings for: ${language}`);\n  }\n\n  // Clients require the resulting mapping to have both keys\n  // and values of type string\n  const preprocessStringsMap = function (mapping) {\n    const result = {};\n    for (const [key, value] of _.toPairs(mapping)) {\n      result[key] = _.isString(value) ? value : JSON.stringify(value);\n    }\n    return result;\n  };\n\n  if (this.apkStrings[language]) {\n    // Return cached strings\n    return preprocessStringsMap(this.apkStrings[language]);\n  }\n\n  if (!this.opts.app && !this.opts.appPackage) {\n    log.errorAndThrow(\"One of 'app' or 'appPackage' capabilities should must be specified\");\n  }\n\n  let app = this.opts.app;\n  const tmpRoot = await tempDir.openDir();\n  try {\n    if (!app) {\n      try {\n        app = await this.adb.pullApk(this.opts.appPackage, tmpRoot);\n      } catch (err) {\n        log.errorAndThrow(`Failed to pull an apk from '${this.opts.appPackage}'. Original error: ${err.message}`);\n      }\n    }\n\n    if (!await fs.exists(app)) {\n      log.errorAndThrow(`The app at '${app}' does not exist`);\n    }\n\n    try {\n      const {apkStrings} = await this.adb.extractStringsFromApk(app, language, tmpRoot);\n      this.apkStrings[language] = apkStrings;\n      return preprocessStringsMap(apkStrings);\n    } catch (err) {\n      log.errorAndThrow(`Cannot extract strings from '${app}'. Original error: ${err.message}`);\n    }\n  } finally {\n    await fs.rimraf(tmpRoot);\n  }\n};\n\ncommands.getDisplayDensity = async function getDisplayDensity () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/display_density', 'GET', {});\n};\n\n// memoized in constructor\ncommands.getWindowSize = async function () {\n  return await this.uiautomator2.jwproxy.command('/window/current/size', 'GET', {});\n};\n\n// For W3C\ncommands.getWindowRect = async function () {\n  const {width, height} = await this.getWindowSize();\n  return {\n    width,\n    height,\n    x: 0,\n    y: 0,\n  };\n};\n\nextensions.executeMobile = async function (mobileCommand, opts = {}) {\n  const mobileCommandsMapping = {\n    shell: 'mobileShell',\n\n    execEmuConsoleCommand: 'mobileExecEmuConsoleCommand',\n\n    dragGesture: 'mobileDragGesture',\n    flingGesture: 'mobileFlingGesture',\n    doubleClickGesture: 'mobileDoubleClickGesture',\n    clickGesture: 'mobileClickGesture',\n    longClickGesture: 'mobileLongClickGesture',\n    pinchCloseGesture: 'mobilePinchCloseGesture',\n    pinchOpenGesture: 'mobilePinchOpenGesture',\n    swipeGesture: 'mobileSwipeGesture',\n    scrollGesture: 'mobileScrollGesture',\n    scrollBackTo: 'mobileScrollBackTo',\n    scroll: 'mobileScroll',\n    viewportScreenshot: 'mobileViewportScreenshot',\n    viewportRect: 'mobileViewPortRect',\n\n    deepLink: 'mobileDeepLink',\n\n    startLogsBroadcast: 'mobileStartLogsBroadcast',\n    stopLogsBroadcast: 'mobileStopLogsBroadcast',\n\n    acceptAlert: 'mobileAcceptAlert',\n    dismissAlert: 'mobileDismissAlert',\n\n    batteryInfo: 'mobileGetBatteryInfo',\n\n    deviceInfo: 'mobileGetDeviceInfo',\n\n    getDeviceTime: 'mobileGetDeviceTime',\n\n    changePermissions: 'mobileChangePermissions',\n    getPermissions: 'mobileGetPermissions',\n\n    performEditorAction: 'mobilePerformEditorAction',\n\n    startScreenStreaming: 'mobileStartScreenStreaming',\n    stopScreenStreaming: 'mobileStopScreenStreaming',\n\n    getNotifications: 'mobileGetNotifications',\n\n    listSms: 'mobileListSms',\n\n    type: 'mobileType',\n    sensorSet: 'sensorSet',\n\n    deleteFile: 'mobileDeleteFile',\n\n    clearApp: 'mobileClearApp',\n\n    startActivity: 'mobileStartActivity',\n    startService: 'mobileStartService',\n    stopService: 'mobileStopService',\n    broadcast: 'mobileBroadcast',\n\n    getContexts: 'mobileGetContexts',\n\n    installMultipleApks: 'mobileInstallMultipleApks',\n\n    unlock: 'mobileUnlock',\n\n    refreshGpsCache: 'mobileRefreshGpsCache',\n  };\n\n  if (!_.has(mobileCommandsMapping, mobileCommand)) {\n    throw new errors.UnknownCommandError(`Unknown mobile command \"${mobileCommand}\". ` +\n      `Only ${_.keys(mobileCommandsMapping)} commands are supported.`);\n  }\n  return await this[mobileCommandsMapping[mobileCommand]](opts);\n};\n\ncommands.mobileViewportScreenshot = async function () {\n  return await this.getViewportScreenshot();\n};\n\n/**\n * @typedef {object} Rectangle\n * @property {number} left - The left coordinate of the Rectangle.\n * @property {number} top - The top coordinate of the Rectangle.\n * @property {number} width - The width of Rectangle.\n * @property {number} height - The height of Rectangle.\n */\n\n/**\n * Returns the viewport coordinates.\n * @returns {Rectangle} The viewport coordinates.\n */\ncommands.mobileViewPortRect = async function mobileViewPortRect () {\n  return await this.getViewPortRect();\n};\n\ncommands.setUrl = async function (url) {\n  await this.adb.startUri(url, this.opts.appPackage);\n};\n\n/**\n * @typedef {object} DeepLinkOpts\n * @property {!string} url - The name of URL to start.\n * @property {!string} package - The name of the package to start the URI with.\n * @property {?boolean} waitForLaunch [true] - if `false` then adb won't wait\n * for the started activity to return the control\n */\n\n/**\n * Start URL that take users directly to specific content in the app\n * @param {DeepLinkOpts} opts\n */\ncommands.mobileDeepLink = async function (opts = {}) {\n  const {\n    url,\n    package: pkg,\n    waitForLaunch,\n  } = opts;\n  return await this.adb.startUri(url, pkg, { waitForLaunch });\n};\n\ncommands.openNotifications = async function () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/open_notifications', 'POST', {});\n};\n\ncommands.updateSettings = async function (settings) {\n  // we have some settings that are set on the settings object in the driver\n  // only, for example image finding settings. The uiauto2 server does not know\n  // what to do with them, so just set them on this driver's settings instance,\n  // and don't forward them to the server\n  let driverOnlySettings = {};\n  let serverSettings = {};\n  for (let [setting, value] of _.toPairs(settings)) {\n    if (BASEDRIVER_HANDLED_SETTINGS.includes(setting)) {\n      driverOnlySettings[setting] = value;\n    } else {\n      serverSettings[setting] = value;\n    }\n  }\n  if (!_.isEmpty(driverOnlySettings)) {\n    log.info(`Found some settings designed to be handled by BaseDriver: ` +\n             `${JSON.stringify(_.keys(driverOnlySettings))}. Not ` +\n             `sending these on to the UiAutomator2 server and instead ` +\n             `setting directly on the driver`);\n    await this.settings.update(driverOnlySettings);\n  }\n  if (!_.isEmpty(serverSettings)) {\n    log.info('Forwarding the following settings to the UiAutomator2 server: ' +\n             JSON.stringify(_.keys(serverSettings)));\n    await this.uiautomator2.jwproxy.command('/appium/settings', 'POST',\n      {settings: serverSettings});\n  }\n};\n\ncommands.getSettings = async function () {\n  // as above, we might have some driver-only settings to return as well\n  const driverOnlySettings = this.settings.getSettings();\n  const serverSettings = await this.uiautomator2.jwproxy.command('/appium/settings', 'GET');\n  return {...driverOnlySettings, ...serverSettings};\n};\n\n/**\n * Overriding appium-android-driver's wrapBootstrapDisconnect,\n * unlike in appium-android-driver avoiding adb restarting as it intern\n * kills UiAutomator2 server running in the device.\n **/\nhelpers.wrapBootstrapDisconnect = async function (wrapped) {\n  await wrapped();\n};\n\n// Stop proxying to any Chromedriver and redirect to uiautomator2\nhelpers.suspendChromedriverProxy = function () {\n  this.chromedriver = null;\n  this.proxyReqRes = this.uiautomator2.proxyReqRes.bind(this.uiautomator2);\n  this.proxyCommand = this.uiautomator2.proxyCommand.bind(this.uiautomator2);\n  this.jwpProxyActive = true;\n};\n\n/**\n * The list of available info entries can be found at\n * https://github.com/appium/appium-uiautomator2-server/blob/master/app/src/main/java/io/appium/uiautomator2/handler/GetDeviceInfo.java\n */\ncommands.mobileGetDeviceInfo = async function () {\n  return await this.uiautomator2.jwproxy.command('/appium/device/info', 'GET');\n};\n\n/**\n * @typedef {Object} TypingOptions\n * @property {!string|number|boolean} text - The text to type\n */\n\n/**\n * Types the given Unicode string.\n * It is expected that the focus is already put\n * to the destination input field before this method is called.\n *\n * @param {TypingOptions} opts\n * @returns {boolean} `true` if the input text has been successfully sent to adb\n * @throws {Error} if `text` property has not been provided\n */\ncommands.mobileType = async function mobileType (opts = {}) {\n  const {\n    text,\n  } = opts;\n  if (_.isUndefined(text)) {\n    log.errorAndThrow(`The 'text' argument is mandatory`);\n  }\n  return await this.adb.typeUnicode(text);\n};\n\n\n/**\n * @typedef {Object} InstallOptions\n * @property {boolean} allowTestPackages [false] - Set to true in order to allow test\n *                                                 packages installation.\n * @property {boolean} useSdcard [false] - Set to true to install the app on sdcard\n *                                         instead of the device memory.\n * @property {boolean} grantPermissions [false] - Set to true in order to grant all the\n *                                                permissions requested in the application's manifest\n *                                                automatically after the installation is completed\n *                                                under Android 6+.\n * @property {boolean} replace [true] - Set it to false if you don't want\n *                                      the application to be upgraded/reinstalled\n *                                      if it is already present on the device.\n * @property {boolean} partialInstall [false] - Install apks partially. It is used for 'install-multiple'.\n *                                             https://android.stackexchange.com/questions/111064/what-is-a-partial-application-install-via-adb\n */\n\n/**\n * @typedef {Object} InstallMultipleApksOptions\n * @property {Array<string>} apks - The list of APKs to install. Each APK should be a path to a apk\n *                                  or downloadable URL as HTTP/HTTPS.\n * @property {InstallOptions} options\n */\n\n/**\n * Install multiple APKs with `install-multiple` option.\n *\n * @param {InstallMultipleApksOptions} opts\n * @throws {Error} if an error occured while installing the given APKs.\n */\ncommands.mobileInstallMultipleApks = async function (opts = {}) {\n  if (!_.isArray(opts.apks) || _.isEmpty(opts.apks)) {\n    throw new errors.InvalidArgumentError('No apks are given to install');\n  }\n  const apks = await B.all(opts.apks\n    .map((app) => this.helpers.configureApp(app, [APK_EXTENSION])));\n  await this.adb.installMultipleApks(apks, opts.options);\n};\n\nObject.assign(extensions, commands, helpers);\n\nexport default extensions;\n"],"file":"lib/commands/general.js","sourceRoot":"../../.."}
@@ -29,11 +29,7 @@ function toPoint(x, y) {
29
29
  }
30
30
 
31
31
  function toRect(left, top, width, height) {
32
- if ([left, top, width, height].some(v => !_lodash.default.isFinite(v))) {
33
- return undefined;
34
- }
35
-
36
- return {
32
+ return [left, top, width, height].some(v => !_lodash.default.isFinite(v)) ? undefined : {
37
33
  left,
38
34
  top,
39
35
  width,
@@ -41,6 +37,18 @@ function toRect(left, top, width, height) {
41
37
  };
42
38
  }
43
39
 
40
+ commands.mobileClickGesture = async function mobileClickGesture(opts = {}) {
41
+ const {
42
+ elementId,
43
+ x,
44
+ y
45
+ } = opts;
46
+ return await this.uiautomator2.jwproxy.command('/appium/gestures/click', 'POST', {
47
+ origin: toOrigin(elementId),
48
+ offset: toPoint(x, y)
49
+ });
50
+ };
51
+
44
52
  commands.mobileLongClickGesture = async function mobileLongClickGesture(opts = {}) {
45
53
  const {
46
54
  elementId,
@@ -218,4 +226,4 @@ var _default = commands;
218
226
  exports.default = _default;require('source-map-support').install();
219
227
 
220
228
 
221
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/gestures.js"],"names":["commands","toOrigin","element","util","wrapElement","unwrapElement","undefined","toPoint","x","y","_","isFinite","toRect","left","top","width","height","some","v","mobileLongClickGesture","opts","elementId","duration","uiautomator2","jwproxy","command","origin","offset","mobileDoubleClickGesture","mobileDragGesture","startX","startY","endX","endY","speed","start","end","mobileFlingGesture","direction","area","mobilePinchCloseGesture","percent","mobilePinchOpenGesture","mobileSwipeGesture","mobileScrollGesture","mobileScrollBackTo","elementToId","errors","InvalidArgumentError","mobileScroll","strategy","selector","maxSwipes","params"],"mappings":"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","sourcesContent":["import { util } from 'appium-support';\nimport _ from 'lodash';\nimport { errors } from 'appium-base-driver';\n\nconst commands = {};\n\n\nfunction toOrigin (element) {\n  return element ? util.wrapElement(util.unwrapElement(element)) : undefined;\n}\n\nfunction toPoint (x, y) {\n  return _.isFinite(x) && _.isFinite(y) ? {x, y} : undefined;\n}\n\nfunction toRect (left, top, width, height) {\n  if ([left, top, width, height].some((v) => !_.isFinite(v))) {\n    return undefined;\n  }\n  return {left, top, width, height};\n}\n\n\n/**\n * @typedef {Object} LongClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n * @property {?number} duration [500] - Click duration in milliseconds.\n * The value must not be negative\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?LongClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileLongClickGesture = async function mobileLongClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n    duration,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/long_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n    duration,\n  });\n};\n\n/**\n * @typedef {Object} DoubleClickOptions\n * @property {?string} elementId - The id of the element to be double clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to double click on\n * @property {?number} y - The y coordinate to double click on\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?DoubleClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDoubleClickGesture = async function mobileDoubleClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/double_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} DragOptions\n * @property {?string} elementId - The id of the element to be dragged.\n * If the element id is missing then the start coordinates must be provided.\n * If both the element id and the start coordinates are provided then these\n * coordinates are considered as offsets from the top left element corner.\n * @property {?number} startX - The x coordinate where the dragging starts\n * @property {?number} startY - The y coordinate where the dragging starts\n * @property {!number} endX - The x coordinate where the dragging ends\n * @property {!number} endY - The y coordinate where the dragging ends\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Drags this object to the specified location.\n *\n * @param {?DragOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDragGesture = async function mobileDragGesture (opts = {}) {\n  const {\n    elementId,\n    startX, startY,\n    endX, endY,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/drag', 'POST', {\n    origin: toOrigin(elementId),\n    start: toPoint(startX, startY),\n    end: toPoint(endX, endY),\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} FlingOptions\n * @property {?string} elementId - The id of the element to be flinged.\n * If the element id is missing then fling bounding area must be provided.\n * If both the element id and the fling bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the fling bounding area\n * @property {?number} top - The top coordinate of the fling bounding area\n * @property {?number} width - The width of the fling bounding area\n * @property {?number} height - The height of the fling bounding area\n * @property {!string} direction - Direction of the fling.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {?number} speed [7500 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must be greater than the minimum fling\n * velocity for the given view (50 by default)\n */\n\n/**\n * Drags to the specified location.\n *\n * @param {?FlingOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileFlingGesture = async function mobileFlingGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/fling', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} PinchOptions\n * @property {?string} elementId - The id of the element to be pinched.\n * If the element id is missing then pinch bounding area must be provided.\n * If both the element id and the pinch bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the pinch bounding area\n * @property {?number} top - The top coordinate of the pinch bounding area\n * @property {?number} width - The width of the pinch bounding area\n * @property {?number} height - The height of the pinch bounding area\n * @property {!number} percent - The size of the pinch as a percentage of the pinch area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a pinch close gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchCloseGesture = async function mobilePinchCloseGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_close', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * Performs a pinch open gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchOpenGesture = async function mobilePinchOpenGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_open', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} SwipeOptions\n * @property {?string} elementId - The id of the element to be swiped.\n * If the element id is missing then swipe bounding area must be provided.\n * If both the element id and the swipe bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the swipe bounding area\n * @property {?number} top - The top coordinate of the swipe bounding area\n * @property {?number} width - The width of the swipe bounding area\n * @property {?number} height - The height of the swipe bounding area\n * @property {!string} direction - Direction of the swipe.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the swipe as a percentage of the swipe area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a swipe gesture.\n *\n * @param {?SwipeOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileSwipeGesture = async function mobileSwipeGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/swipe', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollOptions\n * @property {?string} elementId - The id of the element to be scrolled.\n * If the element id is missing then scroll bounding area must be provided.\n * If both the element id and the scroll bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the scroll bounding area\n * @property {?number} top - The top coordinate of the scroll bounding area\n * @property {?number} width - The width of the scroll bounding area\n * @property {?number} height - The height of the scroll bounding area\n * @property {!string} direction - Direction of the scroll.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the scroll as a percentage of the scrolling area size.\n * Valid values must be float numbers greater than zero, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this gesture\n * in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a scroll gesture.\n *\n * @param {?ScrollOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileScrollGesture = async function mobileScrollGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/scroll', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollElementToElementOpts\n * @property {string} elementId The identifier of the scrollable element,\n * which is going to be scrolled. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy.\n * @property {string} elementToId The identifier of the item, which belongs\n * to the scrollable element above, and which should become visible after\n * the scrolling operation is finished. It is required this element\n * was located by `-android uiautomator` strategy.\n */\n\n/**\n * Scrolls the given scrollable element `elementId` until `elementToId`\n * becomes visible. This function returns immediately if the `elementToId`\n * is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollElementToElementOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScrollBackTo = async function (opts = {}) {\n  const {elementId, elementToId} = opts;\n  if (!elementId || !elementToId) {\n    throw new errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command(\n    `/appium/element/${util.unwrapElement(elementId)}/scroll_to/${util.unwrapElement(elementToId)}`, 'POST', {});\n};\n\n/**\n * @typedef {Object} ScrollOpts\n * @property {?string} elementId The identifier of an element. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy. If this property is not provided then the first currently available scrollable view\n * is selected for the interaction.\n * @property {!string} strategy The following strategies are supported:\n * - `accessibility id` (UiSelector().description)\n * - `class name` (UiSelector().className)\n * - `-android uiautomator` (UiSelector)\n * @property {!string} selector The corresponding lookup value for the given\n * strategy.\n * @property {?number} maxSwipes The maximum number of swipes to perform\n * on the target scrollable view in order to reach the destination element.\n * In case this value is unset then it would be retrieved from the scrollable\n * element itself (vua `getMaxSearchSwipes()` property).\n */\n\n/**\n * Scrolls the given scrollable element until the element identified\n * by `strategy` and `selector` becomes visible. This function returns immediately if the\n * destination element is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScroll = async function (opts = {}) {\n  const {\n    element, elementId, // `element` is deprecated, use `elementId` instead\n    strategy, selector, maxSwipes\n  } = opts;\n  if (!strategy || !selector) {\n    throw new errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command('/touch/scroll', 'POST', {\n    origin: toOrigin(elementId || element),\n    params: {strategy, selector, maxSwipes},\n  });\n};\n\nexport default commands;\n"],"file":"lib/commands/gestures.js","sourceRoot":"../../.."}
229
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/gestures.js"],"names":["commands","toOrigin","element","util","wrapElement","unwrapElement","undefined","toPoint","x","y","_","isFinite","toRect","left","top","width","height","some","v","mobileClickGesture","opts","elementId","uiautomator2","jwproxy","command","origin","offset","mobileLongClickGesture","duration","mobileDoubleClickGesture","mobileDragGesture","startX","startY","endX","endY","speed","start","end","mobileFlingGesture","direction","area","mobilePinchCloseGesture","percent","mobilePinchOpenGesture","mobileSwipeGesture","mobileScrollGesture","mobileScrollBackTo","elementToId","errors","InvalidArgumentError","mobileScroll","strategy","selector","maxSwipes","params"],"mappings":"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","sourcesContent":["import { util } from 'appium-support';\nimport _ from 'lodash';\nimport { errors } from 'appium-base-driver';\n\nconst commands = {};\n\n\nfunction toOrigin (element) {\n  return element ? util.wrapElement(util.unwrapElement(element)) : undefined;\n}\n\nfunction toPoint (x, y) {\n  return _.isFinite(x) && _.isFinite(y) ? {x, y} : undefined;\n}\n\nfunction toRect (left, top, width, height) {\n  return [left, top, width, height].some((v) => !_.isFinite(v))\n    ? undefined\n    : {left, top, width, height};\n}\n\n/**\n * @typedef {Object} ClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n */\n\n/**\n * Performs a simple click/tap gesture\n *\n * @param {?ClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileClickGesture = async function mobileClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} LongClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n * @property {?number} duration [500] - Click duration in milliseconds.\n * The value must not be negative\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?LongClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileLongClickGesture = async function mobileLongClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n    duration,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/long_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n    duration,\n  });\n};\n\n/**\n * @typedef {Object} DoubleClickOptions\n * @property {?string} elementId - The id of the element to be double clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to double click on\n * @property {?number} y - The y coordinate to double click on\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?DoubleClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDoubleClickGesture = async function mobileDoubleClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/double_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} DragOptions\n * @property {?string} elementId - The id of the element to be dragged.\n * If the element id is missing then the start coordinates must be provided.\n * If both the element id and the start coordinates are provided then these\n * coordinates are considered as offsets from the top left element corner.\n * @property {?number} startX - The x coordinate where the dragging starts\n * @property {?number} startY - The y coordinate where the dragging starts\n * @property {!number} endX - The x coordinate where the dragging ends\n * @property {!number} endY - The y coordinate where the dragging ends\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Drags this object to the specified location.\n *\n * @param {?DragOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDragGesture = async function mobileDragGesture (opts = {}) {\n  const {\n    elementId,\n    startX, startY,\n    endX, endY,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/drag', 'POST', {\n    origin: toOrigin(elementId),\n    start: toPoint(startX, startY),\n    end: toPoint(endX, endY),\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} FlingOptions\n * @property {?string} elementId - The id of the element to be flinged.\n * If the element id is missing then fling bounding area must be provided.\n * If both the element id and the fling bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the fling bounding area\n * @property {?number} top - The top coordinate of the fling bounding area\n * @property {?number} width - The width of the fling bounding area\n * @property {?number} height - The height of the fling bounding area\n * @property {!string} direction - Direction of the fling.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {?number} speed [7500 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must be greater than the minimum fling\n * velocity for the given view (50 by default)\n */\n\n/**\n * Drags to the specified location.\n *\n * @param {?FlingOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileFlingGesture = async function mobileFlingGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/fling', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} PinchOptions\n * @property {?string} elementId - The id of the element to be pinched.\n * If the element id is missing then pinch bounding area must be provided.\n * If both the element id and the pinch bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the pinch bounding area\n * @property {?number} top - The top coordinate of the pinch bounding area\n * @property {?number} width - The width of the pinch bounding area\n * @property {?number} height - The height of the pinch bounding area\n * @property {!number} percent - The size of the pinch as a percentage of the pinch area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a pinch close gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchCloseGesture = async function mobilePinchCloseGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_close', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * Performs a pinch open gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchOpenGesture = async function mobilePinchOpenGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_open', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} SwipeOptions\n * @property {?string} elementId - The id of the element to be swiped.\n * If the element id is missing then swipe bounding area must be provided.\n * If both the element id and the swipe bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the swipe bounding area\n * @property {?number} top - The top coordinate of the swipe bounding area\n * @property {?number} width - The width of the swipe bounding area\n * @property {?number} height - The height of the swipe bounding area\n * @property {!string} direction - Direction of the swipe.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the swipe as a percentage of the swipe area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a swipe gesture.\n *\n * @param {?SwipeOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileSwipeGesture = async function mobileSwipeGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/swipe', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollOptions\n * @property {?string} elementId - The id of the element to be scrolled.\n * If the element id is missing then scroll bounding area must be provided.\n * If both the element id and the scroll bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the scroll bounding area\n * @property {?number} top - The top coordinate of the scroll bounding area\n * @property {?number} width - The width of the scroll bounding area\n * @property {?number} height - The height of the scroll bounding area\n * @property {!string} direction - Direction of the scroll.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the scroll as a percentage of the scrolling area size.\n * Valid values must be float numbers greater than zero, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this gesture\n * in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a scroll gesture.\n *\n * @param {?ScrollOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileScrollGesture = async function mobileScrollGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/scroll', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollElementToElementOpts\n * @property {string} elementId The identifier of the scrollable element,\n * which is going to be scrolled. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy.\n * @property {string} elementToId The identifier of the item, which belongs\n * to the scrollable element above, and which should become visible after\n * the scrolling operation is finished. It is required this element\n * was located by `-android uiautomator` strategy.\n */\n\n/**\n * Scrolls the given scrollable element `elementId` until `elementToId`\n * becomes visible. This function returns immediately if the `elementToId`\n * is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollElementToElementOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScrollBackTo = async function (opts = {}) {\n  const {elementId, elementToId} = opts;\n  if (!elementId || !elementToId) {\n    throw new errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command(\n    `/appium/element/${util.unwrapElement(elementId)}/scroll_to/${util.unwrapElement(elementToId)}`, 'POST', {});\n};\n\n/**\n * @typedef {Object} ScrollOpts\n * @property {?string} elementId The identifier of an element. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy. If this property is not provided then the first currently available scrollable view\n * is selected for the interaction.\n * @property {!string} strategy The following strategies are supported:\n * - `accessibility id` (UiSelector().description)\n * - `class name` (UiSelector().className)\n * - `-android uiautomator` (UiSelector)\n * @property {!string} selector The corresponding lookup value for the given\n * strategy.\n * @property {?number} maxSwipes The maximum number of swipes to perform\n * on the target scrollable view in order to reach the destination element.\n * In case this value is unset then it would be retrieved from the scrollable\n * element itself (vua `getMaxSearchSwipes()` property).\n */\n\n/**\n * Scrolls the given scrollable element until the element identified\n * by `strategy` and `selector` becomes visible. This function returns immediately if the\n * destination element is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScroll = async function (opts = {}) {\n  const {\n    element, elementId, // `element` is deprecated, use `elementId` instead\n    strategy, selector, maxSwipes\n  } = opts;\n  if (!strategy || !selector) {\n    throw new errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command('/touch/scroll', 'POST', {\n    origin: toOrigin(elementId || element),\n    params: {strategy, selector, maxSwipes},\n  });\n};\n\nexport default commands;\n"],"file":"lib/commands/gestures.js","sourceRoot":"../../.."}