appium-remote-debugger 10.0.2 → 10.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +14 -0
- package/build/index.js +18 -33
- package/build/lib/atoms.d.ts +17 -0
- package/build/lib/atoms.d.ts.map +1 -0
- package/build/lib/atoms.js +75 -50
- package/build/lib/atoms.js.map +1 -1
- package/build/lib/logger.d.ts +3 -0
- package/build/lib/logger.d.ts.map +1 -0
- package/build/lib/logger.js +5 -11
- package/build/lib/logger.js.map +1 -1
- package/build/lib/mixins/connect.d.ts +125 -0
- package/build/lib/mixins/connect.d.ts.map +1 -0
- package/build/lib/mixins/connect.js +299 -202
- package/build/lib/mixins/connect.js.map +1 -1
- package/build/lib/mixins/events.d.ts +7 -0
- package/build/lib/mixins/events.d.ts.map +1 -0
- package/build/lib/mixins/events.js +7 -12
- package/build/lib/mixins/events.js.map +1 -1
- package/build/lib/mixins/execute.d.ts +38 -0
- package/build/lib/mixins/execute.d.ts.map +1 -0
- package/build/lib/mixins/execute.js +162 -122
- package/build/lib/mixins/execute.js.map +1 -1
- package/build/lib/mixins/index.d.ts +5 -0
- package/build/lib/mixins/index.d.ts.map +1 -0
- package/build/lib/mixins/index.js +14 -23
- package/build/lib/mixins/index.js.map +1 -1
- package/build/lib/mixins/message-handlers.d.ts +92 -0
- package/build/lib/mixins/message-handlers.d.ts.map +1 -0
- package/build/lib/mixins/message-handlers.js +160 -97
- package/build/lib/mixins/message-handlers.js.map +1 -1
- package/build/lib/mixins/navigate.d.ts +92 -0
- package/build/lib/mixins/navigate.d.ts.map +1 -0
- package/build/lib/mixins/navigate.js +199 -141
- package/build/lib/mixins/navigate.js.map +1 -1
- package/build/lib/protocol/index.d.ts +14 -0
- package/build/lib/protocol/index.d.ts.map +1 -0
- package/build/lib/protocol/index.js +192 -118
- package/build/lib/protocol/index.js.map +1 -1
- package/build/lib/remote-debugger-real-device.d.ts +6 -0
- package/build/lib/remote-debugger-real-device.d.ts.map +1 -0
- package/build/lib/remote-debugger-real-device.js +29 -32
- package/build/lib/remote-debugger-real-device.js.map +1 -1
- package/build/lib/remote-debugger.d.ts +119 -0
- package/build/lib/remote-debugger.d.ts.map +1 -0
- package/build/lib/remote-debugger.js +256 -226
- package/build/lib/remote-debugger.js.map +1 -1
- package/build/lib/rpc/index.d.ts +4 -0
- package/build/lib/rpc/index.d.ts.map +1 -0
- package/build/lib/rpc/index.js +10 -21
- package/build/lib/rpc/index.js.map +1 -1
- package/build/lib/rpc/remote-messages.d.ts +51 -0
- package/build/lib/rpc/remote-messages.d.ts.map +1 -0
- package/build/lib/rpc/remote-messages.js +203 -224
- package/build/lib/rpc/remote-messages.js.map +1 -1
- package/build/lib/rpc/rpc-client-real-device.d.ts +6 -0
- package/build/lib/rpc/rpc-client-real-device.d.ts.map +1 -0
- package/build/lib/rpc/rpc-client-real-device.js +43 -49
- package/build/lib/rpc/rpc-client-real-device.js.map +1 -1
- package/build/lib/rpc/rpc-client-simulator.d.ts +15 -0
- package/build/lib/rpc/rpc-client-simulator.d.ts.map +1 -0
- package/build/lib/rpc/rpc-client-simulator.js +138 -125
- package/build/lib/rpc/rpc-client-simulator.js.map +1 -1
- package/build/lib/rpc/rpc-client.d.ts +142 -0
- package/build/lib/rpc/rpc-client.d.ts.map +1 -0
- package/build/lib/rpc/rpc-client.js +559 -418
- package/build/lib/rpc/rpc-client.js.map +1 -1
- package/build/lib/rpc/rpc-message-handler.d.ts +13 -0
- package/build/lib/rpc/rpc-message-handler.d.ts.map +1 -0
- package/build/lib/rpc/rpc-message-handler.js +181 -166
- package/build/lib/rpc/rpc-message-handler.js.map +1 -1
- package/build/lib/utils.d.ts +61 -0
- package/build/lib/utils.d.ts.map +1 -0
- package/build/lib/utils.js +241 -155
- package/build/lib/utils.js.map +1 -1
- package/lib/atoms.js +25 -4
- package/lib/mixins/connect.js +102 -7
- package/lib/mixins/execute.js +46 -13
- package/lib/mixins/message-handlers.js +44 -1
- package/lib/mixins/navigate.js +55 -3
- package/lib/remote-debugger.js +112 -0
- package/lib/rpc/rpc-client-real-device.js +1 -6
- package/lib/rpc/rpc-client-simulator.js +7 -1
- package/lib/rpc/rpc-client.js +106 -6
- package/lib/rpc/rpc-message-handler.js +1 -1
- package/lib/utils.js +31 -1
- package/package.json +26 -16
|
@@ -1,232 +1,329 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
require("
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
var _support = require("@appium/support");
|
|
13
|
-
var _asyncbox = require("asyncbox");
|
|
14
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const logger_1 = __importDefault(require("../logger"));
|
|
7
|
+
const utils_1 = require("../utils");
|
|
8
|
+
const events_1 = __importDefault(require("./events"));
|
|
9
|
+
const support_1 = require("@appium/support");
|
|
10
|
+
const asyncbox_1 = require("asyncbox");
|
|
11
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
15
12
|
const APP_CONNECT_TIMEOUT_MS = 0;
|
|
16
13
|
const APP_CONNECT_INTERVAL_MS = 100;
|
|
17
14
|
const SELECT_APP_RETRIES = 20;
|
|
18
15
|
const SELECT_APP_RETRY_SLEEP_MS = 500;
|
|
19
16
|
const SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';
|
|
20
17
|
const BLANK_PAGE_URL = 'about:blank';
|
|
18
|
+
/**
|
|
19
|
+
* @typedef {Object} AppPages
|
|
20
|
+
* @property {string} appIdKey
|
|
21
|
+
* @property {Record<string, any>} pageDict
|
|
22
|
+
*/
|
|
23
|
+
/**
|
|
24
|
+
* @typedef {Object} App
|
|
25
|
+
* @property {string} id
|
|
26
|
+
* @property {string} bundleId
|
|
27
|
+
*/
|
|
28
|
+
/**
|
|
29
|
+
*
|
|
30
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
31
|
+
*/
|
|
21
32
|
async function setConnectionKey() {
|
|
22
|
-
|
|
23
|
-
|
|
33
|
+
logger_1.default.debug('Sending connection key request');
|
|
34
|
+
if (!this.rpcClient) {
|
|
35
|
+
throw new Error('rpcClient is undefined. Is the debugger connected?');
|
|
36
|
+
}
|
|
37
|
+
// send but only wait to make sure the socket worked
|
|
38
|
+
// as response from Web Inspector can take a long time
|
|
39
|
+
await this.rpcClient.send('setConnectionKey', {}, false);
|
|
24
40
|
}
|
|
41
|
+
/**
|
|
42
|
+
*
|
|
43
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
44
|
+
*/
|
|
25
45
|
async function connect(timeout = APP_CONNECT_TIMEOUT_MS) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
46
|
+
this.setup();
|
|
47
|
+
// initialize the rpc client
|
|
48
|
+
this.initRpcClient();
|
|
49
|
+
if (!this.rpcClient) {
|
|
50
|
+
throw new Error('rpcClient is undefined. Is the debugger connected?');
|
|
51
|
+
}
|
|
52
|
+
// listen for basic debugger-level events
|
|
53
|
+
this.rpcClient.on('_rpc_reportSetup:', lodash_1.default.noop);
|
|
54
|
+
this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));
|
|
55
|
+
this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));
|
|
56
|
+
this.rpcClient.on('_rpc_applicationConnected:', this.onAppConnect.bind(this));
|
|
57
|
+
this.rpcClient.on('_rpc_applicationDisconnected:', this.onAppDisconnect.bind(this));
|
|
58
|
+
this.rpcClient.on('_rpc_applicationUpdated:', this.onAppUpdate.bind(this));
|
|
59
|
+
this.rpcClient.on('_rpc_reportConnectedDriverList:', this.onConnectedDriverList.bind(this));
|
|
60
|
+
this.rpcClient.on('_rpc_reportCurrentState:', this.onCurrentState.bind(this));
|
|
61
|
+
this.rpcClient.on('Page.frameDetached', this.frameDetached.bind(this));
|
|
62
|
+
await this.rpcClient.connect();
|
|
63
|
+
// get the connection information about the app
|
|
64
|
+
try {
|
|
65
|
+
this.setConnectionKey();
|
|
66
|
+
if (timeout) {
|
|
67
|
+
logger_1.default.debug(`Waiting up to ${timeout}ms for applications to be reported`);
|
|
68
|
+
try {
|
|
69
|
+
await (0, asyncbox_1.waitForCondition)(() => !lodash_1.default.isEmpty(this.appDict), {
|
|
70
|
+
waitMs: timeout,
|
|
71
|
+
intervalMs: APP_CONNECT_INTERVAL_MS,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
catch (err) {
|
|
75
|
+
logger_1.default.debug(`Timed out waiting for applications to be reported`);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return this.appDict || {};
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
logger_1.default.error(`Error setting connection key: ${err.message}`);
|
|
82
|
+
await this.disconnect();
|
|
83
|
+
throw err;
|
|
84
|
+
}
|
|
57
85
|
}
|
|
86
|
+
/**
|
|
87
|
+
*
|
|
88
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
89
|
+
* @returns {Promise<void>}
|
|
90
|
+
*/
|
|
58
91
|
async function disconnect() {
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
92
|
+
if (this.rpcClient) {
|
|
93
|
+
await this.rpcClient.disconnect();
|
|
94
|
+
}
|
|
95
|
+
this.emit(events_1.default.EVENT_DISCONNECT, true);
|
|
96
|
+
this.teardown();
|
|
64
97
|
}
|
|
98
|
+
/**
|
|
99
|
+
*
|
|
100
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
101
|
+
* @param {string?} currentUrl
|
|
102
|
+
* @param {number} [maxTries]
|
|
103
|
+
* @param {boolean} [ignoreAboutBlankUrl]
|
|
104
|
+
* @returns {Promise<AppPages[]>}
|
|
105
|
+
*/
|
|
65
106
|
async function selectApp(currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
pageDict
|
|
78
|
-
} = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);
|
|
79
|
-
if (!appIdKey || !pageDict) {
|
|
80
|
-
_logger.default.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);
|
|
81
|
-
}
|
|
82
|
-
if (this.appIdKey !== appIdKey) {
|
|
83
|
-
_logger.default.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);
|
|
84
|
-
this.appIdKey = appIdKey;
|
|
85
|
-
}
|
|
86
|
-
logApplicationDictionary(this.appDict);
|
|
87
|
-
const pageArray = _lodash.default.isEmpty(this.appDict[appIdKey].pageArray) ? (0, _utils.pageArrayFromDict)(pageDict) : this.appDict[appIdKey].pageArray;
|
|
88
|
-
_logger.default.debug(`Finally selecting app ${this.appIdKey}: ${(0, _utils.simpleStringify)(pageArray)}`);
|
|
89
|
-
let fullPageArray = [];
|
|
90
|
-
for (const [app, info] of _lodash.default.toPairs(this.appDict)) {
|
|
91
|
-
if (!_lodash.default.isArray(info.pageArray) || !info.isActive) {
|
|
92
|
-
continue;
|
|
93
|
-
}
|
|
94
|
-
const id = app.replace('PID:', '');
|
|
95
|
-
for (const page of info.pageArray) {
|
|
96
|
-
if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {
|
|
97
|
-
let pageDict = _lodash.default.clone(page);
|
|
98
|
-
pageDict.id = `${id}.${pageDict.id}`;
|
|
99
|
-
pageDict.bundleId = info.bundleId;
|
|
100
|
-
fullPageArray.push(pageDict);
|
|
107
|
+
logger_1.default.debug('Selecting application');
|
|
108
|
+
if (!this.rpcClient) {
|
|
109
|
+
throw new Error('rpcClient is undefined. Is the debugger connected?');
|
|
110
|
+
}
|
|
111
|
+
const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;
|
|
112
|
+
this.rpcClient.shouldCheckForTarget = false;
|
|
113
|
+
try {
|
|
114
|
+
const timer = new support_1.timing.Timer().start();
|
|
115
|
+
if (!this.appDict || lodash_1.default.isEmpty(this.appDict)) {
|
|
116
|
+
logger_1.default.debug('No applications currently connected.');
|
|
117
|
+
return [];
|
|
101
118
|
}
|
|
102
|
-
|
|
119
|
+
const { appIdKey, pageDict } = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);
|
|
120
|
+
// if, after all this, we have no dictionary, we have failed
|
|
121
|
+
if (!appIdKey || !pageDict) {
|
|
122
|
+
logger_1.default.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);
|
|
123
|
+
}
|
|
124
|
+
if (this.appIdKey !== appIdKey) {
|
|
125
|
+
logger_1.default.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);
|
|
126
|
+
this.appIdKey = appIdKey;
|
|
127
|
+
}
|
|
128
|
+
logApplicationDictionary(this.appDict);
|
|
129
|
+
// translate the dictionary into a useful form, and return to sender
|
|
130
|
+
const pageArray = lodash_1.default.isEmpty(this.appDict[appIdKey].pageArray)
|
|
131
|
+
? (0, utils_1.pageArrayFromDict)(pageDict)
|
|
132
|
+
: this.appDict[appIdKey].pageArray;
|
|
133
|
+
logger_1.default.debug(`Finally selecting app ${this.appIdKey}: ${(0, utils_1.simpleStringify)(pageArray)}`);
|
|
134
|
+
let fullPageArray = [];
|
|
135
|
+
for (const [app, info] of lodash_1.default.toPairs(this.appDict)) {
|
|
136
|
+
if (!lodash_1.default.isArray(info.pageArray) || !info.isActive) {
|
|
137
|
+
continue;
|
|
138
|
+
}
|
|
139
|
+
const id = app.replace('PID:', '');
|
|
140
|
+
for (const page of info.pageArray) {
|
|
141
|
+
if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {
|
|
142
|
+
let pageDict = lodash_1.default.clone(page);
|
|
143
|
+
pageDict.id = `${id}.${pageDict.id}`;
|
|
144
|
+
pageDict.bundleId = info.bundleId;
|
|
145
|
+
fullPageArray.push(pageDict);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
logger_1.default.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
|
|
150
|
+
return fullPageArray;
|
|
151
|
+
}
|
|
152
|
+
finally {
|
|
153
|
+
this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;
|
|
103
154
|
}
|
|
104
|
-
_logger.default.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
|
|
105
|
-
return fullPageArray;
|
|
106
|
-
} finally {
|
|
107
|
-
this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;
|
|
108
|
-
}
|
|
109
155
|
}
|
|
156
|
+
/**
|
|
157
|
+
*
|
|
158
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
159
|
+
* @param {string?} currentUrl
|
|
160
|
+
* @param {number} maxTries
|
|
161
|
+
* @param {boolean} ignoreAboutBlankUrl
|
|
162
|
+
* @returns {Promise<AppPages?>}
|
|
163
|
+
*/
|
|
110
164
|
async function searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl) {
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
165
|
+
const bundleIds = this.includeSafari && !this.isSafari
|
|
166
|
+
? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID]
|
|
167
|
+
: [this.bundleId, ...this.additionalBundleIds];
|
|
168
|
+
try {
|
|
169
|
+
return await (0, asyncbox_1.retryInterval)(maxTries, SELECT_APP_RETRY_SLEEP_MS, async (retryCount) => {
|
|
170
|
+
if (!this.rpcClient) {
|
|
171
|
+
throw new Error('rpcClient is undefined. Is the debugger connected?');
|
|
172
|
+
}
|
|
173
|
+
logApplicationDictionary(this.appDict);
|
|
174
|
+
const possibleAppIds = (0, utils_1.getPossibleDebuggerAppKeys)(bundleIds, this.appDict);
|
|
175
|
+
logger_1.default.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);
|
|
176
|
+
for (const attemptedAppIdKey of possibleAppIds) {
|
|
177
|
+
try {
|
|
178
|
+
if (!this.appDict[attemptedAppIdKey].isActive) {
|
|
179
|
+
logger_1.default.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);
|
|
180
|
+
continue;
|
|
181
|
+
}
|
|
182
|
+
logger_1.default.debug(`Attempting app '${attemptedAppIdKey}'`);
|
|
183
|
+
const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey);
|
|
184
|
+
// in iOS 8.2 the connect logic happens, but with an empty dictionary
|
|
185
|
+
// which leads to the remote debugger getting disconnected, and into a loop
|
|
186
|
+
if (lodash_1.default.isEmpty(pageDict)) {
|
|
187
|
+
logger_1.default.debug('Empty page dictionary received. Trying again.');
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
// save the page array for this app
|
|
191
|
+
this.appDict[appIdKey].pageArray = (0, utils_1.pageArrayFromDict)(pageDict);
|
|
192
|
+
// if we are looking for a particular url, make sure we
|
|
193
|
+
// have the right page. Ignore empty or undefined urls.
|
|
194
|
+
// Ignore about:blank if requested.
|
|
195
|
+
const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);
|
|
196
|
+
if (result) {
|
|
197
|
+
return result;
|
|
198
|
+
}
|
|
199
|
+
if (currentUrl) {
|
|
200
|
+
logger_1.default.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
logger_1.default.debug('Received app, but no match was found. Trying again.');
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
catch (err) {
|
|
207
|
+
logger_1.default.debug(`Error checking application: '${err.message}'. Retrying connection`);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
retryCount++;
|
|
211
|
+
throw new Error('Failed to find an app to select');
|
|
212
|
+
}, 0);
|
|
213
|
+
}
|
|
214
|
+
catch (ign) {
|
|
215
|
+
logger_1.default.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);
|
|
216
|
+
}
|
|
217
|
+
return null;
|
|
149
218
|
}
|
|
219
|
+
/**
|
|
220
|
+
*
|
|
221
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
222
|
+
* @param {Record<string, any>} appsDict
|
|
223
|
+
* @param {string?} currentUrl
|
|
224
|
+
* @param {boolean} [ignoreAboutBlankUrl]
|
|
225
|
+
* @returns {AppPages?}
|
|
226
|
+
*/
|
|
150
227
|
function searchForPage(appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
}
|
|
164
|
-
return null;
|
|
228
|
+
for (const appDict of lodash_1.default.values(appsDict)) {
|
|
229
|
+
if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {
|
|
230
|
+
continue;
|
|
231
|
+
}
|
|
232
|
+
for (const dict of appDict.pageArray) {
|
|
233
|
+
if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) &&
|
|
234
|
+
(!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {
|
|
235
|
+
return { appIdKey: appDict.id, pageDict: dict };
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
return null;
|
|
165
240
|
}
|
|
241
|
+
/**
|
|
242
|
+
*
|
|
243
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
244
|
+
* @param {string} appIdKey
|
|
245
|
+
* @param {string} pageIdKey
|
|
246
|
+
* @param {boolean} [skipReadyCheck]
|
|
247
|
+
* @returns {Promise<void>}
|
|
248
|
+
*/
|
|
166
249
|
async function selectPage(appIdKey, pageIdKey, skipReadyCheck = false) {
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
250
|
+
this.appIdKey = `PID:${appIdKey}`;
|
|
251
|
+
this.pageIdKey = pageIdKey;
|
|
252
|
+
logger_1.default.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);
|
|
253
|
+
if (!this.rpcClient) {
|
|
254
|
+
throw new Error('rpcClient is undefined. Is the debugger connected?');
|
|
255
|
+
}
|
|
256
|
+
const timer = new support_1.timing.Timer().start();
|
|
257
|
+
await this.rpcClient.selectPage(this.appIdKey, pageIdKey);
|
|
258
|
+
// make sure everything is ready to go
|
|
259
|
+
if (!skipReadyCheck && !await this.checkPageIsReady()) {
|
|
260
|
+
await this.pageUnload();
|
|
261
|
+
}
|
|
262
|
+
logger_1.default.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
|
|
176
263
|
}
|
|
264
|
+
/**
|
|
265
|
+
*
|
|
266
|
+
* @param {Record<string, any>} apps
|
|
267
|
+
* @returns {void}
|
|
268
|
+
*/
|
|
177
269
|
function logApplicationDictionary(apps) {
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
270
|
+
function getValueString(key, value) {
|
|
271
|
+
if (lodash_1.default.isFunction(value)) {
|
|
272
|
+
return '[Function]';
|
|
273
|
+
}
|
|
274
|
+
if (key === 'pageArray' && !lodash_1.default.isArray(value)) {
|
|
275
|
+
return `"Waiting for data"`;
|
|
276
|
+
}
|
|
277
|
+
return JSON.stringify(value);
|
|
278
|
+
}
|
|
279
|
+
logger_1.default.debug('Current applications available:');
|
|
280
|
+
for (const [app, info] of lodash_1.default.toPairs(apps)) {
|
|
281
|
+
logger_1.default.debug(` Application: "${app}"`);
|
|
282
|
+
for (const [key, value] of lodash_1.default.toPairs(info)) {
|
|
283
|
+
if (key === 'pageArray' && Array.isArray(value) && value.length) {
|
|
284
|
+
logger_1.default.debug(` ${key}:`);
|
|
285
|
+
for (const page of value) {
|
|
286
|
+
let prefix = '- ';
|
|
287
|
+
for (const [k, v] of lodash_1.default.toPairs(page)) {
|
|
288
|
+
logger_1.default.debug(` ${prefix}${k}: ${JSON.stringify(v)}`);
|
|
289
|
+
prefix = ' ';
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
else {
|
|
294
|
+
const valueString = getValueString(key, value);
|
|
295
|
+
logger_1.default.debug(` ${key}: ${valueString}`);
|
|
296
|
+
}
|
|
199
297
|
}
|
|
200
|
-
} else {
|
|
201
|
-
const valueString = getValueString(key, value);
|
|
202
|
-
_logger.default.debug(` ${key}: ${valueString}`);
|
|
203
|
-
}
|
|
204
298
|
}
|
|
205
|
-
}
|
|
206
299
|
}
|
|
300
|
+
/**
|
|
301
|
+
*
|
|
302
|
+
* @this {import('../remote-debugger').RemoteDebugger}
|
|
303
|
+
* @param {Record<string, any>} dict
|
|
304
|
+
* @returns {void}
|
|
305
|
+
*/
|
|
207
306
|
function updateAppsWithDict(dict) {
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
entry
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
307
|
+
// get the dictionary entry into a nice form, and add it to the
|
|
308
|
+
// application dictionary
|
|
309
|
+
this.appDict = this.appDict || {};
|
|
310
|
+
let [id, entry] = (0, utils_1.appInfoFromDict)(dict);
|
|
311
|
+
if (this.appDict[id]) {
|
|
312
|
+
// preserve the page dictionary for this entry
|
|
313
|
+
entry.pageArray = this.appDict[id].pageArray;
|
|
314
|
+
}
|
|
315
|
+
this.appDict[id] = entry;
|
|
316
|
+
// add a promise to get the page dictionary
|
|
317
|
+
if (lodash_1.default.isUndefined(entry.pageArray)) {
|
|
318
|
+
entry.pageArray = (0, utils_1.deferredPromise)();
|
|
319
|
+
}
|
|
320
|
+
// try to get the app id from our connected apps
|
|
321
|
+
if (!this.appIdKey) {
|
|
322
|
+
this.appIdKey = (0, utils_1.getDebuggerAppKey)(this.bundleId, this.appDict);
|
|
323
|
+
}
|
|
220
324
|
}
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
disconnect,
|
|
225
|
-
selectApp,
|
|
226
|
-
searchForApp,
|
|
227
|
-
searchForPage,
|
|
228
|
-
selectPage,
|
|
229
|
-
updateAppsWithDict
|
|
325
|
+
exports.default = {
|
|
326
|
+
setConnectionKey, connect, disconnect, selectApp,
|
|
327
|
+
searchForApp, searchForPage, selectPage, updateAppsWithDict
|
|
230
328
|
};
|
|
231
|
-
|
|
232
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","_interopRequireDefault","require","_utils","_events","_support","_asyncbox","_lodash","APP_CONNECT_TIMEOUT_MS","APP_CONNECT_INTERVAL_MS","SELECT_APP_RETRIES","SELECT_APP_RETRY_SLEEP_MS","SAFARI_BUNDLE_ID","BLANK_PAGE_URL","setConnectionKey","log","debug","rpcClient","send","connect","timeout","setup","initRpcClient","on","_","noop","onPageChange","bind","onConnectedApplicationList","onAppConnect","onAppDisconnect","onAppUpdate","onConnectedDriverList","onCurrentState","frameDetached","waitForCondition","isEmpty","appDict","waitMs","interval","err","error","message","disconnect","emit","events","EVENT_DISCONNECT","teardown","selectApp","currentUrl","maxTries","ignoreAboutBlankUrl","shouldCheckForTarget","timer","timing","Timer","start","appIdKey","pageDict","searchForApp","errorAndThrow","logApplicationDictionary","pageArray","pageArrayFromDict","simpleStringify","fullPageArray","app","info","toPairs","isArray","isActive","id","replace","page","url","clone","bundleId","push","getDuration","asMilliSeconds","toFixed","bundleIds","includeSafari","isSafari","additionalBundleIds","retryInterval","retryCount","possibleAppIds","getPossibleDebuggerAppKeys","join","attemptedAppIdKey","result","searchForPage","Error","ign","appsDict","values","promise","dict","selectPage","pageIdKey","skipReadyCheck","checkPageIsReady","pageUnload","apps","getValueString","key","value","isFunction","JSON","stringify","Array","length","prefix","k","v","valueString","updateAppsWithDict","entry","appInfoFromDict","isUndefined","deferredPromise","getDebuggerAppKey","_default","exports","default"],"sources":["../../../lib/mixins/connect.js"],"sourcesContent":["import log from '../logger';\nimport { appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n         getPossibleDebuggerAppKeys, simpleStringify, deferredPromise } from '../utils';\nimport events from './events';\nimport { timing } from '@appium/support';\nimport { retryInterval, waitForCondition } from 'asyncbox';\nimport _ from 'lodash';\n\n\nconst APP_CONNECT_TIMEOUT_MS = 0;\nconst APP_CONNECT_INTERVAL_MS = 100;\nconst SELECT_APP_RETRIES = 20;\nconst SELECT_APP_RETRY_SLEEP_MS = 500;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\nconst BLANK_PAGE_URL = 'about:blank';\n\n\nasync function setConnectionKey () {\n  log.debug('Sending connection key request');\n  // send but only wait to make sure the socket worked\n  // as response from Web Inspector can take a long time\n  await this.rpcClient.send('setConnectionKey', {}, false);\n}\n\nasync function connect (timeout = APP_CONNECT_TIMEOUT_MS) {\n  this.setup();\n\n  // initialize the rpc client\n  this.initRpcClient();\n\n  // listen for basic debugger-level events\n  this.rpcClient.on('_rpc_reportSetup:', _.noop);\n  this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));\n  this.rpcClient.on('_rpc_applicationConnected:', this.onAppConnect.bind(this));\n  this.rpcClient.on('_rpc_applicationDisconnected:', this.onAppDisconnect.bind(this));\n  this.rpcClient.on('_rpc_applicationUpdated:', this.onAppUpdate.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedDriverList:', this.onConnectedDriverList.bind(this));\n  this.rpcClient.on('_rpc_reportCurrentState:', this.onCurrentState.bind(this));\n  this.rpcClient.on('Page.frameDetached', this.frameDetached.bind(this));\n\n  await this.rpcClient.connect();\n\n  // get the connection information about the app\n  try {\n    await this.setConnectionKey();\n    if (timeout) {\n      log.debug(`Waiting up to ${timeout}ms for applications to be reported`);\n      try {\n        await waitForCondition(() => !_.isEmpty(this.appDict), {\n          waitMs: timeout,\n          interval: APP_CONNECT_INTERVAL_MS,\n        });\n      } catch (err) {\n        log.debug(`Timed out waiting for applications to be reported`);\n      }\n    }\n    return this.appDict || {};\n  } catch (err) {\n    log.error(`Error setting connection key: ${err.message}`);\n    await this.disconnect();\n    throw err;\n  }\n}\n\nasync function disconnect () {\n  if (this.rpcClient) {\n    await this.rpcClient.disconnect();\n  }\n  this.emit(events.EVENT_DISCONNECT, true);\n  this.teardown();\n}\n\nasync function selectApp (currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {\n  const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;\n  this.rpcClient.shouldCheckForTarget = false;\n  try {\n    const timer = new timing.Timer().start();\n    log.debug('Selecting application');\n    if (!this.appDict || _.isEmpty(this.appDict)) {\n      log.debug('No applications currently connected.');\n      return [];\n    }\n\n    const {appIdKey, pageDict} = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);\n\n    // if, after all this, we have no dictionary, we have failed\n    if (!appIdKey || !pageDict) {\n      log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n    }\n\n    if (this.appIdKey !== appIdKey) {\n      log.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);\n      this.appIdKey = appIdKey;\n    }\n\n    logApplicationDictionary(this.appDict);\n\n    // translate the dictionary into a useful form, and return to sender\n    const pageArray = _.isEmpty(this.appDict[appIdKey].pageArray)\n      ? pageArrayFromDict(pageDict)\n      : this.appDict[appIdKey].pageArray;\n    log.debug(`Finally selecting app ${this.appIdKey}: ${simpleStringify(pageArray)}`);\n\n    let fullPageArray = [];\n    for (const [app, info] of _.toPairs(this.appDict)) {\n      if (!_.isArray(info.pageArray) || !info.isActive) {\n        continue;\n      }\n      const id = app.replace('PID:', '');\n      for (const page of info.pageArray) {\n        if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {\n          let pageDict = _.clone(page);\n          pageDict.id = `${id}.${pageDict.id}`;\n          pageDict.bundleId = info.bundleId;\n          fullPageArray.push(pageDict);\n        }\n      }\n    }\n\n    log.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n    return fullPageArray;\n  } finally {\n    this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;\n  }\n}\n\nasync function searchForApp (currentUrl, maxTries, ignoreAboutBlankUrl) {\n  const bundleIds = this.includeSafari && !this.isSafari\n    ? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID]\n    : [this.bundleId, ...this.additionalBundleIds];\n  try {\n    return await retryInterval(maxTries, SELECT_APP_RETRY_SLEEP_MS, async (retryCount) => {\n      logApplicationDictionary(this.appDict);\n      const possibleAppIds = getPossibleDebuggerAppKeys(bundleIds, this.appDict);\n      log.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);\n      for (const attemptedAppIdKey of possibleAppIds) {\n        try {\n          if (!this.appDict[attemptedAppIdKey].isActive) {\n            log.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);\n            continue;\n          }\n          log.debug(`Attempting app '${attemptedAppIdKey}'`);\n          const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey, this.onAppConnect.bind(this));\n          // in iOS 8.2 the connect logic happens, but with an empty dictionary\n          // which leads to the remote debugger getting disconnected, and into a loop\n          if (_.isEmpty(pageDict)) {\n            log.debug('Empty page dictionary received. Trying again.');\n            continue;\n          }\n\n          // save the page array for this app\n          this.appDict[appIdKey].pageArray = pageArrayFromDict(pageDict);\n\n          // if we are looking for a particular url, make sure we\n          // have the right page. Ignore empty or undefined urls.\n          // Ignore about:blank if requested.\n          const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);\n          if (result) {\n            return result;\n          }\n\n          if (currentUrl) {\n            log.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);\n          } else {\n            log.debug('Received app, but no match was found. Trying again.');\n          }\n        } catch (err) {\n          log.debug(`Error checking application: '${err.message}'. Retrying connection`);\n        }\n      }\n      retryCount++;\n      throw new Error('Failed to find an app to select');\n    }, 0);\n  } catch (ign) {\n    log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n  }\n}\n\nfunction searchForPage (appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {\n  for (const appDict of _.values(appsDict)) {\n    if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {\n      continue;\n    }\n\n    for (const dict of appDict.pageArray) {\n      if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) &&\n          (!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {\n        return { appIdKey: appDict.id, pageDict: dict };\n      }\n    }\n  }\n  return null;\n}\n\nasync function selectPage (appIdKey, pageIdKey, skipReadyCheck = false) {\n  this.appIdKey = `PID:${appIdKey}`;\n  this.pageIdKey = pageIdKey;\n\n  log.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);\n\n  const timer = new timing.Timer().start();\n\n  await this.rpcClient.selectPage(this.appIdKey, pageIdKey);\n\n  // make sure everything is ready to go\n  if (!skipReadyCheck && !await this.checkPageIsReady()) {\n    await this.pageUnload();\n  }\n\n  log.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n}\n\nfunction logApplicationDictionary (apps) {\n  function getValueString (key, value) {\n    if (_.isFunction(value)) {\n      return '[Function]';\n    }\n    if (key === 'pageArray' && !_.isArray(value)) {\n      return `\"Waiting for data\"`;\n    }\n    return JSON.stringify(value);\n  }\n  log.debug('Current applications available:');\n  for (const [app, info] of _.toPairs(apps)) {\n    log.debug(`    Application: \"${app}\"`);\n    for (const [key, value] of _.toPairs(info)) {\n      if (key === 'pageArray' && Array.isArray(value) && value.length) {\n        log.debug(`        ${key}:`);\n        for (const page of value) {\n          let prefix = '- ';\n          for (const [k, v] of _.toPairs(page)) {\n            log.debug(`          ${prefix}${k}: ${JSON.stringify(v)}`);\n            prefix = '  ';\n          }\n        }\n      } else {\n        const valueString = getValueString(key, value);\n        log.debug(`        ${key}: ${valueString}`);\n      }\n    }\n  }\n}\n\nfunction updateAppsWithDict (dict) {\n  // get the dictionary entry into a nice form, and add it to the\n  // application dictionary\n  this.appDict = this.appDict || {};\n  let [id, entry] = appInfoFromDict(dict);\n  if (this.appDict[id]) {\n    // preserve the page dictionary for this entry\n    entry.pageArray = this.appDict[id].pageArray;\n  }\n  this.appDict[id] = entry;\n\n  // add a promise to get the page dictionary\n  if (_.isUndefined(entry.pageArray)) {\n    entry.pageArray = deferredPromise();\n  }\n\n  // try to get the app id from our connected apps\n  if (!this.appIdKey) {\n    this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n  }\n}\n\nexport default { setConnectionKey, connect, disconnect, selectApp, searchForApp, searchForPage, selectPage, updateAppsWithDict };\n"],"mappings":"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"}
|
|
329
|
+
//# sourceMappingURL=connect.js.map
|