appium-android-driver 5.0.6 → 5.0.7

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.
Files changed (37) hide show
  1. package/build/lib/commands/actions.js +16 -20
  2. package/build/lib/commands/app-management.js +10 -18
  3. package/build/lib/commands/context.js +43 -56
  4. package/build/lib/commands/coverage.js +2 -6
  5. package/build/lib/commands/element.js +3 -9
  6. package/build/lib/commands/emu-console.js +3 -5
  7. package/build/lib/commands/execute.js +3 -6
  8. package/build/lib/commands/file-actions.js +22 -29
  9. package/build/lib/commands/general.js +18 -30
  10. package/build/lib/commands/ime.js +8 -21
  11. package/build/lib/commands/network.js +14 -27
  12. package/build/lib/commands/performance.js +3 -6
  13. package/build/lib/commands/recordscreen.js +27 -38
  14. package/build/lib/commands/shell.js +6 -7
  15. package/build/lib/commands/streamscreen.js +29 -43
  16. package/build/lib/commands/system-bars.js +10 -16
  17. package/build/lib/commands/touch.js +4 -10
  18. package/build/lib/driver.js +36 -60
  19. package/lib/commands/actions.js +18 -19
  20. package/lib/commands/app-management.js +10 -11
  21. package/lib/commands/context.js +33 -34
  22. package/lib/commands/coverage.js +1 -4
  23. package/lib/commands/element.js +2 -3
  24. package/lib/commands/emu-console.js +2 -2
  25. package/lib/commands/execute.js +2 -3
  26. package/lib/commands/file-actions.js +31 -25
  27. package/lib/commands/general.js +16 -18
  28. package/lib/commands/ime.js +7 -8
  29. package/lib/commands/network.js +15 -16
  30. package/lib/commands/performance.js +2 -3
  31. package/lib/commands/recordscreen.js +23 -22
  32. package/lib/commands/shell.js +6 -6
  33. package/lib/commands/streamscreen.js +22 -23
  34. package/lib/commands/system-bars.js +11 -10
  35. package/lib/commands/touch.js +3 -4
  36. package/lib/driver.js +35 -36
  37. package/package.json +2 -2
@@ -17,8 +17,6 @@ var _index = _interopRequireDefault(require("./commands/index"));
17
17
 
18
18
  var _androidHelpers = require("./android-helpers");
19
19
 
20
- var _logger = _interopRequireDefault(require("./logger"));
21
-
22
20
  var _lodash = _interopRequireDefault(require("lodash"));
23
21
 
24
22
  var _appiumAdb = require("appium-adb");
@@ -130,7 +128,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
130
128
  });
131
129
 
132
130
  if ((await this.adb.getApiLevel()) >= 23) {
133
- _logger.default.warn("Consider setting 'automationName' capability to " + "'uiautomator2' on Android >= 6, since UIAutomator framework " + 'is not maintained anymore by the OS vendor.');
131
+ this.log.warn("Consider setting 'automationName' capability to " + "'uiautomator2' on Android >= 6, since UIAutomator framework " + 'is not maintained anymore by the OS vendor.');
134
132
  }
135
133
 
