appium-android-driver 5.0.6 → 5.0.9
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 +0 -1
- package/build/lib/commands/actions.js +16 -20
- package/build/lib/commands/app-management.js +15 -17
- package/build/lib/commands/context.js +46 -66
- package/build/lib/commands/coverage.js +2 -6
- package/build/lib/commands/element.js +3 -9
- package/build/lib/commands/emu-console.js +3 -5
- package/build/lib/commands/execute.js +3 -6
- package/build/lib/commands/file-actions.js +22 -29
- package/build/lib/commands/general.js +18 -30
- package/build/lib/commands/ime.js +8 -21
- package/build/lib/commands/network.js +14 -27
- package/build/lib/commands/performance.js +3 -6
- package/build/lib/commands/recordscreen.js +27 -38
- package/build/lib/commands/shell.js +6 -7
- package/build/lib/commands/streamscreen.js +29 -43
- package/build/lib/commands/system-bars.js +10 -16
- package/build/lib/commands/touch.js +4 -10
- package/build/lib/driver.js +61 -67
- package/build/lib/webview-helpers.js +2 -7
- package/lib/commands/actions.js +18 -19
- package/lib/commands/app-management.js +13 -12
- package/lib/commands/context.js +36 -40
- package/lib/commands/coverage.js +1 -4
- package/lib/commands/element.js +2 -3
- package/lib/commands/emu-console.js +2 -2
- package/lib/commands/execute.js +2 -3
- package/lib/commands/file-actions.js +31 -25
- package/lib/commands/general.js +16 -18
- package/lib/commands/ime.js +7 -8
- package/lib/commands/network.js +15 -16
- package/lib/commands/performance.js +2 -3
- package/lib/commands/recordscreen.js +23 -22
- package/lib/commands/shell.js +6 -6
- package/lib/commands/streamscreen.js +22 -23
- package/lib/commands/system-bars.js +11 -10
- package/lib/commands/touch.js +3 -4
- package/lib/driver.js +45 -46
- package/lib/webview-helpers.js +1 -7
- package/package.json +2 -2
|
@@ -11,8 +11,6 @@ require("source-map-support/register");
|
|
|
11
11
|
|
|
12
12
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
13
13
|
|
|
14
|
-
var _logger = _interopRequireDefault(require("../logger"));
|
|
15
|
-
|
|
16
14
|
var _appiumChromedriver = _interopRequireDefault(require("appium-chromedriver"));
|
|
17
15
|
|
|
18
16
|
var _portfinder = _interopRequireDefault(require("portfinder"));
|
|
@@ -43,10 +41,7 @@ commands.getCurrentContext = async function getCurrentContext() {
|
|
|
43
41
|
};
|
|
44
42
|
|
|
45
43
|
commands.getContexts = async function getContexts() {
|
|
46
|
-
const
|
|
47
|
-
isChromeSession: this.isChromeSession
|
|
48
|
-
}, this.opts);
|
|
49
|
-
const webviewsMapping = await _webviewHelpers.default.getWebViewsMapping(this.adb, opts);
|
|
44
|
+
const webviewsMapping = await _webviewHelpers.default.getWebViewsMapping(this.adb, this.opts);
|
|
50
45
|
return this.assignContexts(webviewsMapping);
|
|
51
46
|
};
|
|
52
47
|
|
|
@@ -61,10 +56,7 @@ commands.setContext = async function setContext(name) {
|
|
|
61
56
|
return;
|
|
62
57
|
}
|
|
63
58
|
|
|
64
|
-
const
|
|
65
|
-
isChromeSession: this.isChromeSession
|
|
66
|
-
}, this.opts);
|
|
67
|
-
const webviewsMapping = await _webviewHelpers.default.getWebViewsMapping(this.adb, opts);
|
|
59
|
+
const webviewsMapping = await _webviewHelpers.default.getWebViewsMapping(this.adb, this.opts);
|
|
68
60
|
const contexts = this.assignContexts(webviewsMapping);
|
|
69
61
|
|
|
70
62
|
if (!_lodash.default.includes(contexts, name)) {
|
|
@@ -80,8 +72,7 @@ commands.mobileGetContexts = async function mobileGetContexts() {
|
|
|
80
72
|
androidDeviceSocket: this.opts.androidDeviceSocket,
|
|
81
73
|
ensureWebviewsHavePages: true,
|
|
82
74
|
webviewDevtoolsPort: this.opts.webviewDevtoolsPort,
|
|
83
|
-
enableWebviewDetailsCollection: true
|
|
84
|
-
isChromeSession: this.isChromeSession
|
|
75
|
+
enableWebviewDetailsCollection: true
|
|
85
76
|
};
|
|
86
77
|
return await _webviewHelpers.default.getWebViewsMapping(this.adb, opts);
|
|
87
78
|
};
|
|
@@ -94,9 +85,7 @@ helpers.assignContexts = function assignContexts(webviewsMapping) {
|
|
|
94
85
|
const webviews = _webviewHelpers.default.parseWebviewNames(webviewsMapping, opts);
|
|
95
86
|
|
|
96
87
|
this.contexts = [_webviewHelpers.NATIVE_WIN, ...webviews];
|
|
97
|
-
|
|
98
|
-
_logger.default.debug(`Available contexts: ${JSON.stringify(this.contexts)}`);
|
|
99
|
-
|
|
88
|
+
this.log.debug(`Available contexts: ${JSON.stringify(this.contexts)}`);
|
|
100
89
|
return this.contexts;
|
|
101
90
|
};
|
|
102
91
|
|
|
@@ -105,8 +94,7 @@ helpers.switchContext = async function switchContext(name, webviewsMapping) {
|
|
|
105
94
|
await this.startChromedriverProxy(name, webviewsMapping);
|
|
106
95
|
} else if (this.isChromedriverContext(this.curContext)) {
|
|
107
96
|
if (this.opts.recreateChromeDriverSessions) {
|
|
108
|
-
|
|
109
|
-
|
|
97
|
+
this.log.debug('recreateChromeDriverSessions set to true; killing existing chromedrivers');
|
|
110
98
|
await this.stopChromedriverProxies();
|
|
111
99
|
} else {
|
|
112
100
|
await this.suspendChromedriverProxy();
|
|
@@ -129,15 +117,13 @@ helpers.isWebContext = function isWebContext() {
|
|
|
129
117
|
};
|
|
130
118
|
|
|
131
119
|
helpers.startChromedriverProxy = async function startChromedriverProxy(context, webviewsMapping) {
|
|
132
|
-
|
|
133
|
-
|
|
120
|
+
this.log.debug(`Connecting to chrome-backed webview context '${context}'`);
|
|
134
121
|
let cd;
|
|
135
122
|
|
|
136
123
|
if (this.sessionChromedrivers[context]) {
|
|
137
|
-
|
|
138
|
-
|
|
124
|
+
this.log.debug(`Found existing Chromedriver for context '${context}'. Using it.`);
|
|
139
125
|
cd = this.sessionChromedrivers[context];
|
|
140
|
-
await setupExistingChromedriver(cd);
|
|
126
|
+
await setupExistingChromedriver(this.log, cd);
|
|
141
127
|
} else {
|
|
142
128
|
let opts = _lodash.default.cloneDeep(this.opts);
|
|
143
129
|
|
|
@@ -163,9 +149,7 @@ helpers.startChromedriverProxy = async function startChromedriverProxy(context,
|
|
|
163
149
|
|
|
164
150
|
if (_lodash.default.includes([_androidHelpers.APP_STATE.RUNNING_IN_BACKGROUND, _androidHelpers.APP_STATE.RUNNING_IN_FOREGROUND], appState)) {
|
|
165
151
|
opts.chromeAndroidPackage = knownPackage;
|
|
166
|
-
|
|
167
|
-
_logger.default.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` + `for context '${context}' by querying states of Chrome app packages`);
|
|
168
|
-
|
|
152
|
+
this.log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` + `for context '${context}' by querying states of Chrome app packages`);
|
|
169
153
|
break;
|
|
170
154
|
}
|
|
171
155
|
}
|
|
@@ -173,9 +157,7 @@ helpers.startChromedriverProxy = async function startChromedriverProxy(context,
|
|
|
173
157
|
for (const wm of webviewsMapping) {
|
|
174
158
|
if (wm.webviewName === context && _lodash.default.has(wm === null || wm === void 0 ? void 0 : wm.info, 'Android-Package')) {
|
|
175
159
|
opts.chromeAndroidPackage = wm.info['Android-Package'];
|
|
176
|
-
|
|
177
|
-
_logger.default.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` + `for context '${context}' by CDP`);
|
|
178
|
-
|
|
160
|
+
this.log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` + `for context '${context}' by CDP`);
|
|
179
161
|
break;
|
|
180
162
|
}
|
|
181
163
|
}
|
|
@@ -206,14 +188,13 @@ helpers.suspendChromedriverProxy = function suspendChromedriverProxy() {
|
|
|
206
188
|
};
|
|
207
189
|
|
|
208
190
|
helpers.onChromedriverStop = async function onChromedriverStop(context) {
|
|
209
|
-
|
|
191
|
+
this.log.warn(`Chromedriver for context ${context} stopped unexpectedly`);
|
|
210
192
|
|
|
211
193
|
if (context === this.curContext) {
|
|
212
194
|
let err = new Error('Chromedriver quit unexpectedly during session');
|
|
213
195
|
await this.startUnexpectedShutdown(err);
|
|
214
196
|
} else {
|
|
215
|
-
|
|
216
|
-
|
|
197
|
+
this.log.warn("Chromedriver quit unexpectedly, but it wasn't the active " + 'context, ignoring');
|
|
217
198
|
delete this.sessionChromedrivers[context];
|
|
218
199
|
}
|
|
219
200
|
};
|
|
@@ -223,15 +204,13 @@ helpers.stopChromedriverProxies = async function stopChromedriverProxies() {
|
|
|
223
204
|
|
|
224
205
|
for (let context of _lodash.default.keys(this.sessionChromedrivers)) {
|
|
225
206
|
let cd = this.sessionChromedrivers[context];
|
|
226
|
-
|
|
227
|
-
_logger.default.debug(`Stopping chromedriver for context ${context}`);
|
|
228
|
-
|
|
207
|
+
this.log.debug(`Stopping chromedriver for context ${context}`);
|
|
229
208
|
cd.removeAllListeners(_appiumChromedriver.default.EVENT_CHANGED);
|
|
230
209
|
|
|
231
210
|
try {
|
|
232
211
|
await cd.stop();
|
|
233
212
|
} catch (err) {
|
|
234
|
-
|
|
213
|
+
this.log.warn(`Error stopping Chromedriver: ${err.message}`);
|
|
235
214
|
}
|
|
236
215
|
|
|
237
216
|
delete this.sessionChromedrivers[context];
|
|
@@ -247,13 +226,11 @@ helpers.shouldDismissChromeWelcome = function shouldDismissChromeWelcome() {
|
|
|
247
226
|
};
|
|
248
227
|
|
|
249
228
|
helpers.dismissChromeWelcome = async function dismissChromeWelcome() {
|
|
250
|
-
|
|
251
|
-
|
|
229
|
+
this.log.info('Trying to dismiss Chrome welcome');
|
|
252
230
|
let activity = await this.getCurrentActivity();
|
|
253
231
|
|
|
254
232
|
if (activity !== 'org.chromium.chrome.browser.firstrun.FirstRunActivity') {
|
|
255
|
-
|
|
256
|
-
|
|
233
|
+
this.log.info('Chrome welcome dialog never showed up! Continuing');
|
|
257
234
|
return;
|
|
258
235
|
}
|
|
259
236
|
|
|
@@ -264,12 +241,12 @@ helpers.dismissChromeWelcome = async function dismissChromeWelcome() {
|
|
|
264
241
|
let el = await this.findElOrEls('id', 'com.android.chrome:id/negative_button', false);
|
|
265
242
|
await this.click(el.ELEMENT);
|
|
266
243
|
} catch (e) {
|
|
267
|
-
|
|
244
|
+
this.log.warn(`This device did not show Chrome SignIn dialog, ${e.message}`);
|
|
268
245
|
}
|
|
269
246
|
};
|
|
270
247
|
|
|
271
248
|
helpers.startChromeSession = async function startChromeSession() {
|
|
272
|
-
|
|
249
|
+
this.log.info('Starting a chrome-based browser session');
|
|
273
250
|
|
|
274
251
|
let opts = _lodash.default.cloneDeep(this.opts);
|
|
275
252
|
|
|
@@ -298,31 +275,27 @@ helpers.startChromeSession = async function startChromeSession() {
|
|
|
298
275
|
}
|
|
299
276
|
};
|
|
300
277
|
|
|
301
|
-
async function setupExistingChromedriver(chromedriver) {
|
|
278
|
+
async function setupExistingChromedriver(log, chromedriver) {
|
|
302
279
|
if (!(await chromedriver.hasWorkingWebview())) {
|
|
303
|
-
|
|
304
|
-
|
|
280
|
+
log.debug('ChromeDriver is not associated with a window. ' + 'Re-initializing the session.');
|
|
305
281
|
await chromedriver.restart();
|
|
306
282
|
}
|
|
307
283
|
|
|
308
284
|
return chromedriver;
|
|
309
285
|
}
|
|
310
286
|
|
|
311
|
-
async function getChromedriverPort(portSpec) {
|
|
287
|
+
async function getChromedriverPort(portSpec, log = null) {
|
|
312
288
|
const getPort = _bluebird.default.promisify(_portfinder.default.getPort, {
|
|
313
289
|
context: _portfinder.default
|
|
314
290
|
});
|
|
315
291
|
|
|
316
292
|
if (!portSpec) {
|
|
317
293
|
const port = await getPort();
|
|
318
|
-
|
|
319
|
-
_logger.default.debug(`A port was not given, using random free port: ${port}`);
|
|
320
|
-
|
|
294
|
+
log === null || log === void 0 ? void 0 : log.debug(`A port was not given, using random free port: ${port}`);
|
|
321
295
|
return port;
|
|
322
296
|
}
|
|
323
297
|
|
|
324
|
-
|
|
325
|
-
|
|
298
|
+
log === null || log === void 0 ? void 0 : log.debug(`Finding a free port for chromedriver using spec ${JSON.stringify(portSpec)}`);
|
|
326
299
|
let foundPort = null;
|
|
327
300
|
|
|
328
301
|
for (const potentialPort of portSpec) {
|
|
@@ -336,15 +309,14 @@ async function getChromedriverPort(portSpec) {
|
|
|
336
309
|
}
|
|
337
310
|
|
|
338
311
|
try {
|
|
339
|
-
|
|
340
|
-
|
|
312
|
+
log === null || log === void 0 ? void 0 : log.debug(`Checking port range ${port}:${stopPort}`);
|
|
341
313
|
foundPort = await getPort({
|
|
342
314
|
port,
|
|
343
315
|
stopPort
|
|
344
316
|
});
|
|
345
317
|
break;
|
|
346
318
|
} catch (e) {
|
|
347
|
-
|
|
319
|
+
log === null || log === void 0 ? void 0 : log.debug(`Nothing in port range ${port}:${stopPort} was available`);
|
|
348
320
|
}
|
|
349
321
|
}
|
|
350
322
|
|
|
@@ -352,38 +324,45 @@ async function getChromedriverPort(portSpec) {
|
|
|
352
324
|
throw new Error(`Could not find a free port for chromedriver using ` + `chromedriverPorts spec ${JSON.stringify(portSpec)}`);
|
|
353
325
|
}
|
|
354
326
|
|
|
355
|
-
|
|
356
|
-
|
|
327
|
+
log === null || log === void 0 ? void 0 : log.debug(`Using free port ${foundPort} for chromedriver`);
|
|
357
328
|
return foundPort;
|
|
358
329
|
}
|
|
359
330
|
|
|
360
331
|
helpers.isChromedriverAutodownloadEnabled = function isChromedriverAutodownloadEnabled() {
|
|
332
|
+
var _this$log;
|
|
333
|
+
|
|
361
334
|
if (this.isFeatureEnabled(CHROMEDRIVER_AUTODOWNLOAD_FEATURE)) {
|
|
362
335
|
return true;
|
|
363
336
|
}
|
|
364
337
|
|
|
365
|
-
|
|
366
|
-
|
|
338
|
+
this === null || this === void 0 ? void 0 : (_this$log = this.log) === null || _this$log === void 0 ? void 0 : _this$log.debug(`Automated Chromedriver download is disabled. ` + `Use '${CHROMEDRIVER_AUTODOWNLOAD_FEATURE}' server feature to enable it`);
|
|
367
339
|
return false;
|
|
368
340
|
};
|
|
369
341
|
|
|
370
342
|
helpers.setupNewChromedriver = async function setupNewChromedriver(opts, curDeviceId, adb, context = null) {
|
|
343
|
+
var _this$isChromedriverA, _this$log6;
|
|
344
|
+
|
|
371
345
|
if (opts.chromeDriverPort) {
|
|
372
|
-
|
|
346
|
+
var _this$log2;
|
|
373
347
|
|
|
348
|
+
this === null || this === void 0 ? void 0 : (_this$log2 = this.log) === null || _this$log2 === void 0 ? void 0 : _this$log2.warn(`The 'chromeDriverPort' capability is deprecated. Please use 'chromedriverPort' instead`);
|
|
374
349
|
opts.chromedriverPort = opts.chromeDriverPort;
|
|
375
350
|
}
|
|
376
351
|
|
|
377
352
|
if (opts.chromedriverPort) {
|
|
378
|
-
|
|
353
|
+
var _this$log3;
|
|
354
|
+
|
|
355
|
+
this === null || this === void 0 ? void 0 : (_this$log3 = this.log) === null || _this$log3 === void 0 ? void 0 : _this$log3.debug(`Using user-specified port ${opts.chromedriverPort} for chromedriver`);
|
|
379
356
|
} else {
|
|
380
|
-
opts.chromedriverPort = await getChromedriverPort(opts.chromedriverPorts);
|
|
357
|
+
opts.chromedriverPort = await getChromedriverPort(opts.chromedriverPorts, this === null || this === void 0 ? void 0 : this.log);
|
|
381
358
|
}
|
|
382
359
|
|
|
383
360
|
const details = context ? _webviewHelpers.default.getWebviewDetails(adb, context) : undefined;
|
|
384
361
|
|
|
385
362
|
if (!_lodash.default.isEmpty(details)) {
|
|
386
|
-
|
|
363
|
+
var _this$log4;
|
|
364
|
+
|
|
365
|
+
this === null || this === void 0 ? void 0 : (_this$log4 = this.log) === null || _this$log4 === void 0 ? void 0 : _this$log4.debug('Passing web view details to the Chromedriver constructor: ' + JSON.stringify(details, null, 2));
|
|
387
366
|
}
|
|
388
367
|
|
|
389
368
|
const chromedriver = new _appiumChromedriver.default({
|
|
@@ -398,13 +377,15 @@ helpers.setupNewChromedriver = async function setupNewChromedriver(opts, curDevi
|
|
|
398
377
|
useSystemExecutable: opts.chromedriverUseSystemExecutable,
|
|
399
378
|
disableBuildCheck: opts.chromedriverDisableBuildCheck,
|
|
400
379
|
details,
|
|
401
|
-
isAutodownloadEnabled:
|
|
380
|
+
isAutodownloadEnabled: this === null || this === void 0 ? void 0 : (_this$isChromedriverA = this.isChromedriverAutodownloadEnabled) === null || _this$isChromedriverA === void 0 ? void 0 : _this$isChromedriverA.call(this)
|
|
402
381
|
});
|
|
403
382
|
opts.chromeOptions = opts.chromeOptions || {};
|
|
404
383
|
|
|
405
384
|
for (const opt of _lodash.default.keys(opts)) {
|
|
406
385
|
if (opt.endsWith(':chromeOptions')) {
|
|
407
|
-
|
|
386
|
+
var _this$log5;
|
|
387
|
+
|
|
388
|
+
this === null || this === void 0 ? void 0 : (_this$log5 = this.log) === null || _this$log5 === void 0 ? void 0 : _this$log5.warn(`Merging '${opt}' into 'chromeOptions'. This may cause unexpected behavior`);
|
|
408
389
|
|
|
409
390
|
_lodash.default.merge(opts.chromeOptions, opts[opt]);
|
|
410
391
|
}
|
|
@@ -412,8 +393,7 @@ helpers.setupNewChromedriver = async function setupNewChromedriver(opts, curDevi
|
|
|
412
393
|
|
|
413
394
|
const caps = _webviewHelpers.default.createChromedriverCaps(opts, curDeviceId, details);
|
|
414
395
|
|
|
415
|
-
|
|
416
|
-
|
|
396
|
+
this === null || this === void 0 ? void 0 : (_this$log6 = this.log) === null || _this$log6 === void 0 ? void 0 : _this$log6.debug(`Before starting chromedriver, androidPackage is '${caps.chromeOptions.androidPackage}'`);
|
|
417
397
|
await chromedriver.start(caps);
|
|
418
398
|
return chromedriver;
|
|
419
399
|
};
|
|
@@ -425,4 +405,4 @@ var _default = extensions;
|
|
|
425
405
|
exports.default = _default;require('source-map-support').install();
|
|
426
406
|
|
|
427
407
|
|
|
428
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/context.js"],"names":["CHROMEDRIVER_AUTODOWNLOAD_FEATURE","commands","helpers","extensions","getCurrentContext","curContext","defaultContextName","getContexts","opts","Object","assign","isChromeSession","webviewsMapping","webviewHelpers","getWebViewsMapping","adb","assignContexts","setContext","name","util","hasValue","WEBVIEW_WIN","defaultWebviewName","contexts","_","includes","errors","NoSuchContextError","switchContext","mobileGetContexts","androidDeviceSocket","ensureWebviewsHavePages","webviewDevtoolsPort","enableWebviewDetailsCollection","webviews","parseWebviewNames","NATIVE_WIN","log","debug","JSON","stringify","isChromedriverContext","startChromedriverProxy","recreateChromeDriverSessions","stopChromedriverProxies","suspendChromedriverProxy","Error","WEBVIEW_BASE","appPackage","isWebContext","context","cd","sessionChromedrivers","setupExistingChromedriver","cloneDeep","chromeUseRunningApp","extractChromeAndroidPackageFromContextName","androidPackage","match","length","chromeAndroidPackage","has","map","wm","webviewName","knownPackage","KNOWN_CHROME_PACKAGE_NAMES","appState","queryAppState","APP_STATE","RUNNING_IN_BACKGROUND","RUNNING_IN_FOREGROUND","info","setupNewChromedriver","curDeviceId","on","Chromedriver","EVENT_CHANGED","msg","state","STATE_STOPPED","onChromedriverStop","chromedriver","proxyReqRes","proxyReq","bind","proxyCommand","jwproxy","command","jwpProxyActive","warn","err","startUnexpectedShutdown","keys","removeAllListeners","stop","message","viewName","CHROMIUM_WIN","shouldDismissChromeWelcome","chromeOptions","isArray","args","dismissChromeWelcome","activity","getCurrentActivity","el","findElOrEls","click","ELEMENT","e","startChromeSession","knownPackages","chromeBundleId","chromeAndroidActivity","appActivity","hasWorkingWebview","restart","getChromedriverPort","portSpec","getPort","B","promisify","PortFinder","port","foundPort","potentialPort","stopPort","parseInt","isChromedriverAutodownloadEnabled","isFeatureEnabled","chromeDriverPort","chromedriverPort","chromedriverPorts","details","getWebviewDetails","undefined","isEmpty","executable","chromedriverExecutable","cmdArgs","chromedriverArgs","verbose","showChromedriverLog","executableDir","chromedriverExecutableDir","mappingPath","chromedriverChromeMappingFile","bundleId","useSystemExecutable","chromedriverUseSystemExecutable","disableBuildCheck","chromedriverDisableBuildCheck","isAutodownloadEnabled","opt","endsWith","merge","caps","createChromedriverCaps","start"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport log from '../logger';\nimport Chromedriver from 'appium-chromedriver';\nimport PortFinder from 'portfinder';\nimport B from 'bluebird';\nimport { util } from '@appium/support';\nimport { errors } from '@appium/base-driver';\nimport {\n  default as webviewHelpers,\n  NATIVE_WIN, WEBVIEW_BASE, WEBVIEW_WIN, CHROMIUM_WIN, KNOWN_CHROME_PACKAGE_NAMES\n} from '../webview-helpers';\nimport { APP_STATE } from '../android-helpers';\n\nconst CHROMEDRIVER_AUTODOWNLOAD_FEATURE = 'chromedriver_autodownload';\n\nlet commands = {}, helpers = {}, extensions = {};\n\n\n/* -------------------------------\n * Actual MJSONWP command handlers\n * ------------------------------- */\ncommands.getCurrentContext = async function getCurrentContext () { // eslint-disable-line require-await\n  // if the current context is `null`, indicating no context\n  // explicitly set, it is the default context\n  return this.curContext || this.defaultContextName();\n};\n\ncommands.getContexts = async function getContexts () {\n  const opts = Object.assign({isChromeSession: this.isChromeSession}, this.opts);\n  const webviewsMapping = await webviewHelpers.getWebViewsMapping(this.adb, opts);\n  return this.assignContexts(webviewsMapping);\n};\n\ncommands.setContext = async function setContext (name) {\n  if (!util.hasValue(name)) {\n    name = this.defaultContextName();\n  } else if (name === WEBVIEW_WIN) {\n    // handle setContext \"WEBVIEW\"\n    name = this.defaultWebviewName();\n  }\n  // if we're already in the context we want, do nothing\n  if (name === this.curContext) {\n    return;\n  }\n\n  const opts = Object.assign({isChromeSession: this.isChromeSession}, this.opts);\n  const webviewsMapping = await webviewHelpers.getWebViewsMapping(this.adb, opts);\n  const contexts = this.assignContexts(webviewsMapping);\n  // if the context we want doesn't exist, fail\n  if (!_.includes(contexts, name)) {\n    throw new errors.NoSuchContextError();\n  }\n\n  await this.switchContext(name, webviewsMapping);\n  this.curContext = name;\n};\n\n/**\n * @typedef {Object} WebviewsMapping\n * @property {string} proc The name of the Devtools Unix socket\n * @property {string} webview The web view alias. Looks like `WEBVIEW_`\n * prefix plus PID or package name\n * @property {?Object} info Webview information as it is retrieved by\n * /json/version CDP endpoint\n * @property {?Array<Object>} pages Webview pages list as it is retrieved by\n * /json/list CDP endpoint\n * @propery {?string} webviewName An actual webview name for switching context.\n * This value becomes null when failing to find a PID for a webview.\n *\n * The following json demonstrates the example of WebviewsMapping object.\n * Note that `description` in `page` can be an empty string most likely when it comes to Mobile Chrome)\n * {\n *   \"proc\": \"@webview_devtools_remote_22138\",\n *   \"webview\": \"WEBVIEW_22138\",\n *   \"info\": {\n *     \"Android-Package\": \"io.appium.settings\",\n *     \"Browser\": \"Chrome/74.0.3729.185\",\n *     \"Protocol-Version\": \"1.3\",\n *     \"User-Agent\": \"Mozilla/5.0 (Linux; Android 10; Android SDK built for x86 Build/QSR1.190920.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/74.0.3729.185 Mobile Safari/537.36\",\n *     \"V8-Version\": \"7.4.288.28\",\n *     \"WebKit-Version\": \"537.36 (@22955682f94ce09336197bfb8dffea991fa32f0d)\",\n *     \"webSocketDebuggerUrl\": \"ws://127.0.0.1:10900/devtools/browser\"\n *   },\n *   \"pages\": [\n *     {\n *       \"description\": \"{\\\"attached\\\":true,\\\"empty\\\":false,\\\"height\\\":1458,\\\"screenX\\\":0,\\\"screenY\\\":336,\\\"visible\\\":true,\\\"width\\\":1080}\",\n *       \"devtoolsFrontendUrl\": \"http://chrome-devtools-frontend.appspot.com/serve_rev/@22955682f94ce09336197bfb8dffea991fa32f0d/inspector.html?ws=127.0.0.1:10900/devtools/page/27325CC50B600D31B233F45E09487B1F\",\n *       \"id\": \"27325CC50B600D31B233F45E09487B1F\",\n *       \"title\": \"Releases · appium/appium · GitHub\",\n *       \"type\": \"page\",\n *       \"url\": \"https://github.com/appium/appium/releases\",\n *       \"webSocketDebuggerUrl\": \"ws://127.0.0.1:10900/devtools/page/27325CC50B600D31B233F45E09487B1F\"\n *     }\n *   ],\n *   \"webviewName\": \"WEBVIEW_com.io.appium.setting\"\n * }\n */\n\n/**\n * Returns a webviewsMapping based on CDP endpoints\n *\n * @return {Array<WebviewsMapping>} webviewsMapping\n */\ncommands.mobileGetContexts = async function mobileGetContexts () {\n  const opts = {\n    androidDeviceSocket: this.opts.androidDeviceSocket,\n    ensureWebviewsHavePages: true,\n    webviewDevtoolsPort: this.opts.webviewDevtoolsPort,\n    enableWebviewDetailsCollection: true,\n    isChromeSession: this.isChromeSession\n  };\n  return await webviewHelpers.getWebViewsMapping(this.adb, opts);\n};\n\nhelpers.assignContexts = function assignContexts (webviewsMapping) {\n  const opts = Object.assign({isChromeSession: this.isChromeSession}, this.opts);\n  const webviews = webviewHelpers.parseWebviewNames(webviewsMapping, opts);\n  this.contexts = [NATIVE_WIN, ...webviews];\n  log.debug(`Available contexts: ${JSON.stringify(this.contexts)}`);\n  return this.contexts;\n};\n\nhelpers.switchContext = async function switchContext (name, webviewsMapping) {\n  // We have some options when it comes to webviews. If we want a\n  // Chromedriver webview, we can only control one at a time.\n  if (this.isChromedriverContext(name)) {\n    // start proxying commands directly to chromedriver\n    await this.startChromedriverProxy(name, webviewsMapping);\n  } else if (this.isChromedriverContext(this.curContext)) {\n    // if we're moving to a non-chromedriver webview, and our current context\n    // _is_ a chromedriver webview, if caps recreateChromeDriverSessions is set\n    // to true then kill chromedriver session using stopChromedriverProxies or\n    // else simply suspend proxying to the latter\n    if (this.opts.recreateChromeDriverSessions) {\n      log.debug('recreateChromeDriverSessions set to true; killing existing chromedrivers');\n      await this.stopChromedriverProxies();\n    } else {\n      await this.suspendChromedriverProxy();\n    }\n  } else {\n    throw new Error(`Didn't know how to handle switching to context '${name}'`);\n  }\n};\n\n\n/* ---------------------------------\n * On-object context-related helpers\n * --------------------------------- */\n\n// The reason this is a function and not just a constant is that both android-\n// driver and selendroid-driver use this logic, and each one returns\n// a different default context name\nhelpers.defaultContextName = function defaultContextName () {\n  return NATIVE_WIN;\n};\n\nhelpers.defaultWebviewName = function defaultWebviewName () {\n  return WEBVIEW_BASE + this.opts.appPackage;\n};\n\nhelpers.isWebContext = function isWebContext () {\n  return this.curContext !== null && this.curContext !== NATIVE_WIN;\n};\n\n// Turn on proxying to an existing Chromedriver session or a new one\nhelpers.startChromedriverProxy = async function startChromedriverProxy (context, webviewsMapping) {\n  log.debug(`Connecting to chrome-backed webview context '${context}'`);\n\n  let cd;\n  if (this.sessionChromedrivers[context]) {\n    // in the case where we've already set up a chromedriver for a context,\n    // we want to reconnect to it, not create a whole new one\n    log.debug(`Found existing Chromedriver for context '${context}'. Using it.`);\n    cd = this.sessionChromedrivers[context];\n    await setupExistingChromedriver(cd);\n  } else {\n    let opts = _.cloneDeep(this.opts);\n    opts.chromeUseRunningApp = true;\n\n    // if requested, tell chromedriver to attach to the android package we have\n    // associated with the context name, rather than the package of the AUT.\n    // And turn this on by default for chrome--if chrome pops up with a webview\n    // and someone wants to switch to it, we should let chromedriver connect to\n    // chrome rather than staying stuck on the AUT\n    if (opts.extractChromeAndroidPackageFromContextName || context === `${WEBVIEW_BASE}chrome`) {\n      let androidPackage = context.match(`${WEBVIEW_BASE}(.+)`);\n      if (androidPackage && androidPackage.length > 0) {\n        opts.chromeAndroidPackage = androidPackage[1];\n      }\n      if (!opts.extractChromeAndroidPackageFromContextName) {\n        if (_.has(this.opts, 'enableWebviewDetailsCollection') && !this.opts.enableWebviewDetailsCollection) {\n          // When enableWebviewDetailsCollection capability is explicitly disabled, try to identify\n          // chromeAndroidPackage based on contexts, known chrome variant packages and queryAppState result\n          // since webviewsMapping does not have info object\n          const contexts = webviewsMapping.map((wm) => wm.webviewName);\n          for (const knownPackage of KNOWN_CHROME_PACKAGE_NAMES) {\n            if (_.includes(contexts, `${WEBVIEW_BASE}${knownPackage}`)) {\n              continue;\n            }\n            const appState = await this.queryAppState(knownPackage);\n            if (_.includes([APP_STATE.RUNNING_IN_BACKGROUND, APP_STATE.RUNNING_IN_FOREGROUND], appState)) {\n              opts.chromeAndroidPackage = knownPackage;\n              log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` +\n                `for context '${context}' by querying states of Chrome app packages`);\n              break;\n            }\n          }\n        } else {\n          for (const wm of webviewsMapping) {\n            if (wm.webviewName === context && _.has(wm?.info, 'Android-Package')) {\n              opts.chromeAndroidPackage = wm.info['Android-Package'];\n              log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` +\n                `for context '${context}' by CDP`);\n              break;\n            }\n          }\n        }\n      }\n    }\n\n    cd = await this.setupNewChromedriver(opts, this.adb.curDeviceId, this.adb, context);\n    // bind our stop/exit handler, passing in context so we know which\n    // one stopped unexpectedly\n    cd.on(Chromedriver.EVENT_CHANGED, (msg) => {\n      if (msg.state === Chromedriver.STATE_STOPPED) {\n        this.onChromedriverStop(context);\n      }\n    });\n    // save the chromedriver object under the context\n    this.sessionChromedrivers[context] = cd;\n  }\n  // hook up the local variables so we can proxy this biz\n  this.chromedriver = cd;\n  this.proxyReqRes = this.chromedriver.proxyReq.bind(this.chromedriver);\n  this.proxyCommand = this.chromedriver.jwproxy.command.bind(this.chromedriver.jwproxy);\n  this.jwpProxyActive = true;\n};\n\n// Stop proxying to any Chromedriver\nhelpers.suspendChromedriverProxy = function suspendChromedriverProxy () {\n  this.chromedriver = null;\n  this.proxyReqRes = null;\n  this.proxyCommand = null;\n  this.jwpProxyActive = false;\n};\n\n// Handle an out-of-band Chromedriver stop event\nhelpers.onChromedriverStop = async function onChromedriverStop (context) {\n  log.warn(`Chromedriver for context ${context} stopped unexpectedly`);\n  if (context === this.curContext) {\n    // we exited unexpectedly while automating the current context and so want\n    // to shut down the session and respond with an error\n    let err = new Error('Chromedriver quit unexpectedly during session');\n    await this.startUnexpectedShutdown(err);\n  } else {\n    // if a Chromedriver in the non-active context barfs, we don't really\n    // care, we'll just make a new one next time we need the context.\n    log.warn(\"Chromedriver quit unexpectedly, but it wasn't the active \" +\n                'context, ignoring');\n    delete this.sessionChromedrivers[context];\n  }\n};\n\n// Intentionally stop all the chromedrivers currently active, and ignore\n// their exit events\nhelpers.stopChromedriverProxies = async function stopChromedriverProxies () {\n  this.suspendChromedriverProxy(); // make sure we turn off the proxy flag\n  for (let context of _.keys(this.sessionChromedrivers)) {\n    let cd = this.sessionChromedrivers[context];\n    log.debug(`Stopping chromedriver for context ${context}`);\n    // stop listening for the stopped state event\n    cd.removeAllListeners(Chromedriver.EVENT_CHANGED);\n    try {\n      await cd.stop();\n    } catch (err) {\n      log.warn(`Error stopping Chromedriver: ${err.message}`);\n    }\n    delete this.sessionChromedrivers[context];\n  }\n};\n\nhelpers.isChromedriverContext = function isChromedriverContext (viewName) {\n  return _.includes(viewName, WEBVIEW_WIN) || viewName === CHROMIUM_WIN;\n};\n\nhelpers.shouldDismissChromeWelcome = function shouldDismissChromeWelcome () {\n  return !!this.opts.chromeOptions &&\n         _.isArray(this.opts.chromeOptions.args) &&\n         this.opts.chromeOptions.args.includes('--no-first-run');\n};\n\nhelpers.dismissChromeWelcome = async function dismissChromeWelcome () {\n  log.info('Trying to dismiss Chrome welcome');\n  let activity = await this.getCurrentActivity();\n  if (activity !== 'org.chromium.chrome.browser.firstrun.FirstRunActivity') {\n    log.info('Chrome welcome dialog never showed up! Continuing');\n    return;\n  }\n  let el = await this.findElOrEls('id', 'com.android.chrome:id/terms_accept', false);\n  await this.click(el.ELEMENT);\n  try {\n    let el = await this.findElOrEls('id', 'com.android.chrome:id/negative_button', false);\n    await this.click(el.ELEMENT);\n  } catch (e) {\n    // DO NOTHING, THIS DEVICE DIDNT LAUNCH THE SIGNIN DIALOG\n    // IT MUST BE A NON GMS DEVICE\n    log.warn(`This device did not show Chrome SignIn dialog, ${e.message}`);\n  }\n};\n\nhelpers.startChromeSession = async function startChromeSession () {\n  log.info('Starting a chrome-based browser session');\n  let opts = _.cloneDeep(this.opts);\n\n  const knownPackages = [\n    'org.chromium.chrome.shell',\n    'com.android.chrome',\n    'com.chrome.beta',\n    'org.chromium.chrome',\n    'org.chromium.webview_shell',\n  ];\n\n  if (_.includes(knownPackages, this.opts.appPackage)) {\n    opts.chromeBundleId = this.opts.appPackage;\n  } else {\n    opts.chromeAndroidActivity = this.opts.appActivity;\n  }\n  this.chromedriver = await this.setupNewChromedriver(opts, this.adb.curDeviceId, this.adb);\n  this.chromedriver.on(Chromedriver.EVENT_CHANGED, (msg) => {\n    if (msg.state === Chromedriver.STATE_STOPPED) {\n      this.onChromedriverStop(CHROMIUM_WIN);\n    }\n  });\n\n  // Now that we have a Chrome session, we ensure that the context is\n  // appropriately set and that this chromedriver is added to the list\n  // of session chromedrivers so we can switch back and forth\n  this.curContext = CHROMIUM_WIN;\n  this.sessionChromedrivers[CHROMIUM_WIN] = this.chromedriver;\n  this.proxyReqRes = this.chromedriver.proxyReq.bind(this.chromedriver);\n  this.proxyCommand = this.chromedriver.jwproxy.command.bind(this.chromedriver.jwproxy);\n  this.jwpProxyActive = true;\n\n  if (this.shouldDismissChromeWelcome()) {\n    // dismiss Chrome welcome dialog\n    await this.dismissChromeWelcome();\n  }\n};\n\n\n/* --------------------------\n * Internal library functions\n * -------------------------- */\n\nasync function setupExistingChromedriver (chromedriver) {\n  // check the status by sending a simple window-based command to ChromeDriver\n  // if there is an error, we want to recreate the ChromeDriver session\n  if (!await chromedriver.hasWorkingWebview()) {\n    log.debug('ChromeDriver is not associated with a window. ' +\n                 'Re-initializing the session.');\n    await chromedriver.restart();\n  }\n  return chromedriver;\n}\n\n/**\n * Find a free port to have Chromedriver listen on.\n *\n * @param {array} [portSpec] - Array which is a list of ports. A list item may\n * also itself be an array of length 2 specifying a start and end port of\n * a range. Some valid port specs:\n *    - [8000, 8001, 8002]\n *    - [[8000, 8005]]\n *    - [8000, [9000, 9100]]\n *\n * @return {number} A free port\n */\nasync function getChromedriverPort (portSpec) {\n  const getPort = B.promisify(PortFinder.getPort, {context: PortFinder});\n\n  // if the user didn't give us any specific information about chromedriver\n  // port ranges, just find any free port\n  if (!portSpec) {\n    const port = await getPort();\n    log.debug(`A port was not given, using random free port: ${port}`);\n    return port;\n  }\n\n  // otherwise find the free port based on a list or range provided by the user\n  log.debug(`Finding a free port for chromedriver using spec ${JSON.stringify(portSpec)}`);\n  let foundPort = null;\n  for (const potentialPort of portSpec) {\n    let port, stopPort;\n    if (_.isArray(potentialPort)) {\n      ([port, stopPort] = potentialPort);\n    } else {\n      port = parseInt(potentialPort, 10); // ensure we have a number and not a string\n      stopPort = port;\n    }\n    try {\n      log.debug(`Checking port range ${port}:${stopPort}`);\n      foundPort = await getPort({port, stopPort});\n      break;\n    } catch (e) {\n      log.debug(`Nothing in port range ${port}:${stopPort} was available`);\n    }\n  }\n\n  if (foundPort === null) {\n    throw new Error(`Could not find a free port for chromedriver using ` +\n                    `chromedriverPorts spec ${JSON.stringify(portSpec)}`);\n  }\n\n  log.debug(`Using free port ${foundPort} for chromedriver`);\n  return foundPort;\n}\n\nhelpers.isChromedriverAutodownloadEnabled = function isChromedriverAutodownloadEnabled () {\n  if (this.isFeatureEnabled(CHROMEDRIVER_AUTODOWNLOAD_FEATURE)) {\n    return true;\n  }\n  log.debug(`Automated Chromedriver download is disabled. ` +\n    `Use '${CHROMEDRIVER_AUTODOWNLOAD_FEATURE}' server feature to enable it`);\n  return false;\n};\n\nhelpers.setupNewChromedriver = async function setupNewChromedriver (opts, curDeviceId, adb, context = null) {\n  if (opts.chromeDriverPort) {\n    log.warn(`The 'chromeDriverPort' capability is deprecated. Please use 'chromedriverPort' instead`);\n    opts.chromedriverPort = opts.chromeDriverPort;\n  }\n\n  if (opts.chromedriverPort) {\n    log.debug(`Using user-specified port ${opts.chromedriverPort} for chromedriver`);\n  } else {\n    // if a single port wasn't given, we'll look for a free one\n    opts.chromedriverPort = await getChromedriverPort(opts.chromedriverPorts);\n  }\n\n  const details = context ? webviewHelpers.getWebviewDetails(adb, context) : undefined;\n  if (!_.isEmpty(details)) {\n    log.debug('Passing web view details to the Chromedriver constructor: ' +\n      JSON.stringify(details, null, 2));\n  }\n\n  const chromedriver = new Chromedriver({\n    port: opts.chromedriverPort,\n    executable: opts.chromedriverExecutable,\n    adb,\n    cmdArgs: opts.chromedriverArgs,\n    verbose: !!opts.showChromedriverLog,\n    executableDir: opts.chromedriverExecutableDir,\n    mappingPath: opts.chromedriverChromeMappingFile,\n    bundleId: opts.chromeBundleId,\n    useSystemExecutable: opts.chromedriverUseSystemExecutable,\n    disableBuildCheck: opts.chromedriverDisableBuildCheck,\n    details,\n    isAutodownloadEnabled: (this || {}).isChromedriverAutodownloadEnabled\n      ? this.isChromedriverAutodownloadEnabled() : undefined,\n  });\n\n  // make sure there are chromeOptions\n  opts.chromeOptions = opts.chromeOptions || {};\n  // try out any prefixed chromeOptions,\n  // and strip the prefix\n  for (const opt of _.keys(opts)) {\n    if (opt.endsWith(':chromeOptions')) {\n      log.warn(`Merging '${opt}' into 'chromeOptions'. This may cause unexpected behavior`);\n      _.merge(opts.chromeOptions, opts[opt]);\n    }\n  }\n\n  const caps = webviewHelpers.createChromedriverCaps(opts, curDeviceId, details);\n  log.debug(`Before starting chromedriver, androidPackage is '${caps.chromeOptions.androidPackage}'`);\n  await chromedriver.start(caps);\n  return chromedriver;\n};\nconst setupNewChromedriver = helpers.setupNewChromedriver;\n\n\nObject.assign(extensions, commands, helpers);\nexport { commands, helpers, setupNewChromedriver };\nexport default extensions;\n"],"file":"lib/commands/context.js","sourceRoot":"../../.."}
|
|
408
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/context.js"],"names":["CHROMEDRIVER_AUTODOWNLOAD_FEATURE","commands","helpers","extensions","getCurrentContext","curContext","defaultContextName","getContexts","webviewsMapping","webviewHelpers","getWebViewsMapping","adb","opts","assignContexts","setContext","name","util","hasValue","WEBVIEW_WIN","defaultWebviewName","contexts","_","includes","errors","NoSuchContextError","switchContext","mobileGetContexts","androidDeviceSocket","ensureWebviewsHavePages","webviewDevtoolsPort","enableWebviewDetailsCollection","Object","assign","isChromeSession","webviews","parseWebviewNames","NATIVE_WIN","log","debug","JSON","stringify","isChromedriverContext","startChromedriverProxy","recreateChromeDriverSessions","stopChromedriverProxies","suspendChromedriverProxy","Error","WEBVIEW_BASE","appPackage","isWebContext","context","cd","sessionChromedrivers","setupExistingChromedriver","cloneDeep","chromeUseRunningApp","extractChromeAndroidPackageFromContextName","androidPackage","match","length","chromeAndroidPackage","has","map","wm","webviewName","knownPackage","KNOWN_CHROME_PACKAGE_NAMES","appState","queryAppState","APP_STATE","RUNNING_IN_BACKGROUND","RUNNING_IN_FOREGROUND","info","setupNewChromedriver","curDeviceId","on","Chromedriver","EVENT_CHANGED","msg","state","STATE_STOPPED","onChromedriverStop","chromedriver","proxyReqRes","proxyReq","bind","proxyCommand","jwproxy","command","jwpProxyActive","warn","err","startUnexpectedShutdown","keys","removeAllListeners","stop","message","viewName","CHROMIUM_WIN","shouldDismissChromeWelcome","chromeOptions","isArray","args","dismissChromeWelcome","activity","getCurrentActivity","el","findElOrEls","click","ELEMENT","e","startChromeSession","knownPackages","chromeBundleId","chromeAndroidActivity","appActivity","hasWorkingWebview","restart","getChromedriverPort","portSpec","getPort","B","promisify","PortFinder","port","foundPort","potentialPort","stopPort","parseInt","isChromedriverAutodownloadEnabled","isFeatureEnabled","chromeDriverPort","chromedriverPort","chromedriverPorts","details","getWebviewDetails","undefined","isEmpty","executable","chromedriverExecutable","cmdArgs","chromedriverArgs","verbose","showChromedriverLog","executableDir","chromedriverExecutableDir","mappingPath","chromedriverChromeMappingFile","bundleId","useSystemExecutable","chromedriverUseSystemExecutable","disableBuildCheck","chromedriverDisableBuildCheck","isAutodownloadEnabled","opt","endsWith","merge","caps","createChromedriverCaps","start"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport Chromedriver from 'appium-chromedriver';\nimport PortFinder from 'portfinder';\nimport B from 'bluebird';\nimport { util } from '@appium/support';\nimport { errors } from '@appium/base-driver';\nimport {\n  default as webviewHelpers,\n  NATIVE_WIN, WEBVIEW_BASE, WEBVIEW_WIN, CHROMIUM_WIN, KNOWN_CHROME_PACKAGE_NAMES\n} from '../webview-helpers';\nimport { APP_STATE } from '../android-helpers';\n\nconst CHROMEDRIVER_AUTODOWNLOAD_FEATURE = 'chromedriver_autodownload';\n\nlet commands = {}, helpers = {}, extensions = {};\n\n\n/* -------------------------------\n * Actual MJSONWP command handlers\n * ------------------------------- */\ncommands.getCurrentContext = async function getCurrentContext () { // eslint-disable-line require-await\n  // if the current context is `null`, indicating no context\n  // explicitly set, it is the default context\n  return this.curContext || this.defaultContextName();\n};\n\ncommands.getContexts = async function getContexts () {\n  const webviewsMapping = await webviewHelpers.getWebViewsMapping(this.adb, this.opts);\n  return this.assignContexts(webviewsMapping);\n};\n\ncommands.setContext = async function setContext (name) {\n  if (!util.hasValue(name)) {\n    name = this.defaultContextName();\n  } else if (name === WEBVIEW_WIN) {\n    // handle setContext \"WEBVIEW\"\n    name = this.defaultWebviewName();\n  }\n  // if we're already in the context we want, do nothing\n  if (name === this.curContext) {\n    return;\n  }\n\n  const webviewsMapping = await webviewHelpers.getWebViewsMapping(this.adb, this.opts);\n  const contexts = this.assignContexts(webviewsMapping);\n  // if the context we want doesn't exist, fail\n  if (!_.includes(contexts, name)) {\n    throw new errors.NoSuchContextError();\n  }\n\n  await this.switchContext(name, webviewsMapping);\n  this.curContext = name;\n};\n\n/**\n * @typedef {Object} WebviewsMapping\n * @property {string} proc The name of the Devtools Unix socket\n * @property {string} webview The web view alias. Looks like `WEBVIEW_`\n * prefix plus PID or package name\n * @property {?Object} info Webview information as it is retrieved by\n * /json/version CDP endpoint\n * @property {?Array<Object>} pages Webview pages list as it is retrieved by\n * /json/list CDP endpoint\n * @propery {?string} webviewName An actual webview name for switching context.\n * This value becomes null when failing to find a PID for a webview.\n *\n * The following json demonstrates the example of WebviewsMapping object.\n * Note that `description` in `page` can be an empty string most likely when it comes to Mobile Chrome)\n * {\n *   \"proc\": \"@webview_devtools_remote_22138\",\n *   \"webview\": \"WEBVIEW_22138\",\n *   \"info\": {\n *     \"Android-Package\": \"io.appium.settings\",\n *     \"Browser\": \"Chrome/74.0.3729.185\",\n *     \"Protocol-Version\": \"1.3\",\n *     \"User-Agent\": \"Mozilla/5.0 (Linux; Android 10; Android SDK built for x86 Build/QSR1.190920.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/74.0.3729.185 Mobile Safari/537.36\",\n *     \"V8-Version\": \"7.4.288.28\",\n *     \"WebKit-Version\": \"537.36 (@22955682f94ce09336197bfb8dffea991fa32f0d)\",\n *     \"webSocketDebuggerUrl\": \"ws://127.0.0.1:10900/devtools/browser\"\n *   },\n *   \"pages\": [\n *     {\n *       \"description\": \"{\\\"attached\\\":true,\\\"empty\\\":false,\\\"height\\\":1458,\\\"screenX\\\":0,\\\"screenY\\\":336,\\\"visible\\\":true,\\\"width\\\":1080}\",\n *       \"devtoolsFrontendUrl\": \"http://chrome-devtools-frontend.appspot.com/serve_rev/@22955682f94ce09336197bfb8dffea991fa32f0d/inspector.html?ws=127.0.0.1:10900/devtools/page/27325CC50B600D31B233F45E09487B1F\",\n *       \"id\": \"27325CC50B600D31B233F45E09487B1F\",\n *       \"title\": \"Releases · appium/appium · GitHub\",\n *       \"type\": \"page\",\n *       \"url\": \"https://github.com/appium/appium/releases\",\n *       \"webSocketDebuggerUrl\": \"ws://127.0.0.1:10900/devtools/page/27325CC50B600D31B233F45E09487B1F\"\n *     }\n *   ],\n *   \"webviewName\": \"WEBVIEW_com.io.appium.setting\"\n * }\n */\n\n/**\n * Returns a webviewsMapping based on CDP endpoints\n *\n * @return {Array<WebviewsMapping>} webviewsMapping\n */\ncommands.mobileGetContexts = async function mobileGetContexts () {\n  const opts = {\n    androidDeviceSocket: this.opts.androidDeviceSocket,\n    ensureWebviewsHavePages: true,\n    webviewDevtoolsPort: this.opts.webviewDevtoolsPort,\n    enableWebviewDetailsCollection: true\n  };\n  return await webviewHelpers.getWebViewsMapping(this.adb, opts);\n};\n\nhelpers.assignContexts = function assignContexts (webviewsMapping) {\n  const opts = Object.assign({isChromeSession: this.isChromeSession}, this.opts);\n  const webviews = webviewHelpers.parseWebviewNames(webviewsMapping, opts);\n  this.contexts = [NATIVE_WIN, ...webviews];\n  this.log.debug(`Available contexts: ${JSON.stringify(this.contexts)}`);\n  return this.contexts;\n};\n\nhelpers.switchContext = async function switchContext (name, webviewsMapping) {\n  // We have some options when it comes to webviews. If we want a\n  // Chromedriver webview, we can only control one at a time.\n  if (this.isChromedriverContext(name)) {\n    // start proxying commands directly to chromedriver\n    await this.startChromedriverProxy(name, webviewsMapping);\n  } else if (this.isChromedriverContext(this.curContext)) {\n    // if we're moving to a non-chromedriver webview, and our current context\n    // _is_ a chromedriver webview, if caps recreateChromeDriverSessions is set\n    // to true then kill chromedriver session using stopChromedriverProxies or\n    // else simply suspend proxying to the latter\n    if (this.opts.recreateChromeDriverSessions) {\n      this.log.debug('recreateChromeDriverSessions set to true; killing existing chromedrivers');\n      await this.stopChromedriverProxies();\n    } else {\n      await this.suspendChromedriverProxy();\n    }\n  } else {\n    throw new Error(`Didn't know how to handle switching to context '${name}'`);\n  }\n};\n\n\n/* ---------------------------------\n * On-object context-related helpers\n * --------------------------------- */\n\n// The reason this is a function and not just a constant is that both android-\n// driver and selendroid-driver use this logic, and each one returns\n// a different default context name\nhelpers.defaultContextName = function defaultContextName () {\n  return NATIVE_WIN;\n};\n\nhelpers.defaultWebviewName = function defaultWebviewName () {\n  return WEBVIEW_BASE + this.opts.appPackage;\n};\n\nhelpers.isWebContext = function isWebContext () {\n  return this.curContext !== null && this.curContext !== NATIVE_WIN;\n};\n\n// Turn on proxying to an existing Chromedriver session or a new one\nhelpers.startChromedriverProxy = async function startChromedriverProxy (context, webviewsMapping) {\n  this.log.debug(`Connecting to chrome-backed webview context '${context}'`);\n\n  let cd;\n  if (this.sessionChromedrivers[context]) {\n    // in the case where we've already set up a chromedriver for a context,\n    // we want to reconnect to it, not create a whole new one\n    this.log.debug(`Found existing Chromedriver for context '${context}'. Using it.`);\n    cd = this.sessionChromedrivers[context];\n    await setupExistingChromedriver(this.log, cd);\n  } else {\n    let opts = _.cloneDeep(this.opts);\n    opts.chromeUseRunningApp = true;\n\n    // if requested, tell chromedriver to attach to the android package we have\n    // associated with the context name, rather than the package of the AUT.\n    // And turn this on by default for chrome--if chrome pops up with a webview\n    // and someone wants to switch to it, we should let chromedriver connect to\n    // chrome rather than staying stuck on the AUT\n    if (opts.extractChromeAndroidPackageFromContextName || context === `${WEBVIEW_BASE}chrome`) {\n      let androidPackage = context.match(`${WEBVIEW_BASE}(.+)`);\n      if (androidPackage && androidPackage.length > 0) {\n        opts.chromeAndroidPackage = androidPackage[1];\n      }\n      if (!opts.extractChromeAndroidPackageFromContextName) {\n        if (_.has(this.opts, 'enableWebviewDetailsCollection') && !this.opts.enableWebviewDetailsCollection) {\n          // When enableWebviewDetailsCollection capability is explicitly disabled, try to identify\n          // chromeAndroidPackage based on contexts, known chrome variant packages and queryAppState result\n          // since webviewsMapping does not have info object\n          const contexts = webviewsMapping.map((wm) => wm.webviewName);\n          for (const knownPackage of KNOWN_CHROME_PACKAGE_NAMES) {\n            if (_.includes(contexts, `${WEBVIEW_BASE}${knownPackage}`)) {\n              continue;\n            }\n            const appState = await this.queryAppState(knownPackage);\n            if (_.includes([APP_STATE.RUNNING_IN_BACKGROUND, APP_STATE.RUNNING_IN_FOREGROUND], appState)) {\n              opts.chromeAndroidPackage = knownPackage;\n              this.log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` +\n                `for context '${context}' by querying states of Chrome app packages`);\n              break;\n            }\n          }\n        } else {\n          for (const wm of webviewsMapping) {\n            if (wm.webviewName === context && _.has(wm?.info, 'Android-Package')) {\n              opts.chromeAndroidPackage = wm.info['Android-Package'];\n              this.log.debug(`Identified chromeAndroidPackage as '${opts.chromeAndroidPackage}' ` +\n                `for context '${context}' by CDP`);\n              break;\n            }\n          }\n        }\n      }\n    }\n\n    cd = await this.setupNewChromedriver(opts, this.adb.curDeviceId, this.adb, context);\n    // bind our stop/exit handler, passing in context so we know which\n    // one stopped unexpectedly\n    cd.on(Chromedriver.EVENT_CHANGED, (msg) => {\n      if (msg.state === Chromedriver.STATE_STOPPED) {\n        this.onChromedriverStop(context);\n      }\n    });\n    // save the chromedriver object under the context\n    this.sessionChromedrivers[context] = cd;\n  }\n  // hook up the local variables so we can proxy this biz\n  this.chromedriver = cd;\n  this.proxyReqRes = this.chromedriver.proxyReq.bind(this.chromedriver);\n  this.proxyCommand = this.chromedriver.jwproxy.command.bind(this.chromedriver.jwproxy);\n  this.jwpProxyActive = true;\n};\n\n// Stop proxying to any Chromedriver\nhelpers.suspendChromedriverProxy = function suspendChromedriverProxy () {\n  this.chromedriver = null;\n  this.proxyReqRes = null;\n  this.proxyCommand = null;\n  this.jwpProxyActive = false;\n};\n\n// Handle an out-of-band Chromedriver stop event\nhelpers.onChromedriverStop = async function onChromedriverStop (context) {\n  this.log.warn(`Chromedriver for context ${context} stopped unexpectedly`);\n  if (context === this.curContext) {\n    // we exited unexpectedly while automating the current context and so want\n    // to shut down the session and respond with an error\n    let err = new Error('Chromedriver quit unexpectedly during session');\n    await this.startUnexpectedShutdown(err);\n  } else {\n    // if a Chromedriver in the non-active context barfs, we don't really\n    // care, we'll just make a new one next time we need the context.\n    this.log.warn(\"Chromedriver quit unexpectedly, but it wasn't the active \" +\n      'context, ignoring');\n    delete this.sessionChromedrivers[context];\n  }\n};\n\n// Intentionally stop all the chromedrivers currently active, and ignore\n// their exit events\nhelpers.stopChromedriverProxies = async function stopChromedriverProxies () {\n  this.suspendChromedriverProxy(); // make sure we turn off the proxy flag\n  for (let context of _.keys(this.sessionChromedrivers)) {\n    let cd = this.sessionChromedrivers[context];\n    this.log.debug(`Stopping chromedriver for context ${context}`);\n    // stop listening for the stopped state event\n    cd.removeAllListeners(Chromedriver.EVENT_CHANGED);\n    try {\n      await cd.stop();\n    } catch (err) {\n      this.log.warn(`Error stopping Chromedriver: ${err.message}`);\n    }\n    delete this.sessionChromedrivers[context];\n  }\n};\n\nhelpers.isChromedriverContext = function isChromedriverContext (viewName) {\n  return _.includes(viewName, WEBVIEW_WIN) || viewName === CHROMIUM_WIN;\n};\n\nhelpers.shouldDismissChromeWelcome = function shouldDismissChromeWelcome () {\n  return !!this.opts.chromeOptions &&\n         _.isArray(this.opts.chromeOptions.args) &&\n         this.opts.chromeOptions.args.includes('--no-first-run');\n};\n\nhelpers.dismissChromeWelcome = async function dismissChromeWelcome () {\n  this.log.info('Trying to dismiss Chrome welcome');\n  let activity = await this.getCurrentActivity();\n  if (activity !== 'org.chromium.chrome.browser.firstrun.FirstRunActivity') {\n    this.log.info('Chrome welcome dialog never showed up! Continuing');\n    return;\n  }\n  let el = await this.findElOrEls('id', 'com.android.chrome:id/terms_accept', false);\n  await this.click(el.ELEMENT);\n  try {\n    let el = await this.findElOrEls('id', 'com.android.chrome:id/negative_button', false);\n    await this.click(el.ELEMENT);\n  } catch (e) {\n    // DO NOTHING, THIS DEVICE DIDNT LAUNCH THE SIGNIN DIALOG\n    // IT MUST BE A NON GMS DEVICE\n    this.log.warn(`This device did not show Chrome SignIn dialog, ${e.message}`);\n  }\n};\n\nhelpers.startChromeSession = async function startChromeSession () {\n  this.log.info('Starting a chrome-based browser session');\n  let opts = _.cloneDeep(this.opts);\n\n  const knownPackages = [\n    'org.chromium.chrome.shell',\n    'com.android.chrome',\n    'com.chrome.beta',\n    'org.chromium.chrome',\n    'org.chromium.webview_shell',\n  ];\n\n  if (_.includes(knownPackages, this.opts.appPackage)) {\n    opts.chromeBundleId = this.opts.appPackage;\n  } else {\n    opts.chromeAndroidActivity = this.opts.appActivity;\n  }\n  this.chromedriver = await this.setupNewChromedriver(opts, this.adb.curDeviceId, this.adb);\n  this.chromedriver.on(Chromedriver.EVENT_CHANGED, (msg) => {\n    if (msg.state === Chromedriver.STATE_STOPPED) {\n      this.onChromedriverStop(CHROMIUM_WIN);\n    }\n  });\n\n  // Now that we have a Chrome session, we ensure that the context is\n  // appropriately set and that this chromedriver is added to the list\n  // of session chromedrivers so we can switch back and forth\n  this.curContext = CHROMIUM_WIN;\n  this.sessionChromedrivers[CHROMIUM_WIN] = this.chromedriver;\n  this.proxyReqRes = this.chromedriver.proxyReq.bind(this.chromedriver);\n  this.proxyCommand = this.chromedriver.jwproxy.command.bind(this.chromedriver.jwproxy);\n  this.jwpProxyActive = true;\n\n  if (this.shouldDismissChromeWelcome()) {\n    // dismiss Chrome welcome dialog\n    await this.dismissChromeWelcome();\n  }\n};\n\n\n/* --------------------------\n * Internal library functions\n * -------------------------- */\n\nasync function setupExistingChromedriver (log, chromedriver) {\n  // check the status by sending a simple window-based command to ChromeDriver\n  // if there is an error, we want to recreate the ChromeDriver session\n  if (!await chromedriver.hasWorkingWebview()) {\n    log.debug('ChromeDriver is not associated with a window. ' +\n                 'Re-initializing the session.');\n    await chromedriver.restart();\n  }\n  return chromedriver;\n}\n\n/**\n * Find a free port to have Chromedriver listen on.\n *\n * @param {array} portSpec - Array which is a list of ports. A list item may\n * also itself be an array of length 2 specifying a start and end port of\n * a range. Some valid port specs:\n *    - [8000, 8001, 8002]\n *    - [[8000, 8005]]\n *    - [8000, [9000, 9100]]\n * @param {Object?} log Logger instance\n *\n * @return {number} A free port\n */\nasync function getChromedriverPort (portSpec, log = null) {\n  const getPort = B.promisify(PortFinder.getPort, {context: PortFinder});\n\n  // if the user didn't give us any specific information about chromedriver\n  // port ranges, just find any free port\n  if (!portSpec) {\n    const port = await getPort();\n    log?.debug(`A port was not given, using random free port: ${port}`);\n    return port;\n  }\n\n  // otherwise find the free port based on a list or range provided by the user\n  log?.debug(`Finding a free port for chromedriver using spec ${JSON.stringify(portSpec)}`);\n  let foundPort = null;\n  for (const potentialPort of portSpec) {\n    let port, stopPort;\n    if (_.isArray(potentialPort)) {\n      ([port, stopPort] = potentialPort);\n    } else {\n      port = parseInt(potentialPort, 10); // ensure we have a number and not a string\n      stopPort = port;\n    }\n    try {\n      log?.debug(`Checking port range ${port}:${stopPort}`);\n      foundPort = await getPort({port, stopPort});\n      break;\n    } catch (e) {\n      log?.debug(`Nothing in port range ${port}:${stopPort} was available`);\n    }\n  }\n\n  if (foundPort === null) {\n    throw new Error(`Could not find a free port for chromedriver using ` +\n                    `chromedriverPorts spec ${JSON.stringify(portSpec)}`);\n  }\n\n  log?.debug(`Using free port ${foundPort} for chromedriver`);\n  return foundPort;\n}\n\nhelpers.isChromedriverAutodownloadEnabled = function isChromedriverAutodownloadEnabled () {\n  if (this.isFeatureEnabled(CHROMEDRIVER_AUTODOWNLOAD_FEATURE)) {\n    return true;\n  }\n  this?.log?.debug(`Automated Chromedriver download is disabled. ` +\n    `Use '${CHROMEDRIVER_AUTODOWNLOAD_FEATURE}' server feature to enable it`);\n  return false;\n};\n\nhelpers.setupNewChromedriver = async function setupNewChromedriver (opts, curDeviceId, adb, context = null) {\n  if (opts.chromeDriverPort) {\n    this?.log?.warn(`The 'chromeDriverPort' capability is deprecated. Please use 'chromedriverPort' instead`);\n    opts.chromedriverPort = opts.chromeDriverPort;\n  }\n\n  if (opts.chromedriverPort) {\n    this?.log?.debug(`Using user-specified port ${opts.chromedriverPort} for chromedriver`);\n  } else {\n    // if a single port wasn't given, we'll look for a free one\n    opts.chromedriverPort = await getChromedriverPort(opts.chromedriverPorts, this?.log);\n  }\n\n  const details = context ? webviewHelpers.getWebviewDetails(adb, context) : undefined;\n  if (!_.isEmpty(details)) {\n    this?.log?.debug('Passing web view details to the Chromedriver constructor: ' +\n      JSON.stringify(details, null, 2));\n  }\n\n  const chromedriver = new Chromedriver({\n    port: opts.chromedriverPort,\n    executable: opts.chromedriverExecutable,\n    adb,\n    cmdArgs: opts.chromedriverArgs,\n    verbose: !!opts.showChromedriverLog,\n    executableDir: opts.chromedriverExecutableDir,\n    mappingPath: opts.chromedriverChromeMappingFile,\n    bundleId: opts.chromeBundleId,\n    useSystemExecutable: opts.chromedriverUseSystemExecutable,\n    disableBuildCheck: opts.chromedriverDisableBuildCheck,\n    details,\n    isAutodownloadEnabled: this?.isChromedriverAutodownloadEnabled?.()\n  });\n\n  // make sure there are chromeOptions\n  opts.chromeOptions = opts.chromeOptions || {};\n  // try out any prefixed chromeOptions,\n  // and strip the prefix\n  for (const opt of _.keys(opts)) {\n    if (opt.endsWith(':chromeOptions')) {\n      this?.log?.warn(`Merging '${opt}' into 'chromeOptions'. This may cause unexpected behavior`);\n      _.merge(opts.chromeOptions, opts[opt]);\n    }\n  }\n\n  const caps = webviewHelpers.createChromedriverCaps(opts, curDeviceId, details);\n  this?.log?.debug(`Before starting chromedriver, androidPackage is '${caps.chromeOptions.androidPackage}'`);\n  await chromedriver.start(caps);\n  return chromedriver;\n};\nconst setupNewChromedriver = helpers.setupNewChromedriver;\n\n\nObject.assign(extensions, commands, helpers);\nexport { commands, helpers, setupNewChromedriver };\nexport default extensions;\n"],"file":"lib/commands/context.js","sourceRoot":"../../.."}
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
3
|
Object.defineProperty(exports, "__esModule", {
|
|
6
4
|
value: true
|
|
7
5
|
});
|
|
@@ -9,8 +7,6 @@ exports.default = exports.commands = void 0;
|
|
|
9
7
|
|
|
10
8
|
require("source-map-support/register");
|
|
11
9
|
|
|
12
|
-
var _logger = _interopRequireDefault(require("../logger"));
|
|
13
|
-
|
|
14
10
|
const commands = {};
|
|
15
11
|
exports.commands = commands;
|
|
16
12
|
|
|
@@ -20,7 +16,7 @@ commands.endCoverage = async function endCoverage(intentToBroadcast, ecOnDeviceP
|
|
|
20
16
|
await this.adb.broadcastProcessEnd(intentToBroadcast, this.appProcess);
|
|
21
17
|
return await this.pullFile(ecOnDevicePath);
|
|
22
18
|
} catch (err) {
|
|
23
|
-
|
|
19
|
+
this.log.warn(`Error ending test coverage: ${err.message}`);
|
|
24
20
|
}
|
|
25
21
|
|
|
26
22
|
return '';
|
|
@@ -30,4 +26,4 @@ var _default = commands;
|
|
|
30
26
|
exports.default = _default;require('source-map-support').install();
|
|
31
27
|
|
|
32
28
|
|
|
33
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy9jb3ZlcmFnZS5qcyJdLCJuYW1lcyI6WyJjb21tYW5kcyIsImVuZENvdmVyYWdlIiwiaW50ZW50VG9Ccm9hZGNhc3QiLCJlY09uRGV2aWNlUGF0aCIsImFkYiIsInJpbXJhZiIsImJyb2FkY2FzdFByb2Nlc3NFbmQiLCJhcHBQcm9jZXNzIiwicHVsbEZpbGUiLCJlcnIiLCJsb2ciLCJ3YXJuIiwibWVzc2FnZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsTUFBTUEsUUFBUSxHQUFHLEVBQWpCOzs7QUFHQUEsUUFBUSxDQUFDQyxXQUFULEdBQXVCLGVBQWVBLFdBQWYsQ0FBNEJDLGlCQUE1QixFQUErQ0MsY0FBL0MsRUFBK0Q7QUFDcEYsTUFBSTtBQUVGLFVBQU0sS0FBS0MsR0FBTCxDQUFTQyxNQUFULENBQWdCRixjQUFoQixDQUFOO0FBQ0EsVUFBTSxLQUFLQyxHQUFMLENBQVNFLG1CQUFULENBQTZCSixpQkFBN0IsRUFBZ0QsS0FBS0ssVUFBckQsQ0FBTjtBQUNBLFdBQU8sTUFBTSxLQUFLQyxRQUFMLENBQWNMLGNBQWQsQ0FBYjtBQUNELEdBTEQsQ0FLRSxPQUFPTSxHQUFQLEVBQVk7QUFDWixTQUFLQyxHQUFMLENBQVNDLElBQVQsQ0FBZSwrQkFBOEJGLEdBQUcsQ0FBQ0csT0FBUSxFQUF6RDtBQUNEOztBQUNELFNBQU8sRUFBUDtBQUNELENBVkQ7O2VBY2VaLFEiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBjb21tYW5kcyA9IHt9O1xuXG5cbmNvbW1hbmRzLmVuZENvdmVyYWdlID0gYXN5bmMgZnVuY3Rpb24gZW5kQ292ZXJhZ2UgKGludGVudFRvQnJvYWRjYXN0LCBlY09uRGV2aWNlUGF0aCkge1xuICB0cnkge1xuICAgIC8vIGVuc3VyZSB0aGUgZWMgd2UncmUgcHVsbGluZyBpcyBuZXdseSBjcmVhdGVkIGFzIGEgcmVzdWx0IG9mIHRoZSBpbnRlbnQuXG4gICAgYXdhaXQgdGhpcy5hZGIucmltcmFmKGVjT25EZXZpY2VQYXRoKTtcbiAgICBhd2FpdCB0aGlzLmFkYi5icm9hZGNhc3RQcm9jZXNzRW5kKGludGVudFRvQnJvYWRjYXN0LCB0aGlzLmFwcFByb2Nlc3MpO1xuICAgIHJldHVybiBhd2FpdCB0aGlzLnB1bGxGaWxlKGVjT25EZXZpY2VQYXRoKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgdGhpcy5sb2cud2FybihgRXJyb3IgZW5kaW5nIHRlc3QgY292ZXJhZ2U6ICR7ZXJyLm1lc3NhZ2V9YCk7XG4gIH1cbiAgcmV0dXJuICcnO1xufTtcblxuXG5leHBvcnQgeyBjb21tYW5kcyB9O1xuZXhwb3J0IGRlZmF1bHQgY29tbWFuZHM7XG4iXSwiZmlsZSI6ImxpYi9jb21tYW5kcy9jb3ZlcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
|