136
134
  if (this.helpers.isPackageOrBundle(this.opts.app)) {
@@ -142,14 +140,13 @@ class AndroidDriver extends _baseDriver.BaseDriver {
142
140
  this.opts.app = await this.helpers.configureApp(this.opts.app, APP_EXTENSION);
143
141
  await this.checkAppPresent();
144
142
  } else if (this.appOnDevice) {
145
- _logger.default.info(`App file was not listed, instead we're going to run ` + `${this.opts.appPackage} directly on the device`);
146
-
143
+ this.log.info(`App file was not listed, instead we're going to run ` + `${this.opts.appPackage} directly on the device`);
147
144
  await this.checkPackagePresent();
148
145
  }
149
146
 
150
147
  if (_support.util.hasValue(this.opts.networkSpeed)) {
151
148
  if (!this.isEmulator()) {
152
- _logger.default.warn('Sorry, networkSpeed capability is only available for emulators');
149
+ this.log.warn('Sorry, networkSpeed capability is only available for emulators');
153
150
  } else {
154
151
  const networkSpeed = (0, _androidHelpers.ensureNetworkSpeed)(this.adb, this.opts.networkSpeed);
155
152
  await this.adb.networkSpeed(networkSpeed);
@@ -158,11 +155,10 @@ class AndroidDriver extends _baseDriver.BaseDriver {
158
155
 
159
156
  if (_support.util.hasValue(this.opts.gpsEnabled)) {
160
157
  if (this.isEmulator()) {
161
- _logger.default.info(`Trying to ${this.opts.gpsEnabled ? 'enable' : 'disable'} gps location provider`);
162
-
158
+ this.log.info(`Trying to ${this.opts.gpsEnabled ? 'enable' : 'disable'} gps location provider`);
163
159
  await this.adb.toggleGPSLocationProvider(this.opts.gpsEnabled);
164
160
  } else {
165
- _logger.default.warn('Sorry! gpsEnabled capability is only available for emulators');
161
+ this.log.warn('Sorry! gpsEnabled capability is only available for emulators');
166
162
  }
167
163
  }
168
164
 
@@ -183,14 +179,14 @@ class AndroidDriver extends _baseDriver.BaseDriver {
183
179
 
184
180
  setAvdFromCapabilities(caps) {
185
181
  if (this.opts.avd) {
186
- _logger.default.info('avd name defined, ignoring device name and platform version');
182
+ this.log.info('avd name defined, ignoring device name and platform version');
187
183
  } else {
188
184
  if (!caps.deviceName) {
189
- _logger.default.errorAndThrow('avd or deviceName should be specified when reboot option is enables');
185
+ this.log.errorAndThrow('avd or deviceName should be specified when reboot option is enables');
190
186
  }
191
187
 
192
188
  if (!caps.platformVersion) {
193
- _logger.default.errorAndThrow('avd or platformVersion should be specified when reboot option is enabled');
189
+ this.log.errorAndThrow('avd or platformVersion should be specified when reboot option is enabled');
194
190
  }
195
191
 
196
192
  let avdDevice = caps.deviceName.replace(/[^a-zA-Z0-9_.]/g, '-');
@@ -213,8 +209,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
213
209
  }
214
210
 
215
211
  async startAndroidSession() {
216
- _logger.default.info(`Starting Android session`);
217
-
212
+ this.log.info(`Starting Android session`);
218
213
  this.defaultIME = await _androidHelpers.helpers.initDevice(this.adb, this.opts);
219
214
  this.caps.deviceName = this.adb.curDeviceId;
220
215
  this.caps.deviceUDID = this.opts.udid;
@@ -226,17 +221,15 @@ class AndroidDriver extends _baseDriver.BaseDriver {
226
221
  if (this.opts.disableWindowAnimation) {
227
222
  if (await this.adb.isAnimationOn()) {
228
223
  if ((await this.adb.getApiLevel()) >= 28) {
229
- _logger.default.warn('Relaxing hidden api policy to manage animation scale');
230
-
224
+ this.log.warn('Relaxing hidden api policy to manage animation scale');
231
225
  await this.adb.setHiddenApiPolicy('1', !!this.opts.ignoreHiddenApiPolicyError);
232
226
  }
233
227
 
234
- _logger.default.info('Disabling window animation as it is requested by "disableWindowAnimation" capability');
235
-
228
+ this.log.info('Disabling window animation as it is requested by "disableWindowAnimation" capability');
236
229
  await this.adb.setAnimationState(false);
237
230
  this._wasWindowAnimationDisabled = true;
238
231
  } else {
239
- _logger.default.info('Window animation is already disabled');
232
+ this.log.info('Window animation is already disabled');
240
233
  }
241
234
  }
242
235
 
@@ -268,8 +261,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
268
261
  }
269
262
 
270
263
  if (_support.util.hasValue(this.opts.orientation)) {
271
- _logger.default.debug(`Setting initial orientation to '${this.opts.orientation}'`);
272
-
264
+ this.addManagedDriverlog.debug(`Setting initial orientation to '${this.opts.orientation}'`);
273
265
  await this.setOrientation(this.opts.orientation);
274
266
  }
275
267
 
@@ -280,9 +272,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
280
272
  if (this.opts.autoWebview) {
281
273
  let viewName = this.defaultWebviewName();
282
274
  let timeout = this.opts.autoWebviewTimeout || 2000;
283
-
284
- _logger.default.info(`Setting auto webview to context '${viewName}' with timeout ${timeout}ms`);
285
-
275
+ this.log.info(`Setting auto webview to context '${viewName}' with timeout ${timeout}ms`);
286
276
  await (0, _asyncbox.retryInterval)(timeout / 500, 500, async () => {
287
277
  await this.setContext(viewName);
288
278
  });
@@ -306,7 +296,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
306
296
  try {
307
297
  otherApps = _androidHelpers.helpers.parseArray(this.opts.otherApps);
308
298
  } catch (e) {
309
- _logger.default.errorAndThrow(`Could not parse "otherApps" capability: ${e.message}`);
299
+ this.log.errorAndThrow(`Could not parse "otherApps" capability: ${e.message}`);
310
300
  }
311
301
 
312
302
  otherApps = await _bluebird.default.all(otherApps.map(app => this.helpers.configureApp(app, APP_EXTENSION)));
@@ -315,10 +305,10 @@ class AndroidDriver extends _baseDriver.BaseDriver {
315
305
 
316
306
  if (!this.opts.app) {
317
307
  if (this.opts.fullReset) {
318
- _logger.default.errorAndThrow('Full reset requires an app capability, use fastReset if app is not provided');
308
+ this.log.errorAndThrow('Full reset requires an app capability, use fastReset if app is not provided');
319
309
  }
320
310
 
321
- _logger.default.debug('No app capability. Assuming it is already on the device');
311
+ this.log.debug('No app capability. Assuming it is already on the device');
322
312
 
323
313
  if (this.opts.fastReset) {
324
314
  await _androidHelpers.helpers.resetApp(this.adb, this.opts);
@@ -344,18 +334,18 @@ class AndroidDriver extends _baseDriver.BaseDriver {
344
334
  }
345
335
 
346
336
  async checkAppPresent() {
347
- _logger.default.debug('Checking whether app is actually present');
337
+ this.log.debug('Checking whether app is actually present');
348
338
 
349
339
  if (!(await _support.fs.exists(this.opts.app))) {
350
- _logger.default.errorAndThrow(`Could not find app apk at ${this.opts.app}`);
340
+ this.log.errorAndThrow(`Could not find app apk at ${this.opts.app}`);
351
341
  }
352
342
  }
353
343
 
354
344
  async checkPackagePresent() {
355
- _logger.default.debug('Checking whether package is present on the device');
345
+ this.log.debug('Checking whether package is present on the device');
356
346
 
357
347
  if (!(await this.adb.shell(['pm', 'list', 'packages', this.opts.appPackage]))) {
358
- _logger.default.errorAndThrow(`Could not find package ${this.opts.appPackage} on the device`);
348
+ this.log.errorAndThrow(`Could not find package ${this.opts.appPackage} on the device`);
359
349
  }
360
350
  }
361
351
 
@@ -366,7 +356,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
366
356
  }
367
357
 
368
358
  async deleteSession() {
369
- _logger.default.debug('Shutting down Android driver');
359
+ this.log.debug('Shutting down Android driver');
370
360
 
371
361
  try {
372
362
  if (!_lodash.default.isEmpty(this._screenRecordingProperties)) {
@@ -382,8 +372,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
382
372
  await this.stopChromedriverProxies();
383
373
 
384
374
  if (this.opts.unicodeKeyboard && this.opts.resetKeyboard && this.defaultIME) {
385
- _logger.default.debug(`Resetting IME to ${this.defaultIME}`);
386
-
375
+ this.log.debug(`Resetting IME to ${this.defaultIME}`);
387
376
  await this.adb.setIME(this.defaultIME);
388
377
  }
389
378
 
@@ -400,7 +389,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
400
389
  await this.bootstrap.shutdown();
401
390
  this.bootstrap = null;
402
391
  } else {
403
- _logger.default.debug("Called deleteSession but bootstrap wasn't active");
392
+ this.log.debug("Called deleteSession but bootstrap wasn't active");
404
393
  }
405
394
 
406
395
  await this.adb.stopLogcat();
@@ -410,36 +399,29 @@ class AndroidDriver extends _baseDriver.BaseDriver {
410
399
  }
411
400
 
412
401
  if (this._wasWindowAnimationDisabled) {
413
- _logger.default.info('Restoring window animation state');
414
-
402
+ this.log.info('Restoring window animation state');
415
403
  await this.adb.setAnimationState(true);
416
404
 
417
405
  if ((await this.adb.getApiLevel()) >= 28) {
418
- _logger.default.info('Restoring hidden api policy to the device default configuration');
419
-
406
+ this.log.info('Restoring hidden api policy to the device default configuration');
420
407
  await this.adb.setDefaultHiddenApiPolicy(!!this.opts.ignoreHiddenApiPolicyError);
421
408
  }
422
409
  }
423
410
 
424
411
  if (this.opts.reboot) {
425
412
  let avdName = this.opts.avd.replace('@', '');
426
-
427
- _logger.default.debug(`closing emulator '${avdName}'`);
428
-
413
+ this.log.debug(`closing emulator '${avdName}'`);
429
414
  await this.adb.killEmulator(avdName);
430
415
  }
431
416
  }
432
417
 
433
418
  async setSharedPreferences() {
434
419
  let sharedPrefs = this.opts.sharedPreferences;
435
-
436
- _logger.default.info('Trying to set shared preferences');
437
-
420
+ this.log.info('Trying to set shared preferences');
438
421
  let name = sharedPrefs.name;
439
422
 
440
423
  if (_lodash.default.isUndefined(name)) {
441
- _logger.default.warn(`Skipping setting Shared preferences, name is undefined: ${JSON.stringify(sharedPrefs)}`);
442
-
424
+ this.log.warn(`Skipping setting Shared preferences, name is undefined: ${JSON.stringify(sharedPrefs)}`);
443
425
  return false;
444
426
  }
445
427
 
@@ -448,27 +430,21 @@ class AndroidDriver extends _baseDriver.BaseDriver {
448
430
  let localPath = `/tmp/${name}.xml`;
449
431
  let builder = this.getPrefsBuilder();
450
432
  builder.build(sharedPrefs.prefs);
451
-
452
- _logger.default.info(`Creating temporary shared preferences: ${localPath}`);
453
-
433
+ this.log.info(`Creating temporary shared preferences: ${localPath}`);
454
434
  builder.toFile(localPath);
455
-
456
- _logger.default.info(`Creating shared_prefs remote folder: ${remotePath}`);
457
-
435
+ this.log.info(`Creating shared_prefs remote folder: ${remotePath}`);
458
436
  await this.adb.shell(['mkdir', '-p', remotePath]);
459
-
460
- _logger.default.info(`Pushing shared_prefs to ${remoteFile}`);
461
-
437
+ this.log.info(`Pushing shared_prefs to ${remoteFile}`);
462
438
  await this.adb.push(localPath, remoteFile);
463
439
 
464
440
  try {
465
- _logger.default.info(`Trying to remove shared preferences temporary file`);
441
+ this.log.info(`Trying to remove shared preferences temporary file`);
466
442
 
467
443
  if (await _support.fs.exists(localPath)) {
468
444
  await _support.fs.unlink(localPath);
469
445
  }
470
446
  } catch (e) {
471
- _logger.default.warn(`Error trying to remove temporary file ${localPath}`);
447
+ this.log.warn(`Error trying to remove temporary file ${localPath}`);
472
448
  }
473
449
 
474
450
  return true;
@@ -484,7 +460,7 @@ class AndroidDriver extends _baseDriver.BaseDriver {
484
460
  }
485
461
 
486
462
  if ((!caps.browserName || !_androidHelpers.helpers.isChromeBrowser(caps.browserName)) && !caps.app && !caps.appPackage) {
487
- _logger.default.errorAndThrow('The desired capabilities must include either an app, appPackage or browserName');
463
+ this.log.errorAndThrow('The desired capabilities must include either an app, appPackage or browserName');
488
464
  }
489
465
 
490
466
  return _androidHelpers.helpers.validateDesiredCaps(caps);
@@ -512,4 +488,4 @@ var _default = AndroidDriver;
512
488
  exports.default = _default;require('source-map-support').install();
513
489
 
514
490
 
515
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/driver.js"],"names":["APP_EXTENSION","DEVICE_PORT","NO_PROXY","RegExp","AndroidDriver","BaseDriver","constructor","opts","shouldValidateCaps","locatorStrategies","desiredCapConstraints","desiredConstraints","sessionChromedrivers","jwpProxyActive","jwpProxyAvoid","_","clone","settings","DeviceSettings","ignoreUnimportantViews","onSettingsUpdate","bind","chromedriver","apkStrings","unlocker","helpers","cmd","fn","toPairs","commands","prototype","curContext","defaultContextName","createSession","args","sessionId","caps","serverDetails","platform","webStorageEnabled","takesScreenshot","javascriptEnabled","databaseEnabled","networkConnectionEnabled","locationContextEnabled","warnings","desired","Object","assign","defaultOpts","action","category","flags","disableAndroidWatchers","tmpDir","tempDir","staticDir","fullReset","autoLaunch","adbPort","DEFAULT_ADB_PORT","bootstrapPort","androidInstallTimeout","defaults","useUnlockHelperApp","isUndefined","unlockType","noReset","fastReset","skipUninstall","isChromeSession","adjustBrowserSessionCaps","nativeWebScreenshot","push","reboot","setAvdFromCapabilities","udid","emPort","getDeviceInfoFromCaps","adb","createADB","suppressKillServer","remoteAdbHost","clearDeviceLogsOnStart","adbExecTimeout","allowOfflineDevices","getApiLevel","log","warn","isPackageOrBundle","app","appPackage","configureApp","checkAppPresent","appOnDevice","info","checkPackagePresent","util","hasValue","networkSpeed","isEmulator","gpsEnabled","toggleGPSLocationProvider","startAndroidSession","e","deleteSession","ign","avd","deviceName","errorAndThrow","platformVersion","avdDevice","replace","isChromeBrowser","browserName","key","value","setCompressedLayoutHierarchy","defaultIME","initDevice","curDeviceId","deviceUDID","getPlatformVersion","deviceScreenSize","getScreenSize","deviceModel","getModel","deviceManufacturer","getManufacturer","disableWindowAnimation","isAnimationOn","setHiddenApiPolicy","ignoreHiddenApiPolicyError","setAnimationState","_wasWindowAnimationDisabled","initAUT","bootstrap","websocket","start","acceptSslCerts","onUnexpectedShutdown","catch","err","ignoreUnexpectedShutdown","startUnexpectedShutdown","skipUnlock","unlock","update","startChromeSession","startAUT","orientation","debug","setOrientation","initAutoWebview","autoWebview","viewName","defaultWebviewName","timeout","autoWebviewTimeout","setContext","launchInfo","getLaunchInfo","uninstallOtherPackages","validateDesiredCaps","parseArray","SETTINGS_HELPER_PKG_ID","otherApps","message","B","all","map","installOtherApks","resetApp","uninstallApk","installApk","apkStringsForLanguage","pushStrings","language","sharedPreferences","setSharedPreferences","fs","exists","shell","compress","sendAction","compressLayout","isEmpty","_screenRecordingProperties","stopRecordingScreen","removeAllSessionWebSocketHandlers","server","mobileStopScreenStreaming","stopChromedriverProxies","unicodeKeyboard","resetKeyboard","setIME","dontStopAppOnReset","forceStop","goToHome","shutdown","stopLogcat","setDefaultHiddenApiPolicy","avdName","killEmulator","sharedPrefs","name","JSON","stringify","remotePath","remoteFile","localPath","builder","getPrefsBuilder","build","prefs","toFile","unlink","SharedPrefsBuilder","proxyActive","getProxyAvoidList","canProxy","isFunction","proxyReqRes"],"mappings":"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","sourcesContent":["import { BaseDriver, DeviceSettings } from '@appium/base-driver';\nimport desiredConstraints from './desired-caps';\nimport commands from './commands/index';\nimport {\n  helpers, ensureNetworkSpeed,\n  SETTINGS_HELPER_PKG_ID,\n} from './android-helpers';\nimport log from './logger';\nimport _ from 'lodash';\nimport { DEFAULT_ADB_PORT } from 'appium-adb';\nimport { fs, tempDir, util } from '@appium/support';\nimport { retryInterval } from 'asyncbox';\nimport { SharedPrefsBuilder } from 'shared-preferences-builder';\nimport B from 'bluebird';\n\nconst APP_EXTENSION = '.apk';\nconst DEVICE_PORT = 4724;\n\n// This is a set of methods and paths that we never want to proxy to\n// Chromedriver\nconst NO_PROXY = [\n  ['POST', new RegExp('^/session/[^/]+/context')],\n  ['GET', new RegExp('^/session/[^/]+/context')],\n  ['POST', new RegExp('^/session/[^/]+/appium')],\n  ['GET', new RegExp('^/session/[^/]+/appium')],\n  ['POST', new RegExp('^/session/[^/]+/touch/perform')],\n  ['POST', new RegExp('^/session/[^/]+/touch/multi/perform')],\n  ['POST', new RegExp('^/session/[^/]+/orientation')],\n  ['GET', new RegExp('^/session/[^/]+/orientation')],\n  ['POST', new RegExp('^/session/[^/]+/execute')],\n  ['POST', new RegExp('^/session/[^/]+/execute/sync')],\n  ['GET', new RegExp('^/session/[^/]+/network_connection')],\n  ['POST', new RegExp('^/session/[^/]+/network_connection')],\n];\n\nclass AndroidDriver extends BaseDriver {\n  constructor (opts = {}, shouldValidateCaps = true) {\n    super(opts, shouldValidateCaps);\n\n    this.locatorStrategies = [\n      'xpath',\n      'id',\n      'class name',\n      'accessibility id',\n      '-android uiautomator'\n    ];\n    this.desiredCapConstraints = desiredConstraints;\n    this.sessionChromedrivers = {};\n    this.jwpProxyActive = false;\n    this.jwpProxyAvoid = _.clone(NO_PROXY);\n    this.settings = new DeviceSettings({ignoreUnimportantViews: false},\n                                       this.onSettingsUpdate.bind(this));\n    this.chromedriver = null;\n    this.apkStrings = {};\n    this.unlocker = helpers.unlocker;\n\n    for (let [cmd, fn] of _.toPairs(commands)) {\n      AndroidDriver.prototype[cmd] = fn;\n    }\n\n    // needs to be after the line which assigns commands to AndroidDriver.prototype, so that `this.defaultContextName` is defined.\n    this.curContext = this.defaultContextName();\n  }\n\n  async createSession (...args) {\n    // the whole createSession flow is surrounded in a try-catch statement\n    // if creating a session fails at any point, we teardown everything we\n    // set up before throwing the error.\n    try {\n      let [sessionId, caps] = await super.createSession(...args);\n\n      let serverDetails = {\n        platform: 'LINUX',\n        webStorageEnabled: false,\n        takesScreenshot: true,\n        javascriptEnabled: true,\n        databaseEnabled: false,\n        networkConnectionEnabled: true,\n        locationContextEnabled: false,\n        warnings: {},\n        desired: this.caps\n      };\n\n      this.caps = Object.assign(serverDetails, this.caps);\n\n      // assigning defaults\n      let defaultOpts = {\n        action: 'android.intent.action.MAIN',\n        category: 'android.intent.category.LAUNCHER',\n        flags: '0x10200000',\n        disableAndroidWatchers: false,\n        tmpDir: await tempDir.staticDir(),\n        fullReset: false,\n        autoLaunch: true,\n        adbPort: DEFAULT_ADB_PORT,\n        bootstrapPort: DEVICE_PORT,\n        androidInstallTimeout: 90000,\n      };\n      _.defaults(this.opts, defaultOpts);\n      this.useUnlockHelperApp = _.isUndefined(this.caps.unlockType);\n\n      // not user visible via caps\n      if (this.opts.noReset === true) {\n        this.opts.fullReset = false;\n      }\n      if (this.opts.fullReset === true) {\n        this.opts.noReset = false;\n      }\n      this.opts.fastReset = !this.opts.fullReset && !this.opts.noReset;\n      this.opts.skipUninstall = this.opts.fastReset || this.opts.noReset;\n\n      if (this.isChromeSession) {\n        helpers.adjustBrowserSessionCaps(this.opts);\n      }\n\n      if (this.opts.nativeWebScreenshot) {\n        this.jwpProxyAvoid.push(['GET', new RegExp('^/session/[^/]+/screenshot')]);\n      }\n\n      if (this.opts.reboot) {\n        this.setAvdFromCapabilities(caps);\n      }\n\n      // get device udid for this session\n      let {udid, emPort} = await helpers.getDeviceInfoFromCaps(this.opts);\n      this.opts.udid = udid;\n      this.opts.emPort = emPort;\n\n      // set up an instance of ADB\n      this.adb = await helpers.createADB({\n        udid: this.opts.udid,\n        emPort: this.opts.emPort,\n        adbPort: this.opts.adbPort,\n        suppressKillServer: this.opts.suppressKillServer,\n        remoteAdbHost: this.opts.remoteAdbHost,\n        clearDeviceLogsOnStart: this.opts.clearDeviceLogsOnStart,\n        adbExecTimeout: this.opts.adbExecTimeout,\n        allowOfflineDevices: this.opts.allowOfflineDevices,\n      });\n\n      if (await this.adb.getApiLevel() >= 23) {\n        log.warn(\"Consider setting 'automationName' capability to \" +\n          \"'uiautomator2' on Android >= 6, since UIAutomator framework \" +\n          'is not maintained anymore by the OS vendor.');\n      }\n\n      if (this.helpers.isPackageOrBundle(this.opts.app)) {\n        // user provided package instead of app for 'app' capability, massage options\n        this.opts.appPackage = this.opts.app;\n        this.opts.app = null;\n      }\n\n      if (this.opts.app) {\n        // find and copy, or download and unzip an app url or path\n        this.opts.app = await this.helpers.configureApp(this.opts.app, APP_EXTENSION);\n        await this.checkAppPresent();\n      } else if (this.appOnDevice) {\n        // the app isn't an actual app file but rather something we want to\n        // assume is on the device and just launch via the appPackage\n        log.info(`App file was not listed, instead we're going to run ` +\n          `${this.opts.appPackage} directly on the device`);\n        await this.checkPackagePresent();\n      }\n\n      // Some cloud services using appium launch the avd themselves, so we ensure netspeed\n      // is set for emulators by calling adb.networkSpeed before running the app\n      if (util.hasValue(this.opts.networkSpeed)) {\n        if (!this.isEmulator()) {\n          log.warn('Sorry, networkSpeed capability is only available for emulators');\n        } else {\n          const networkSpeed = ensureNetworkSpeed(this.adb, this.opts.networkSpeed);\n          await this.adb.networkSpeed(networkSpeed);\n        }\n      }\n      // check if we have to enable/disable gps before running the application\n      if (util.hasValue(this.opts.gpsEnabled)) {\n        if (this.isEmulator()) {\n          log.info(`Trying to ${this.opts.gpsEnabled ? 'enable' : 'disable'} gps location provider`);\n          await this.adb.toggleGPSLocationProvider(this.opts.gpsEnabled);\n        } else {\n          log.warn('Sorry! gpsEnabled capability is only available for emulators');\n        }\n      }\n\n      await this.startAndroidSession(this.opts);\n      return [sessionId, this.caps];\n    } catch (e) {\n      // ignoring delete session exception if any and throw the real error\n      // that happened while creating the session.\n      try {\n        await this.deleteSession();\n      } catch (ign) {}\n      throw e;\n    }\n  }\n\n  isEmulator () {\n    return helpers.isEmulator(this.adb, this.opts);\n  }\n\n  setAvdFromCapabilities (caps) {\n    if (this.opts.avd) {\n      log.info('avd name defined, ignoring device name and platform version');\n    } else {\n      if (!caps.deviceName) {\n        log.errorAndThrow('avd or deviceName should be specified when reboot option is enables');\n      }\n      if (!caps.platformVersion) {\n        log.errorAndThrow('avd or platformVersion should be specified when reboot option is enabled');\n      }\n      let avdDevice = caps.deviceName.replace(/[^a-zA-Z0-9_.]/g, '-');\n      this.opts.avd = `${avdDevice}__${caps.platformVersion}`;\n    }\n  }\n\n  get appOnDevice () {\n    return this.helpers.isPackageOrBundle(this.opts.app) || (!this.opts.app &&\n           this.helpers.isPackageOrBundle(this.opts.appPackage));\n  }\n\n  get isChromeSession () {\n    return helpers.isChromeBrowser(this.opts.browserName);\n  }\n\n  async onSettingsUpdate (key, value) {\n    if (key === 'ignoreUnimportantViews') {\n      await this.setCompressedLayoutHierarchy(value);\n    }\n  }\n\n  async startAndroidSession () {\n    log.info(`Starting Android session`);\n    // set up the device to run on (real or emulator, etc)\n    this.defaultIME = await helpers.initDevice(this.adb, this.opts);\n\n    // set actual device name, udid, platform version, screen size, model and manufacturer details.\n    this.caps.deviceName = this.adb.curDeviceId;\n    this.caps.deviceUDID = this.opts.udid;\n    this.caps.platformVersion = await this.adb.getPlatformVersion();\n    this.caps.deviceScreenSize = await this.adb.getScreenSize();\n    this.caps.deviceModel = await this.adb.getModel();\n    this.caps.deviceManufacturer = await this.adb.getManufacturer();\n\n    if (this.opts.disableWindowAnimation) {\n      if (await this.adb.isAnimationOn()) {\n        if (await this.adb.getApiLevel() >= 28) { // API level 28 is Android P\n          // Don't forget to reset the relaxing in delete session\n          log.warn('Relaxing hidden api policy to manage animation scale');\n          await this.adb.setHiddenApiPolicy('1', !!this.opts.ignoreHiddenApiPolicyError);\n        }\n\n        log.info('Disabling window animation as it is requested by \"disableWindowAnimation\" capability');\n        await this.adb.setAnimationState(false);\n        this._wasWindowAnimationDisabled = true;\n      } else {\n        log.info('Window animation is already disabled');\n      }\n    }\n\n    // set up app under test\n    await this.initAUT();\n\n    // start UiAutomator\n    this.bootstrap = new helpers.bootstrap(this.adb, this.opts.bootstrapPort, this.opts.websocket);\n    await this.bootstrap.start(this.opts.appPackage, this.opts.disableAndroidWatchers, this.opts.acceptSslCerts);\n    // handling unexpected shutdown\n    this.bootstrap.onUnexpectedShutdown.catch(async (err) => { // eslint-disable-line promise/prefer-await-to-callbacks\n      if (!this.bootstrap.ignoreUnexpectedShutdown) {\n        await this.startUnexpectedShutdown(err);\n      }\n    });\n\n    if (!this.opts.skipUnlock) {\n      // Let's try to unlock the device\n      await helpers.unlock(this, this.adb, this.caps);\n    }\n\n    // Set CompressedLayoutHierarchy on the device based on current settings object\n    // this has to happen _after_ bootstrap is initialized\n    if (this.opts.ignoreUnimportantViews) {\n      await this.settings.update({ignoreUnimportantViews: this.opts.ignoreUnimportantViews});\n    }\n\n    if (this.isChromeSession) {\n      // start a chromedriver session and proxy to it\n      await this.startChromeSession();\n    } else {\n      if (this.opts.autoLaunch) {\n        // start app\n        await this.startAUT();\n      }\n    }\n\n    if (util.hasValue(this.opts.orientation)) {\n      log.debug(`Setting initial orientation to '${this.opts.orientation}'`);\n      await this.setOrientation(this.opts.orientation);\n    }\n\n    await this.initAutoWebview();\n  }\n\n  async initAutoWebview () {\n    if (this.opts.autoWebview) {\n      let viewName = this.defaultWebviewName();\n      let timeout = (this.opts.autoWebviewTimeout) || 2000;\n\n      log.info(`Setting auto webview to context '${viewName}' with timeout ${timeout}ms`);\n\n      // try every 500ms until timeout is over\n      await retryInterval(timeout / 500, 500, async () => {\n        await this.setContext(viewName);\n      });\n    }\n  }\n\n  async initAUT () {\n    // populate appPackage, appActivity, appWaitPackage, appWaitActivity,\n    // and the device being used\n    // in the opts and caps (so it gets back to the user on session creation)\n    let launchInfo = await helpers.getLaunchInfo(this.adb, this.opts);\n    Object.assign(this.opts, launchInfo);\n    Object.assign(this.caps, launchInfo);\n\n    // Uninstall any uninstallOtherPackages which were specified in caps\n    if (this.opts.uninstallOtherPackages) {\n      helpers.validateDesiredCaps(this.opts);\n      // Only SETTINGS_HELPER_PKG_ID package is used by UIA1\n      await helpers.uninstallOtherPackages(\n        this.adb,\n        helpers.parseArray(this.opts.uninstallOtherPackages),\n        [SETTINGS_HELPER_PKG_ID]\n      );\n    }\n\n    // Install any \"otherApps\" that were specified in caps\n    if (this.opts.otherApps) {\n      let otherApps;\n      try {\n        otherApps = helpers.parseArray(this.opts.otherApps);\n      } catch (e) {\n        log.errorAndThrow(`Could not parse \"otherApps\" capability: ${e.message}`);\n      }\n      otherApps = await B.all(otherApps.map((app) => this.helpers.configureApp(app, APP_EXTENSION)));\n      await helpers.installOtherApks(otherApps, this.adb, this.opts);\n    }\n\n    // install app\n    if (!this.opts.app) {\n      if (this.opts.fullReset) {\n        log.errorAndThrow('Full reset requires an app capability, use fastReset if app is not provided');\n      }\n      log.debug('No app capability. Assuming it is already on the device');\n      if (this.opts.fastReset) {\n        await helpers.resetApp(this.adb, this.opts);\n      }\n      return;\n    }\n    if (!this.opts.skipUninstall) {\n      await this.adb.uninstallApk(this.opts.appPackage);\n    }\n    await helpers.installApk(this.adb, this.opts);\n    const apkStringsForLanguage = await helpers.pushStrings(this.opts.language, this.adb, this.opts);\n    if (this.opts.language) {\n      this.apkStrings[this.opts.language] = apkStringsForLanguage;\n    }\n\n    // This must run after installing the apk, otherwise it would cause the\n    // install to fail. And before running the app.\n    if (!_.isUndefined(this.opts.sharedPreferences)) {\n      await this.setSharedPreferences(this.opts);\n    }\n  }\n\n  async checkAppPresent () {\n    log.debug('Checking whether app is actually present');\n    if (!(await fs.exists(this.opts.app))) {\n      log.errorAndThrow(`Could not find app apk at ${this.opts.app}`);\n    }\n  }\n\n  async checkPackagePresent () {\n    log.debug('Checking whether package is present on the device');\n    if (!(await this.adb.shell(['pm', 'list', 'packages', this.opts.appPackage]))) {\n      log.errorAndThrow(`Could not find package ${this.opts.appPackage} on the device`);\n    }\n  }\n\n  // Set CompressedLayoutHierarchy on the device\n  async setCompressedLayoutHierarchy (compress) {\n    await this.bootstrap.sendAction('compressedLayoutHierarchy', {compressLayout: compress});\n  }\n\n  async deleteSession () {\n    log.debug('Shutting down Android driver');\n\n    try {\n      if (!_.isEmpty(this._screenRecordingProperties)) {\n        await this.stopRecordingScreen();\n      }\n    } catch (ign) {}\n\n    await helpers.removeAllSessionWebSocketHandlers(this.server, this.sessionId);\n\n    await this.mobileStopScreenStreaming();\n\n    await super.deleteSession();\n\n    if (this.bootstrap) {\n      // certain cleanup we only care to do if the bootstrap was ever run\n      await this.stopChromedriverProxies();\n      if (this.opts.unicodeKeyboard && this.opts.resetKeyboard && this.defaultIME) {\n        log.debug(`Resetting IME to ${this.defaultIME}`);\n        await this.adb.setIME(this.defaultIME);\n      }\n      if (!this.isChromeSession && !this.opts.dontStopAppOnReset) {\n        await this.adb.forceStop(this.opts.appPackage);\n      }\n      await this.adb.goToHome();\n      if (this.opts.fullReset && !this.opts.skipUninstall && !this.appOnDevice) {\n        await this.adb.uninstallApk(this.opts.appPackage);\n      }\n      await this.bootstrap.shutdown();\n      this.bootstrap = null;\n    } else {\n      log.debug(\"Called deleteSession but bootstrap wasn't active\");\n    }\n    // some cleanup we want to do regardless, in case we are shutting down\n    // mid-startup\n    await this.adb.stopLogcat();\n    if (this.useUnlockHelperApp) {\n      await this.adb.forceStop('io.appium.unlock');\n    }\n    if (this._wasWindowAnimationDisabled) {\n      log.info('Restoring window animation state');\n      await this.adb.setAnimationState(true);\n\n      // This was necessary to change animation scale over Android P. We must reset the policy for the security.\n      if (await this.adb.getApiLevel() >= 28) {\n        log.info('Restoring hidden api policy to the device default configuration');\n        await this.adb.setDefaultHiddenApiPolicy(!!this.opts.ignoreHiddenApiPolicyError);\n      }\n    }\n\n    if (this.opts.reboot) {\n      let avdName = this.opts.avd.replace('@', '');\n      log.debug(`closing emulator '${avdName}'`);\n      await this.adb.killEmulator(avdName);\n    }\n  }\n\n  async setSharedPreferences () {\n    let sharedPrefs = this.opts.sharedPreferences;\n    log.info('Trying to set shared preferences');\n    let name = sharedPrefs.name;\n    if (_.isUndefined(name)) {\n      log.warn(`Skipping setting Shared preferences, name is undefined: ${JSON.stringify(sharedPrefs)}`);\n      return false;\n    }\n    let remotePath = `/data/data/${this.opts.appPackage}/shared_prefs`;\n    let remoteFile = `${remotePath}/${name}.xml`;\n    let localPath = `/tmp/${name}.xml`;\n    let builder = this.getPrefsBuilder();\n    builder.build(sharedPrefs.prefs);\n    log.info(`Creating temporary shared preferences: ${localPath}`);\n    builder.toFile(localPath);\n    log.info(`Creating shared_prefs remote folder: ${remotePath}`);\n    await this.adb.shell(['mkdir', '-p', remotePath]);\n    log.info(`Pushing shared_prefs to ${remoteFile}`);\n    await this.adb.push(localPath, remoteFile);\n    try {\n      log.info(`Trying to remove shared preferences temporary file`);\n      if (await fs.exists(localPath)) {\n        await fs.unlink(localPath);\n      }\n    } catch (e) {\n      log.warn(`Error trying to remove temporary file ${localPath}`);\n    }\n    return true;\n  }\n\n  getPrefsBuilder () {\n    /* Add this method to create a new SharedPrefsBuilder instead of\n     * directly creating the object on setSharedPreferences for testing purposes\n    */\n    return new SharedPrefsBuilder();\n  }\n\n  validateDesiredCaps (caps) {\n    if (!super.validateDesiredCaps(caps)) {\n      return false;\n    }\n    if ((!caps.browserName || !helpers.isChromeBrowser(caps.browserName)) && !caps.app && !caps.appPackage) {\n      log.errorAndThrow('The desired capabilities must include either an app, appPackage or browserName');\n    }\n    return helpers.validateDesiredCaps(caps);\n  }\n\n  proxyActive (sessionId) {\n    super.proxyActive(sessionId);\n\n    return this.jwpProxyActive;\n  }\n\n  getProxyAvoidList (sessionId) {\n    super.getProxyAvoidList(sessionId);\n\n    return this.jwpProxyAvoid;\n  }\n\n  canProxy (sessionId) {\n    super.canProxy(sessionId);\n\n    // this will change depending on ChromeDriver status\n    return _.isFunction(this.proxyReqRes);\n  }\n}\n\nexport { AndroidDriver };\nexport default AndroidDriver;\n"],"file":"lib/driver.js","sourceRoot":"../.."}
491
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/driver.js"],"names":["APP_EXTENSION","DEVICE_PORT","NO_PROXY","RegExp","AndroidDriver","BaseDriver","constructor","opts","shouldValidateCaps","locatorStrategies","desiredCapConstraints","desiredConstraints","sessionChromedrivers","jwpProxyActive","jwpProxyAvoid","_","clone","settings","DeviceSettings","ignoreUnimportantViews","onSettingsUpdate","bind","chromedriver","apkStrings","unlocker","helpers","cmd","fn","toPairs","commands","prototype","curContext","defaultContextName","createSession","args","sessionId","caps","serverDetails","platform","webStorageEnabled","takesScreenshot","javascriptEnabled","databaseEnabled","networkConnectionEnabled","locationContextEnabled","warnings","desired","Object","assign","defaultOpts","action","category","flags","disableAndroidWatchers","tmpDir","tempDir","staticDir","fullReset","autoLaunch","adbPort","DEFAULT_ADB_PORT","bootstrapPort","androidInstallTimeout","defaults","useUnlockHelperApp","isUndefined","unlockType","noReset","fastReset","skipUninstall","isChromeSession","adjustBrowserSessionCaps","nativeWebScreenshot","push","reboot","setAvdFromCapabilities","udid","emPort","getDeviceInfoFromCaps","adb","createADB","suppressKillServer","remoteAdbHost","clearDeviceLogsOnStart","adbExecTimeout","allowOfflineDevices","getApiLevel","log","warn","isPackageOrBundle","app","appPackage","configureApp","checkAppPresent","appOnDevice","info","checkPackagePresent","util","hasValue","networkSpeed","isEmulator","gpsEnabled","toggleGPSLocationProvider","startAndroidSession","e","deleteSession","ign","avd","deviceName","errorAndThrow","platformVersion","avdDevice","replace","isChromeBrowser","browserName","key","value","setCompressedLayoutHierarchy","defaultIME","initDevice","curDeviceId","deviceUDID","getPlatformVersion","deviceScreenSize","getScreenSize","deviceModel","getModel","deviceManufacturer","getManufacturer","disableWindowAnimation","isAnimationOn","setHiddenApiPolicy","ignoreHiddenApiPolicyError","setAnimationState","_wasWindowAnimationDisabled","initAUT","bootstrap","websocket","start","acceptSslCerts","onUnexpectedShutdown","catch","err","ignoreUnexpectedShutdown","startUnexpectedShutdown","skipUnlock","unlock","update","startChromeSession","startAUT","orientation","addManagedDriverlog","debug","setOrientation","initAutoWebview","autoWebview","viewName","defaultWebviewName","timeout","autoWebviewTimeout","setContext","launchInfo","getLaunchInfo","uninstallOtherPackages","validateDesiredCaps","parseArray","SETTINGS_HELPER_PKG_ID","otherApps","message","B","all","map","installOtherApks","resetApp","uninstallApk","installApk","apkStringsForLanguage","pushStrings","language","sharedPreferences","setSharedPreferences","fs","exists","shell","compress","sendAction","compressLayout","isEmpty","_screenRecordingProperties","stopRecordingScreen","removeAllSessionWebSocketHandlers","server","mobileStopScreenStreaming","stopChromedriverProxies","unicodeKeyboard","resetKeyboard","setIME","dontStopAppOnReset","forceStop","goToHome","shutdown","stopLogcat","setDefaultHiddenApiPolicy","avdName","killEmulator","sharedPrefs","name","JSON","stringify","remotePath","remoteFile","localPath","builder","getPrefsBuilder","build","prefs","toFile","unlink","SharedPrefsBuilder","proxyActive","getProxyAvoidList","canProxy","isFunction","proxyReqRes"],"mappings":"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","sourcesContent":["import { BaseDriver, DeviceSettings } from '@appium/base-driver';\nimport desiredConstraints from './desired-caps';\nimport commands from './commands/index';\nimport {\n  helpers, ensureNetworkSpeed,\n  SETTINGS_HELPER_PKG_ID,\n} from './android-helpers';\nimport _ from 'lodash';\nimport { DEFAULT_ADB_PORT } from 'appium-adb';\nimport { fs, tempDir, util } from '@appium/support';\nimport { retryInterval } from 'asyncbox';\nimport { SharedPrefsBuilder } from 'shared-preferences-builder';\nimport B from 'bluebird';\n\nconst APP_EXTENSION = '.apk';\nconst DEVICE_PORT = 4724;\n\n// This is a set of methods and paths that we never want to proxy to\n// Chromedriver\nconst NO_PROXY = [\n  ['POST', new RegExp('^/session/[^/]+/context')],\n  ['GET', new RegExp('^/session/[^/]+/context')],\n  ['POST', new RegExp('^/session/[^/]+/appium')],\n  ['GET', new RegExp('^/session/[^/]+/appium')],\n  ['POST', new RegExp('^/session/[^/]+/touch/perform')],\n  ['POST', new RegExp('^/session/[^/]+/touch/multi/perform')],\n  ['POST', new RegExp('^/session/[^/]+/orientation')],\n  ['GET', new RegExp('^/session/[^/]+/orientation')],\n  ['POST', new RegExp('^/session/[^/]+/execute')],\n  ['POST', new RegExp('^/session/[^/]+/execute/sync')],\n  ['GET', new RegExp('^/session/[^/]+/network_connection')],\n  ['POST', new RegExp('^/session/[^/]+/network_connection')],\n];\n\nclass AndroidDriver extends BaseDriver {\n  constructor (opts = {}, shouldValidateCaps = true) {\n    super(opts, shouldValidateCaps);\n\n    this.locatorStrategies = [\n      'xpath',\n      'id',\n      'class name',\n      'accessibility id',\n      '-android uiautomator'\n    ];\n    this.desiredCapConstraints = desiredConstraints;\n    this.sessionChromedrivers = {};\n    this.jwpProxyActive = false;\n    this.jwpProxyAvoid = _.clone(NO_PROXY);\n    this.settings = new DeviceSettings({ignoreUnimportantViews: false},\n                                       this.onSettingsUpdate.bind(this));\n    this.chromedriver = null;\n    this.apkStrings = {};\n    this.unlocker = helpers.unlocker;\n\n    for (let [cmd, fn] of _.toPairs(commands)) {\n      AndroidDriver.prototype[cmd] = fn;\n    }\n\n    // needs to be after the line which assigns commands to AndroidDriver.prototype, so that `this.defaultContextName` is defined.\n    this.curContext = this.defaultContextName();\n  }\n\n  async createSession (...args) {\n    // the whole createSession flow is surrounded in a try-catch statement\n    // if creating a session fails at any point, we teardown everything we\n    // set up before throwing the error.\n    try {\n      let [sessionId, caps] = await super.createSession(...args);\n\n      let serverDetails = {\n        platform: 'LINUX',\n        webStorageEnabled: false,\n        takesScreenshot: true,\n        javascriptEnabled: true,\n        databaseEnabled: false,\n        networkConnectionEnabled: true,\n        locationContextEnabled: false,\n        warnings: {},\n        desired: this.caps\n      };\n\n      this.caps = Object.assign(serverDetails, this.caps);\n\n      // assigning defaults\n      let defaultOpts = {\n        action: 'android.intent.action.MAIN',\n        category: 'android.intent.category.LAUNCHER',\n        flags: '0x10200000',\n        disableAndroidWatchers: false,\n        tmpDir: await tempDir.staticDir(),\n        fullReset: false,\n        autoLaunch: true,\n        adbPort: DEFAULT_ADB_PORT,\n        bootstrapPort: DEVICE_PORT,\n        androidInstallTimeout: 90000,\n      };\n      _.defaults(this.opts, defaultOpts);\n      this.useUnlockHelperApp = _.isUndefined(this.caps.unlockType);\n\n      // not user visible via caps\n      if (this.opts.noReset === true) {\n        this.opts.fullReset = false;\n      }\n      if (this.opts.fullReset === true) {\n        this.opts.noReset = false;\n      }\n      this.opts.fastReset = !this.opts.fullReset && !this.opts.noReset;\n      this.opts.skipUninstall = this.opts.fastReset || this.opts.noReset;\n\n      if (this.isChromeSession) {\n        helpers.adjustBrowserSessionCaps(this.opts);\n      }\n\n      if (this.opts.nativeWebScreenshot) {\n        this.jwpProxyAvoid.push(['GET', new RegExp('^/session/[^/]+/screenshot')]);\n      }\n\n      if (this.opts.reboot) {\n        this.setAvdFromCapabilities(caps);\n      }\n\n      // get device udid for this session\n      let {udid, emPort} = await helpers.getDeviceInfoFromCaps(this.opts);\n      this.opts.udid = udid;\n      this.opts.emPort = emPort;\n\n      // set up an instance of ADB\n      this.adb = await helpers.createADB({\n        udid: this.opts.udid,\n        emPort: this.opts.emPort,\n        adbPort: this.opts.adbPort,\n        suppressKillServer: this.opts.suppressKillServer,\n        remoteAdbHost: this.opts.remoteAdbHost,\n        clearDeviceLogsOnStart: this.opts.clearDeviceLogsOnStart,\n        adbExecTimeout: this.opts.adbExecTimeout,\n        allowOfflineDevices: this.opts.allowOfflineDevices,\n      });\n\n      if (await this.adb.getApiLevel() >= 23) {\n        this.log.warn(\"Consider setting 'automationName' capability to \" +\n          \"'uiautomator2' on Android >= 6, since UIAutomator framework \" +\n          'is not maintained anymore by the OS vendor.');\n      }\n\n      if (this.helpers.isPackageOrBundle(this.opts.app)) {\n        // user provided package instead of app for 'app' capability, massage options\n        this.opts.appPackage = this.opts.app;\n        this.opts.app = null;\n      }\n\n      if (this.opts.app) {\n        // find and copy, or download and unzip an app url or path\n        this.opts.app = await this.helpers.configureApp(this.opts.app, APP_EXTENSION);\n        await this.checkAppPresent();\n      } else if (this.appOnDevice) {\n        // the app isn't an actual app file but rather something we want to\n        // assume is on the device and just launch via the appPackage\n        this.log.info(`App file was not listed, instead we're going to run ` +\n          `${this.opts.appPackage} directly on the device`);\n        await this.checkPackagePresent();\n      }\n\n      // Some cloud services using appium launch the avd themselves, so we ensure netspeed\n      // is set for emulators by calling adb.networkSpeed before running the app\n      if (util.hasValue(this.opts.networkSpeed)) {\n        if (!this.isEmulator()) {\n          this.log.warn('Sorry, networkSpeed capability is only available for emulators');\n        } else {\n          const networkSpeed = ensureNetworkSpeed(this.adb, this.opts.networkSpeed);\n          await this.adb.networkSpeed(networkSpeed);\n        }\n      }\n      // check if we have to enable/disable gps before running the application\n      if (util.hasValue(this.opts.gpsEnabled)) {\n        if (this.isEmulator()) {\n          this.log.info(`Trying to ${this.opts.gpsEnabled ? 'enable' : 'disable'} gps location provider`);\n          await this.adb.toggleGPSLocationProvider(this.opts.gpsEnabled);\n        } else {\n          this.log.warn('Sorry! gpsEnabled capability is only available for emulators');\n        }\n      }\n\n      await this.startAndroidSession(this.opts);\n      return [sessionId, this.caps];\n    } catch (e) {\n      // ignoring delete session exception if any and throw the real error\n      // that happened while creating the session.\n      try {\n        await this.deleteSession();\n      } catch (ign) {}\n      throw e;\n    }\n  }\n\n  isEmulator () {\n    return helpers.isEmulator(this.adb, this.opts);\n  }\n\n  setAvdFromCapabilities (caps) {\n    if (this.opts.avd) {\n      this.log.info('avd name defined, ignoring device name and platform version');\n    } else {\n      if (!caps.deviceName) {\n        this.log.errorAndThrow('avd or deviceName should be specified when reboot option is enables');\n      }\n      if (!caps.platformVersion) {\n        this.log.errorAndThrow('avd or platformVersion should be specified when reboot option is enabled');\n      }\n      let avdDevice = caps.deviceName.replace(/[^a-zA-Z0-9_.]/g, '-');\n      this.opts.avd = `${avdDevice}__${caps.platformVersion}`;\n    }\n  }\n\n  get appOnDevice () {\n    return this.helpers.isPackageOrBundle(this.opts.app) || (!this.opts.app &&\n           this.helpers.isPackageOrBundle(this.opts.appPackage));\n  }\n\n  get isChromeSession () {\n    return helpers.isChromeBrowser(this.opts.browserName);\n  }\n\n  async onSettingsUpdate (key, value) {\n    if (key === 'ignoreUnimportantViews') {\n      await this.setCompressedLayoutHierarchy(value);\n    }\n  }\n\n  async startAndroidSession () {\n    this.log.info(`Starting Android session`);\n    // set up the device to run on (real or emulator, etc)\n    this.defaultIME = await helpers.initDevice(this.adb, this.opts);\n\n    // set actual device name, udid, platform version, screen size, model and manufacturer details.\n    this.caps.deviceName = this.adb.curDeviceId;\n    this.caps.deviceUDID = this.opts.udid;\n    this.caps.platformVersion = await this.adb.getPlatformVersion();\n    this.caps.deviceScreenSize = await this.adb.getScreenSize();\n    this.caps.deviceModel = await this.adb.getModel();\n    this.caps.deviceManufacturer = await this.adb.getManufacturer();\n\n    if (this.opts.disableWindowAnimation) {\n      if (await this.adb.isAnimationOn()) {\n        if (await this.adb.getApiLevel() >= 28) { // API level 28 is Android P\n          // Don't forget to reset the relaxing in delete session\n          this.log.warn('Relaxing hidden api policy to manage animation scale');\n          await this.adb.setHiddenApiPolicy('1', !!this.opts.ignoreHiddenApiPolicyError);\n        }\n\n        this.log.info('Disabling window animation as it is requested by \"disableWindowAnimation\" capability');\n        await this.adb.setAnimationState(false);\n        this._wasWindowAnimationDisabled = true;\n      } else {\n        this.log.info('Window animation is already disabled');\n      }\n    }\n\n    // set up app under test\n    await this.initAUT();\n\n    // start UiAutomator\n    this.bootstrap = new helpers.bootstrap(this.adb, this.opts.bootstrapPort, this.opts.websocket);\n    await this.bootstrap.start(this.opts.appPackage, this.opts.disableAndroidWatchers, this.opts.acceptSslCerts);\n    // handling unexpected shutdown\n    this.bootstrap.onUnexpectedShutdown.catch(async (err) => { // eslint-disable-line promise/prefer-await-to-callbacks\n      if (!this.bootstrap.ignoreUnexpectedShutdown) {\n        await this.startUnexpectedShutdown(err);\n      }\n    });\n\n    if (!this.opts.skipUnlock) {\n      // Let's try to unlock the device\n      await helpers.unlock(this, this.adb, this.caps);\n    }\n\n    // Set CompressedLayoutHierarchy on the device based on current settings object\n    // this has to happen _after_ bootstrap is initialized\n    if (this.opts.ignoreUnimportantViews) {\n      await this.settings.update({ignoreUnimportantViews: this.opts.ignoreUnimportantViews});\n    }\n\n    if (this.isChromeSession) {\n      // start a chromedriver session and proxy to it\n      await this.startChromeSession();\n    } else {\n      if (this.opts.autoLaunch) {\n        // start app\n        await this.startAUT();\n      }\n    }\n\n    if (util.hasValue(this.opts.orientation)) {\n      this.addManagedDriverlog.debug(`Setting initial orientation to '${this.opts.orientation}'`);\n      await this.setOrientation(this.opts.orientation);\n    }\n\n    await this.initAutoWebview();\n  }\n\n  async initAutoWebview () {\n    if (this.opts.autoWebview) {\n      let viewName = this.defaultWebviewName();\n      let timeout = (this.opts.autoWebviewTimeout) || 2000;\n\n      this.log.info(`Setting auto webview to context '${viewName}' with timeout ${timeout}ms`);\n\n      // try every 500ms until timeout is over\n      await retryInterval(timeout / 500, 500, async () => {\n        await this.setContext(viewName);\n      });\n    }\n  }\n\n  async initAUT () {\n    // populate appPackage, appActivity, appWaitPackage, appWaitActivity,\n    // and the device being used\n    // in the opts and caps (so it gets back to the user on session creation)\n    let launchInfo = await helpers.getLaunchInfo(this.adb, this.opts);\n    Object.assign(this.opts, launchInfo);\n    Object.assign(this.caps, launchInfo);\n\n    // Uninstall any uninstallOtherPackages which were specified in caps\n    if (this.opts.uninstallOtherPackages) {\n      helpers.validateDesiredCaps(this.opts);\n      // Only SETTINGS_HELPER_PKG_ID package is used by UIA1\n      await helpers.uninstallOtherPackages(\n        this.adb,\n        helpers.parseArray(this.opts.uninstallOtherPackages),\n        [SETTINGS_HELPER_PKG_ID]\n      );\n    }\n\n    // Install any \"otherApps\" that were specified in caps\n    if (this.opts.otherApps) {\n      let otherApps;\n      try {\n        otherApps = helpers.parseArray(this.opts.otherApps);\n      } catch (e) {\n        this.log.errorAndThrow(`Could not parse \"otherApps\" capability: ${e.message}`);\n      }\n      otherApps = await B.all(otherApps.map((app) => this.helpers.configureApp(app, APP_EXTENSION)));\n      await helpers.installOtherApks(otherApps, this.adb, this.opts);\n    }\n\n    // install app\n    if (!this.opts.app) {\n      if (this.opts.fullReset) {\n        this.log.errorAndThrow('Full reset requires an app capability, use fastReset if app is not provided');\n      }\n      this.log.debug('No app capability. Assuming it is already on the device');\n      if (this.opts.fastReset) {\n        await helpers.resetApp(this.adb, this.opts);\n      }\n      return;\n    }\n    if (!this.opts.skipUninstall) {\n      await this.adb.uninstallApk(this.opts.appPackage);\n    }\n    await helpers.installApk(this.adb, this.opts);\n    const apkStringsForLanguage = await helpers.pushStrings(this.opts.language, this.adb, this.opts);\n    if (this.opts.language) {\n      this.apkStrings[this.opts.language] = apkStringsForLanguage;\n    }\n\n    // This must run after installing the apk, otherwise it would cause the\n    // install to fail. And before running the app.\n    if (!_.isUndefined(this.opts.sharedPreferences)) {\n      await this.setSharedPreferences(this.opts);\n    }\n  }\n\n  async checkAppPresent () {\n    this.log.debug('Checking whether app is actually present');\n    if (!(await fs.exists(this.opts.app))) {\n      this.log.errorAndThrow(`Could not find app apk at ${this.opts.app}`);\n    }\n  }\n\n  async checkPackagePresent () {\n    this.log.debug('Checking whether package is present on the device');\n    if (!(await this.adb.shell(['pm', 'list', 'packages', this.opts.appPackage]))) {\n      this.log.errorAndThrow(`Could not find package ${this.opts.appPackage} on the device`);\n    }\n  }\n\n  // Set CompressedLayoutHierarchy on the device\n  async setCompressedLayoutHierarchy (compress) {\n    await this.bootstrap.sendAction('compressedLayoutHierarchy', {compressLayout: compress});\n  }\n\n  async deleteSession () {\n    this.log.debug('Shutting down Android driver');\n\n    try {\n      if (!_.isEmpty(this._screenRecordingProperties)) {\n        await this.stopRecordingScreen();\n      }\n    } catch (ign) {}\n\n    await helpers.removeAllSessionWebSocketHandlers(this.server, this.sessionId);\n\n    await this.mobileStopScreenStreaming();\n\n    await super.deleteSession();\n\n    if (this.bootstrap) {\n      // certain cleanup we only care to do if the bootstrap was ever run\n      await this.stopChromedriverProxies();\n      if (this.opts.unicodeKeyboard && this.opts.resetKeyboard && this.defaultIME) {\n        this.log.debug(`Resetting IME to ${this.defaultIME}`);\n        await this.adb.setIME(this.defaultIME);\n      }\n      if (!this.isChromeSession && !this.opts.dontStopAppOnReset) {\n        await this.adb.forceStop(this.opts.appPackage);\n      }\n      await this.adb.goToHome();\n      if (this.opts.fullReset && !this.opts.skipUninstall && !this.appOnDevice) {\n        await this.adb.uninstallApk(this.opts.appPackage);\n      }\n      await this.bootstrap.shutdown();\n      this.bootstrap = null;\n    } else {\n      this.log.debug(\"Called deleteSession but bootstrap wasn't active\");\n    }\n    // some cleanup we want to do regardless, in case we are shutting down\n    // mid-startup\n    await this.adb.stopLogcat();\n    if (this.useUnlockHelperApp) {\n      await this.adb.forceStop('io.appium.unlock');\n    }\n    if (this._wasWindowAnimationDisabled) {\n      this.log.info('Restoring window animation state');\n      await this.adb.setAnimationState(true);\n\n      // This was necessary to change animation scale over Android P. We must reset the policy for the security.\n      if (await this.adb.getApiLevel() >= 28) {\n        this.log.info('Restoring hidden api policy to the device default configuration');\n        await this.adb.setDefaultHiddenApiPolicy(!!this.opts.ignoreHiddenApiPolicyError);\n      }\n    }\n\n    if (this.opts.reboot) {\n      let avdName = this.opts.avd.replace('@', '');\n      this.log.debug(`closing emulator '${avdName}'`);\n      await this.adb.killEmulator(avdName);\n    }\n  }\n\n  async setSharedPreferences () {\n    let sharedPrefs = this.opts.sharedPreferences;\n    this.log.info('Trying to set shared preferences');\n    let name = sharedPrefs.name;\n    if (_.isUndefined(name)) {\n      this.log.warn(`Skipping setting Shared preferences, name is undefined: ${JSON.stringify(sharedPrefs)}`);\n      return false;\n    }\n    let remotePath = `/data/data/${this.opts.appPackage}/shared_prefs`;\n    let remoteFile = `${remotePath}/${name}.xml`;\n    let localPath = `/tmp/${name}.xml`;\n    let builder = this.getPrefsBuilder();\n    builder.build(sharedPrefs.prefs);\n    this.log.info(`Creating temporary shared preferences: ${localPath}`);\n    builder.toFile(localPath);\n    this.log.info(`Creating shared_prefs remote folder: ${remotePath}`);\n    await this.adb.shell(['mkdir', '-p', remotePath]);\n    this.log.info(`Pushing shared_prefs to ${remoteFile}`);\n    await this.adb.push(localPath, remoteFile);\n    try {\n      this.log.info(`Trying to remove shared preferences temporary file`);\n      if (await fs.exists(localPath)) {\n        await fs.unlink(localPath);\n      }\n    } catch (e) {\n      this.log.warn(`Error trying to remove temporary file ${localPath}`);\n    }\n    return true;\n  }\n\n  getPrefsBuilder () {\n    /* Add this method to create a new SharedPrefsBuilder instead of\n     * directly creating the object on setSharedPreferences for testing purposes\n    */\n    return new SharedPrefsBuilder();\n  }\n\n  validateDesiredCaps (caps) {\n    if (!super.validateDesiredCaps(caps)) {\n      return false;\n    }\n    if ((!caps.browserName || !helpers.isChromeBrowser(caps.browserName)) && !caps.app && !caps.appPackage) {\n      this.log.errorAndThrow('The desired capabilities must include either an app, appPackage or browserName');\n    }\n    return helpers.validateDesiredCaps(caps);\n  }\n\n  proxyActive (sessionId) {\n    super.proxyActive(sessionId);\n\n    return this.jwpProxyActive;\n  }\n\n  getProxyAvoidList (sessionId) {\n    super.getProxyAvoidList(sessionId);\n\n    return this.jwpProxyAvoid;\n  }\n\n  canProxy (sessionId) {\n    super.canProxy(sessionId);\n\n    // this will change depending on ChromeDriver status\n    return _.isFunction(this.proxyReqRes);\n  }\n}\n\nexport { AndroidDriver };\nexport default AndroidDriver;\n"],"file":"lib/driver.js","sourceRoot":"../.."}
@@ -1,7 +1,6 @@
1
1
  import androidHelpers from '../android-helpers';
2
2
  import { fs, util, tempDir} from '@appium/support';
3
3
  import path from 'path';
4
- import log from '../logger';
5
4
  import B from 'bluebird';
6
5
  import jimp from 'jimp';
7
6
  import { exec } from 'teen_process';
@@ -13,7 +12,7 @@ let commands = {}, helpers = {}, extensions = {};
13
12
 
14
13
  commands.keyevent = async function keyevent (keycode, metastate = null) {
15
14
  // TODO deprecate keyevent; currently wd only implements keyevent
16
- log.warn('keyevent will be deprecated use pressKeyCode');
15
+ this.log.warn('keyevent will be deprecated use pressKeyCode');
17
16
  return await this.pressKeyCode(keycode, metastate);
18
17
  };
19
18
 
@@ -148,56 +147,56 @@ commands.setLocation = async function setLocation (latitude, longitude) {
148
147
 
149
148
  commands.fingerprint = async function fingerprint (fingerprintId) {
150
149
  if (!this.isEmulator()) {
151
- log.errorAndThrow('fingerprint method is only available for emulators');
150
+ this.log.errorAndThrow('fingerprint method is only available for emulators');
152
151
  }
153
152
  await this.adb.fingerprint(fingerprintId);
154
153
  };
155
154
 
156
155
  commands.sendSMS = async function sendSMS (phoneNumber, message) {
157
156
  if (!this.isEmulator()) {
158
- log.errorAndThrow('sendSMS method is only available for emulators');
157
+ this.log.errorAndThrow('sendSMS method is only available for emulators');
159
158
  }
160
159
  await this.adb.sendSMS(phoneNumber, message);
161
160
  };
162
161
 
163
162
  commands.gsmCall = async function gsmCall (phoneNumber, action) {
164
163
  if (!this.isEmulator()) {
165
- log.errorAndThrow('gsmCall method is only available for emulators');
164
+ this.log.errorAndThrow('gsmCall method is only available for emulators');
166
165
  }
167
166
  await this.adb.gsmCall(phoneNumber, action);
168
167
  };
169
168
 
170
169
  commands.gsmSignal = async function gsmSignal (signalStrengh) {
171
170
  if (!this.isEmulator()) {
172
- log.errorAndThrow('gsmSignal method is only available for emulators');
171
+ this.log.errorAndThrow('gsmSignal method is only available for emulators');
173
172
  }
174
173
  await this.adb.gsmSignal(signalStrengh);
175
174
  };
176
175
 
177
176
  commands.gsmVoice = async function gsmVoice (state) {
178
177
  if (!this.isEmulator()) {
179
- log.errorAndThrow('gsmVoice method is only available for emulators');
178
+ this.log.errorAndThrow('gsmVoice method is only available for emulators');
180
179
  }
181
180
  await this.adb.gsmVoice(state);
182
181
  };
183
182
 
184
183
  commands.powerAC = async function powerAC (state) {
185
184
  if (!this.isEmulator()) {
186
- log.errorAndThrow('powerAC method is only available for emulators');
185
+ this.log.errorAndThrow('powerAC method is only available for emulators');
187
186
  }
188
187
  await this.adb.powerAC(state);
189
188
  };
190
189
 
191
190
  commands.powerCapacity = async function powerCapacity (batteryPercent) {
192
191
  if (!this.isEmulator()) {
193
- log.errorAndThrow('powerCapacity method is only available for emulators');
192
+ this.log.errorAndThrow('powerCapacity method is only available for emulators');
194
193
  }
195
194
  await this.adb.powerCapacity(batteryPercent);
196
195
  };
197
196
 
198
197
  commands.networkSpeed = async function networkSpeed (networkSpeed) {
199
198
  if (!this.isEmulator()) {
200
- log.errorAndThrow('networkSpeed method is only available for emulators');
199
+ this.log.errorAndThrow('networkSpeed method is only available for emulators');
201
200
  }
202
201
  await this.adb.networkSpeed(networkSpeed);
203
202
  };
@@ -217,13 +216,13 @@ commands.networkSpeed = async function networkSpeed (networkSpeed) {
217
216
  commands.sensorSet = async function sensorSet (sensor = {}) {
218
217
  const {sensorType, value} = sensor;
219
218
  if (!util.hasValue(sensorType)) {
220
- log.errorAndThrow(`'sensorType' argument is required`);
219
+ this.log.errorAndThrow(`'sensorType' argument is required`);
221
220
  }
222
221
  if (!util.hasValue(value)) {
223
- log.errorAndThrow(`'value' argument is required`);
222
+ this.log.errorAndThrow(`'value' argument is required`);
224
223
  }
225
224
  if (!this.isEmulator()) {
226
- log.errorAndThrow('sensorSet method is only available for emulators');
225
+ this.log.errorAndThrow('sensorSet method is only available for emulators');
227
226
  }
228
227
  await this.adb.sensorSet(sensorType, value);
229
228
  };
@@ -276,8 +275,8 @@ commands.getScreenshot = async function getScreenshot () {
276
275
  // to be executed. Unfortunately, exec-out option is only supported by newer Android/SDK versions (5.0 and later)
277
276
  image = await this.getScreenshotDataWithAdbExecOut(this.adb);
278
277
  } catch (e) {
279
- log.info(`Cannot get screenshot data with 'adb exec-out' because of '${e.message}'. ` +
280
- `Defaulting to 'adb shell' call`);
278
+ this.log.info(`Cannot get screenshot data with 'adb exec-out' because of '${e.message}'. ` +
279
+ `Defaulting to 'adb shell' call`);
281
280
  }
282
281
  }
283
282
  if (!image) {
@@ -285,9 +284,9 @@ commands.getScreenshot = async function getScreenshot () {
285
284
  image = await this.getScreenshotDataWithAdbShell(this.adb, this.opts);
286
285
  } catch (e) {
287
286
  const err = `Cannot get screenshot data because of '${e.message}'. ` +
288
- `Make sure the 'LayoutParams.FLAG_SECURE' is not set for ` +
289
- `the current view`;
290
- log.errorAndThrow(err);
287
+ `Make sure the 'LayoutParams.FLAG_SECURE' is not set for ` +
288
+ `the current view`;
289
+ this.log.errorAndThrow(err);
291
290
  }
292
291
  }
293
292
  if (apiLevel < 23) {
@@ -296,7 +295,7 @@ commands.getScreenshot = async function getScreenshot () {
296
295
  try {
297
296
  image = await image.rotate(-90 * screenOrientation);
298
297
  } catch (err) {
299
- log.warn(`Could not rotate screenshot due to error: ${err}`);
298
+ this.log.warn(`Could not rotate screenshot due to error: ${err}`);
300
299
  }
301
300
  }
302
301
  const getBuffer = B.promisify(image.getBuffer, {context: image});