appium-remote-debugger 9.1.2 → 9.1.4
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 +1 -0
- package/README.md +1 -13
- package/build/index.js +2 -9
- package/build/lib/atoms.js +2 -25
- package/build/lib/atoms.js.map +1 -0
- package/build/lib/logger.js +2 -8
- package/build/lib/logger.js.map +1 -0
- package/build/lib/mixins/connect.js +6 -72
- package/build/lib/mixins/connect.js.map +1 -0
- package/build/lib/mixins/events.js +2 -6
- package/build/lib/mixins/events.js.map +1 -0
- package/build/lib/mixins/execute.js +4 -37
- package/build/lib/mixins/execute.js.map +1 -0
- package/build/lib/mixins/index.js +2 -12
- package/build/lib/mixins/index.js.map +1 -0
- package/build/lib/mixins/message-handlers.js +2 -36
- package/build/lib/mixins/message-handlers.js.map +1 -0
- package/build/lib/mixins/navigate.js +5 -55
- package/build/lib/mixins/navigate.js.map +1 -0
- package/build/lib/protocol/index.js +21 -10
- package/build/lib/protocol/index.js.map +1 -0
- package/build/lib/remote-debugger-real-device.js +2 -12
- package/build/lib/remote-debugger-real-device.js.map +1 -0
- package/build/lib/remote-debugger.js +3 -64
- package/build/lib/remote-debugger.js.map +1 -0
- package/build/lib/rpc/index.js +2 -8
- package/build/lib/rpc/index.js.map +1 -0
- package/build/lib/rpc/remote-messages.js +6 -31
- package/build/lib/rpc/remote-messages.js.map +1 -0
- package/build/lib/rpc/rpc-client-real-device.js +2 -19
- package/build/lib/rpc/rpc-client-real-device.js.map +1 -0
- package/build/lib/rpc/rpc-client-simulator.js +5 -33
- package/build/lib/rpc/rpc-client-simulator.js.map +1 -0
- package/build/lib/rpc/rpc-client.js +14 -112
- package/build/lib/rpc/rpc-client.js.map +1 -0
- package/build/lib/rpc/rpc-message-handler.js +2 -55
- package/build/lib/rpc/rpc-message-handler.js.map +1 -0
- package/build/lib/utils.js +10 -47
- package/build/lib/utils.js.map +1 -0
- package/package.json +49 -25
- package/scripts/build-atoms.js +6 -0
- package/scripts/build-selenium.js +3 -0
- package/scripts/common.js +194 -0
- package/scripts/import-atoms.js +3 -0
|
@@ -1,54 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.default = exports.RemoteDebugger = exports.RPC_RESPONSE_TIMEOUT_MS = exports.REMOTE_DEBUGGER_PORT = void 0;
|
|
9
|
-
|
|
10
8
|
require("source-map-support/register");
|
|
11
|
-
|
|
12
9
|
var _events = require("events");
|
|
13
|
-
|
|
14
10
|
var _logger = _interopRequireDefault(require("./logger"));
|
|
15
|
-
|
|
16
11
|
var _rpc = require("./rpc");
|
|
17
|
-
|
|
18
12
|
var _utils = require("./utils");
|
|
19
|
-
|
|
20
13
|
var _mixins = require("./mixins");
|
|
21
|
-
|
|
22
14
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
23
|
-
|
|
24
15
|
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
25
|
-
|
|
26
16
|
var _path = _interopRequireDefault(require("path"));
|
|
27
|
-
|
|
28
17
|
var _asyncLock = _interopRequireDefault(require("async-lock"));
|
|
29
|
-
|
|
30
18
|
let VERSION;
|
|
31
|
-
|
|
32
19
|
try {
|
|
33
20
|
VERSION = require(_path.default.resolve(__dirname, '..', '..', 'package.json')).version;
|
|
34
21
|
} catch (ign) {}
|
|
35
|
-
|
|
36
22
|
const REMOTE_DEBUGGER_PORT = 27753;
|
|
37
23
|
exports.REMOTE_DEBUGGER_PORT = REMOTE_DEBUGGER_PORT;
|
|
38
24
|
const SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';
|
|
25
|
+
|
|
39
26
|
const RPC_RESPONSE_TIMEOUT_MS = 5000;
|
|
40
27
|
exports.RPC_RESPONSE_TIMEOUT_MS = RPC_RESPONSE_TIMEOUT_MS;
|
|
41
28
|
const PAGE_READY_TIMEOUT = 5000;
|
|
42
29
|
const GARBAGE_COLLECT_TIMEOUT = 5000;
|
|
43
|
-
|
|
44
30
|
class RemoteDebugger extends _events.EventEmitter {
|
|
45
31
|
constructor(opts = {}) {
|
|
46
32
|
super();
|
|
47
|
-
|
|
48
33
|
if (VERSION) {
|
|
49
34
|
_logger.default.info(`Remote Debugger version ${VERSION}`);
|
|
50
35
|
}
|
|
51
|
-
|
|
52
36
|
const {
|
|
53
37
|
bundleId,
|
|
54
38
|
additionalBundleIds = [],
|
|
@@ -77,9 +61,7 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
77
61
|
this.includeSafari = includeSafari;
|
|
78
62
|
this.useNewSafari = useNewSafari;
|
|
79
63
|
this.pageLoadMs = pageLoadMs;
|
|
80
|
-
|
|
81
64
|
_logger.default.debug(`useNewSafari --> ${this.useNewSafari}`);
|
|
82
|
-
|
|
83
65
|
this.garbageCollectOnExecute = garbageCollectOnExecute;
|
|
84
66
|
this.host = host;
|
|
85
67
|
this.port = port;
|
|
@@ -89,15 +71,12 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
89
71
|
this.logAllCommunication = _lodash.default.isNil(logAllCommunication) ? !!logFullResponse : !!logAllCommunication;
|
|
90
72
|
this.logAllCommunicationHexDump = logAllCommunicationHexDump;
|
|
91
73
|
this.socketChunkSize = socketChunkSize;
|
|
92
|
-
|
|
93
74
|
if (_lodash.default.isInteger(webInspectorMaxFrameLength)) {
|
|
94
75
|
this.webInspectorMaxFrameLength = webInspectorMaxFrameLength;
|
|
95
76
|
}
|
|
96
|
-
|
|
97
77
|
this.fullPageInitialization = fullPageInitialization;
|
|
98
78
|
this._lock = new _asyncLock.default();
|
|
99
79
|
}
|
|
100
|
-
|
|
101
80
|
setup() {
|
|
102
81
|
this.appDict = {};
|
|
103
82
|
this.appIdKey = null;
|
|
@@ -108,10 +87,8 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
108
87
|
this.rpcClient = null;
|
|
109
88
|
this._clientEventListeners = {};
|
|
110
89
|
}
|
|
111
|
-
|
|
112
90
|
teardown() {
|
|
113
91
|
_logger.default.debug('Cleaning up listeners');
|
|
114
|
-
|
|
115
92
|
this.appDict = {};
|
|
116
93
|
this.appIdKey = null;
|
|
117
94
|
this.pageIdKey = null;
|
|
@@ -120,7 +97,6 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
120
97
|
this.removeAllListeners(RemoteDebugger.EVENT_PAGE_CHANGE);
|
|
121
98
|
this.removeAllListeners(RemoteDebugger.EVENT_DISCONNECT);
|
|
122
99
|
}
|
|
123
|
-
|
|
124
100
|
initRpcClient() {
|
|
125
101
|
this.rpcClient = new _rpc.RpcClientSimulator({
|
|
126
102
|
bundleId: this.bundleId,
|
|
@@ -136,32 +112,25 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
136
112
|
webInspectorMaxFrameLength: this.webInspectorMaxFrameLength
|
|
137
113
|
});
|
|
138
114
|
}
|
|
139
|
-
|
|
140
115
|
get isConnected() {
|
|
141
116
|
var _this$rpcClient;
|
|
142
|
-
|
|
143
117
|
return !!((_this$rpcClient = this.rpcClient) !== null && _this$rpcClient !== void 0 && _this$rpcClient.isConnected);
|
|
144
118
|
}
|
|
145
|
-
|
|
146
119
|
async launchSafari() {
|
|
147
120
|
await this.rpcClient.send('launchApplication', {
|
|
148
121
|
bundleId: SAFARI_BUNDLE_ID
|
|
149
122
|
});
|
|
150
123
|
}
|
|
151
|
-
|
|
152
124
|
async startTimeline(fn) {
|
|
153
125
|
_logger.default.debug('Starting to record the timeline');
|
|
154
|
-
|
|
155
126
|
this.rpcClient.on('Timeline.eventRecorded', fn);
|
|
156
127
|
return await this.rpcClient.send('startTimeline', {
|
|
157
128
|
appIdKey: this.appIdKey,
|
|
158
129
|
pageIdKey: this.pageIdKey
|
|
159
130
|
});
|
|
160
131
|
}
|
|
161
|
-
|
|
162
132
|
async stopTimeline() {
|
|
163
133
|
_logger.default.debug('Stopping to record the timeline');
|
|
164
|
-
|
|
165
134
|
await this.rpcClient.send('Timeline.stop', {
|
|
166
135
|
appIdKey: this.appIdKey,
|
|
167
136
|
pageIdKey: this.pageIdKey
|
|
@@ -170,65 +139,48 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
170
139
|
|
|
171
140
|
addClientEventListener(eventName, listener) {
|
|
172
141
|
this._clientEventListeners[eventName] = this._clientEventListeners[eventName] || [];
|
|
173
|
-
|
|
174
142
|
this._clientEventListeners[eventName].push(listener);
|
|
175
|
-
|
|
176
143
|
this.rpcClient.on(eventName, listener);
|
|
177
144
|
}
|
|
178
|
-
|
|
179
145
|
removeClientEventListener(eventName) {
|
|
180
146
|
for (const listener of this._clientEventListeners[eventName] || []) {
|
|
181
147
|
this.rpcClient.off(eventName, listener);
|
|
182
148
|
}
|
|
183
149
|
}
|
|
184
|
-
|
|
185
150
|
startConsole(listener) {
|
|
186
151
|
_logger.default.debug('Starting to listen for JavaScript console');
|
|
187
|
-
|
|
188
152
|
this.addClientEventListener('Console.messageAdded', listener);
|
|
189
153
|
this.addClientEventListener('Console.messageRepeatCountUpdated', listener);
|
|
190
154
|
}
|
|
191
|
-
|
|
192
155
|
stopConsole() {
|
|
193
156
|
_logger.default.debug('Stopping to listen for JavaScript console');
|
|
194
|
-
|
|
195
157
|
this.removeClientEventListener('Console.messageAdded');
|
|
196
158
|
this.removeClientEventListener('Console.messageRepeatCountUpdated');
|
|
197
159
|
}
|
|
198
|
-
|
|
199
160
|
startNetwork(listener) {
|
|
200
161
|
_logger.default.debug('Starting to listen for network events');
|
|
201
|
-
|
|
202
162
|
this.addClientEventListener('NetworkEvent', listener);
|
|
203
163
|
}
|
|
204
|
-
|
|
205
164
|
stopNetwork() {
|
|
206
165
|
_logger.default.debug('Stopping to listen for network events');
|
|
207
|
-
|
|
208
166
|
this.removeClientEventListener('NetworkEvent');
|
|
209
167
|
}
|
|
210
|
-
|
|
211
168
|
set allowNavigationWithoutReload(allow) {
|
|
212
169
|
this._allowNavigationWithoutReload = allow;
|
|
213
170
|
}
|
|
214
|
-
|
|
215
171
|
get allowNavigationWithoutReload() {
|
|
216
172
|
return this._allowNavigationWithoutReload;
|
|
217
173
|
}
|
|
218
|
-
|
|
219
174
|
async getCookies(urls) {
|
|
220
175
|
_logger.default.debug('Getting cookies');
|
|
221
|
-
|
|
222
176
|
return await this.rpcClient.send('Page.getCookies', {
|
|
223
177
|
appIdKey: this.appIdKey,
|
|
224
178
|
pageIdKey: this.pageIdKey,
|
|
225
179
|
urls
|
|
226
180
|
});
|
|
227
181
|
}
|
|
228
|
-
|
|
229
182
|
async deleteCookie(cookieName, url) {
|
|
230
183
|
_logger.default.debug(`Deleting cookie '${cookieName}' on '${url}'`);
|
|
231
|
-
|
|
232
184
|
return await this.rpcClient.send('Page.deleteCookie', {
|
|
233
185
|
appIdKey: this.appIdKey,
|
|
234
186
|
pageIdKey: this.pageIdKey,
|
|
@@ -236,10 +188,8 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
236
188
|
url
|
|
237
189
|
});
|
|
238
190
|
}
|
|
239
|
-
|
|
240
191
|
async garbageCollect(timeoutMs = GARBAGE_COLLECT_TIMEOUT) {
|
|
241
192
|
_logger.default.debug(`Garbage collecting with ${timeoutMs}ms timeout`);
|
|
242
|
-
|
|
243
193
|
try {
|
|
244
194
|
(0, _utils.checkParams)({
|
|
245
195
|
appIdKey: this.appIdKey,
|
|
@@ -247,10 +197,8 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
247
197
|
});
|
|
248
198
|
} catch (err) {
|
|
249
199
|
_logger.default.debug(`Unable to collect garbage at this time`);
|
|
250
|
-
|
|
251
200
|
return;
|
|
252
201
|
}
|
|
253
|
-
|
|
254
202
|
await _bluebird.default.resolve(this.rpcClient.send('Heap.gc', {
|
|
255
203
|
appIdKey: this.appIdKey,
|
|
256
204
|
pageIdKey: this.pageIdKey
|
|
@@ -264,29 +212,20 @@ class RemoteDebugger extends _events.EventEmitter {
|
|
|
264
212
|
}
|
|
265
213
|
});
|
|
266
214
|
}
|
|
267
|
-
|
|
268
215
|
async useAppDictLock(fn) {
|
|
269
216
|
return await this._lock.acquire('appDict', fn);
|
|
270
217
|
}
|
|
271
|
-
|
|
272
218
|
get skippedApps() {
|
|
273
219
|
return this._skippedApps || [];
|
|
274
220
|
}
|
|
275
|
-
|
|
276
221
|
}
|
|
277
|
-
|
|
278
222
|
exports.RemoteDebugger = RemoteDebugger;
|
|
279
|
-
|
|
280
223
|
for (const [name, fn] of _lodash.default.toPairs(_mixins.mixins)) {
|
|
281
224
|
RemoteDebugger.prototype[name] = fn;
|
|
282
225
|
}
|
|
283
|
-
|
|
284
226
|
for (const [name, event] of _lodash.default.toPairs(_mixins.events)) {
|
|
285
227
|
RemoteDebugger[name] = event;
|
|
286
228
|
}
|
|
287
|
-
|
|
288
229
|
var _default = RemoteDebugger;
|
|
289
|
-
exports.default = _default;
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/remote-debugger.js","names":["VERSION","require","path","resolve","__dirname","version","ign","REMOTE_DEBUGGER_PORT","SAFARI_BUNDLE_ID","RPC_RESPONSE_TIMEOUT_MS","PAGE_READY_TIMEOUT","GARBAGE_COLLECT_TIMEOUT","RemoteDebugger","EventEmitter","constructor","opts","log","info","bundleId","additionalBundleIds","platformVersion","isSafari","includeSafari","useNewSafari","pageLoadMs","host","port","socketPath","pageReadyTimeout","remoteDebugProxy","garbageCollectOnExecute","logFullResponse","logAllCommunication","logAllCommunicationHexDump","webInspectorMaxFrameLength","socketChunkSize","fullPageInitialization","debug","_","isNil","isInteger","_lock","AsyncLock","setup","appDict","appIdKey","pageIdKey","pageLoading","_navigatingToPage","allowNavigationWithoutReload","rpcClient","_clientEventListeners","teardown","removeAllListeners","EVENT_PAGE_CHANGE","EVENT_DISCONNECT","initRpcClient","RpcClientSimulator","messageProxy","isConnected","launchSafari","send","startTimeline","fn","on","stopTimeline","addClientEventListener","eventName","listener","push","removeClientEventListener","off","startConsole","stopConsole","startNetwork","stopNetwork","allow","_allowNavigationWithoutReload","getCookies","urls","deleteCookie","cookieName","url","garbageCollect","timeoutMs","checkParams","err","B","timeout","then","gcSuccess","catch","gcError","TimeoutError","message","useAppDictLock","acquire","skippedApps","_skippedApps","name","toPairs","mixins","prototype","event","events"],"sourceRoot":"../..","sources":["lib/remote-debugger.js"],"sourcesContent":["import { EventEmitter } from 'events';\nimport log from './logger';\nimport { RpcClientSimulator } from './rpc';\nimport { checkParams } from './utils';\nimport { mixins, events } from './mixins';\nimport _ from 'lodash';\nimport B from 'bluebird';\nimport path from 'path';\nimport AsyncLock from 'async-lock';\n\n\nlet VERSION;\ntry {\n  VERSION = require(path.resolve(__dirname, '..', '..', 'package.json')).version;\n} catch (ign) {}\n\nconst REMOTE_DEBUGGER_PORT = 27753;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\nconst PAGE_READY_TIMEOUT = 5000;\n\nconst GARBAGE_COLLECT_TIMEOUT = 5000;\n\n\nclass RemoteDebugger extends EventEmitter {\n  /*\n   * The constructor takes an opts hash with the following properties:\n   *   - bundleId - id of the app being connected to\n   *   - additionalBundleIds - array of possible bundle ids that the inspector\n   *                           could return\n   *   - platformVersion - version of iOS\n   *   - useNewSafari - for web inspector, whether this is a new Safari instance\n   *   - pageLoadMs - the time, in ms, that should be waited for page loading\n   *   - host - the remote debugger's host address\n   *   - port - the remote debugger port through which to communicate\n   *   - logAllCommunication - log plists sent and received from Web Inspector\n   *   - logAllCommunicationHexDump - log communication from Web Inspector as hex dump\n   *   - socketChunkSize - size, in bytes, of chunks of data sent to Web Inspector (real device only)\n   *   - webInspectorMaxFrameLength - The maximum size in bytes of a single data frame\n   *                                  in the device communication protocol\n   */\n  constructor (opts = {}) {\n    super();\n\n    if (VERSION) {\n      log.info(`Remote Debugger version ${VERSION}`);\n    }\n\n    const {\n      bundleId,\n      additionalBundleIds = [],\n      platformVersion,\n      isSafari = true,\n      includeSafari = false,\n      useNewSafari = false,\n      pageLoadMs,\n      host,\n      port = REMOTE_DEBUGGER_PORT,\n      socketPath,\n      pageReadyTimeout = PAGE_READY_TIMEOUT,\n      remoteDebugProxy,\n      garbageCollectOnExecute = false,\n      logFullResponse = false,\n      logAllCommunication = false,\n      logAllCommunicationHexDump = false,\n      webInspectorMaxFrameLength,\n      socketChunkSize,\n      fullPageInitialization,\n    } = opts;\n\n    this.bundleId = bundleId;\n    this.additionalBundleIds = additionalBundleIds;\n    this.platformVersion = platformVersion;\n    this.isSafari = isSafari;\n    this.includeSafari = includeSafari;\n    this.useNewSafari = useNewSafari;\n    this.pageLoadMs = pageLoadMs;\n    log.debug(`useNewSafari --> ${this.useNewSafari}`);\n\n    this.garbageCollectOnExecute = garbageCollectOnExecute;\n\n    this.host = host;\n    this.port = port;\n    this.socketPath = socketPath;\n    this.remoteDebugProxy = remoteDebugProxy;\n    this.pageReadyTimeout = pageReadyTimeout;\n\n    this.logAllCommunication = _.isNil(logAllCommunication) ? !!logFullResponse : !!logAllCommunication;\n    this.logAllCommunicationHexDump = logAllCommunicationHexDump;\n    this.socketChunkSize = socketChunkSize;\n\n    if (_.isInteger(webInspectorMaxFrameLength)) {\n      this.webInspectorMaxFrameLength = webInspectorMaxFrameLength;\n    }\n\n    this.fullPageInitialization = fullPageInitialization;\n\n    this._lock = new AsyncLock();\n  }\n\n  setup () {\n    // app handling configuration\n    this.appDict = {};\n    this.appIdKey = null;\n    this.pageIdKey = null;\n    this.pageLoading = false;\n    this._navigatingToPage = false;\n    this.allowNavigationWithoutReload = false;\n\n    this.rpcClient = null;\n    this._clientEventListeners = {};\n  }\n\n  teardown () {\n    log.debug('Cleaning up listeners');\n\n    this.appDict = {};\n    this.appIdKey = null;\n    this.pageIdKey = null;\n    this.pageLoading = false;\n\n    this.rpcClient = null;\n\n    this.removeAllListeners(RemoteDebugger.EVENT_PAGE_CHANGE);\n    this.removeAllListeners(RemoteDebugger.EVENT_DISCONNECT);\n  }\n\n  initRpcClient () {\n    this.rpcClient = new RpcClientSimulator({\n      bundleId: this.bundleId,\n      platformVersion: this.platformVersion,\n      isSafari: this.isSafari,\n      host: this.host,\n      port: this.port,\n      socketPath: this.socketPath,\n      messageProxy: this.remoteDebugProxy,\n      logAllCommunication: this.logAllCommunication,\n      logAllCommunicationHexDump: this.logAllCommunicationHexDump,\n      fullPageInitialization: this.fullPageInitialization,\n      webInspectorMaxFrameLength: this.webInspectorMaxFrameLength,\n    });\n  }\n\n  get isConnected () {\n    return !!this.rpcClient?.isConnected;\n  }\n\n  async launchSafari () {\n    await this.rpcClient.send('launchApplication', {\n      bundleId: SAFARI_BUNDLE_ID\n    });\n  }\n\n  async startTimeline (fn) {\n    log.debug('Starting to record the timeline');\n    this.rpcClient.on('Timeline.eventRecorded', fn);\n    return await this.rpcClient.send('startTimeline', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    });\n  }\n\n  async stopTimeline () {\n    log.debug('Stopping to record the timeline');\n    await this.rpcClient.send('Timeline.stop', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    });\n  }\n\n  /*\n   * Keep track of the client event listeners so they can be removed\n   */\n  addClientEventListener (eventName, listener) {\n    this._clientEventListeners[eventName] = this._clientEventListeners[eventName] || [];\n    this._clientEventListeners[eventName].push(listener);\n    this.rpcClient.on(eventName, listener);\n  }\n\n  removeClientEventListener (eventName) {\n    for (const listener of (this._clientEventListeners[eventName] || [])) {\n      this.rpcClient.off(eventName, listener);\n    }\n  }\n\n  startConsole (listener) {\n    log.debug('Starting to listen for JavaScript console');\n    this.addClientEventListener('Console.messageAdded', listener);\n    this.addClientEventListener('Console.messageRepeatCountUpdated', listener);\n  }\n\n  stopConsole () {\n    log.debug('Stopping to listen for JavaScript console');\n    this.removeClientEventListener('Console.messageAdded');\n    this.removeClientEventListener('Console.messageRepeatCountUpdated');\n  }\n\n  startNetwork (listener) {\n    log.debug('Starting to listen for network events');\n    this.addClientEventListener('NetworkEvent', listener);\n  }\n\n  stopNetwork () {\n    log.debug('Stopping to listen for network events');\n    this.removeClientEventListener('NetworkEvent');\n  }\n\n  set allowNavigationWithoutReload (allow) {\n    this._allowNavigationWithoutReload = allow;\n  }\n\n  get allowNavigationWithoutReload () {\n    return this._allowNavigationWithoutReload;\n  }\n\n  async getCookies (urls) {\n    log.debug('Getting cookies');\n    return await this.rpcClient.send('Page.getCookies', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n      urls,\n    });\n  }\n\n  async deleteCookie (cookieName, url) {\n    log.debug(`Deleting cookie '${cookieName}' on '${url}'`);\n    return await this.rpcClient.send('Page.deleteCookie', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n      cookieName,\n      url,\n    });\n  }\n\n  async garbageCollect (timeoutMs = GARBAGE_COLLECT_TIMEOUT) {\n    log.debug(`Garbage collecting with ${timeoutMs}ms timeout`);\n    try {\n      checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n    } catch (err) {\n      log.debug(`Unable to collect garbage at this time`);\n      return;\n    }\n\n    await B.resolve(this.rpcClient.send('Heap.gc', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    })).timeout(timeoutMs)\n    .then(function gcSuccess () { // eslint-disable-line promise/prefer-await-to-then\n      log.debug(`Garbage collection successful`);\n    }).catch(function gcError (err) { // eslint-disable-line promise/prefer-await-to-callbacks\n      if (err instanceof B.TimeoutError) {\n        log.debug(`Garbage collection timed out after ${timeoutMs}ms`);\n      } else {\n        log.debug(`Unable to collect garbage: ${err.message}`);\n      }\n    });\n  }\n\n  async useAppDictLock (fn) {\n    return await this._lock.acquire('appDict', fn);\n  }\n\n  get skippedApps () {\n    return this._skippedApps || [];\n  }\n}\n\nfor (const [name, fn] of _.toPairs(mixins)) {\n  RemoteDebugger.prototype[name] = fn;\n}\n\nfor (const [name, event] of _.toPairs(events)) {\n  RemoteDebugger[name] = event;\n}\n\nexport default RemoteDebugger;\nexport {\n  RemoteDebugger, REMOTE_DEBUGGER_PORT, RPC_RESPONSE_TIMEOUT_MS,\n};\n"],"mappings":"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"}
|
|
230
|
+
exports.default = _default;
|
|
231
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["VERSION","require","path","resolve","__dirname","version","ign","REMOTE_DEBUGGER_PORT","SAFARI_BUNDLE_ID","RPC_RESPONSE_TIMEOUT_MS","PAGE_READY_TIMEOUT","GARBAGE_COLLECT_TIMEOUT","RemoteDebugger","EventEmitter","constructor","opts","log","info","bundleId","additionalBundleIds","platformVersion","isSafari","includeSafari","useNewSafari","pageLoadMs","host","port","socketPath","pageReadyTimeout","remoteDebugProxy","garbageCollectOnExecute","logFullResponse","logAllCommunication","logAllCommunicationHexDump","webInspectorMaxFrameLength","socketChunkSize","fullPageInitialization","debug","_","isNil","isInteger","_lock","AsyncLock","setup","appDict","appIdKey","pageIdKey","pageLoading","_navigatingToPage","allowNavigationWithoutReload","rpcClient","_clientEventListeners","teardown","removeAllListeners","EVENT_PAGE_CHANGE","EVENT_DISCONNECT","initRpcClient","RpcClientSimulator","messageProxy","isConnected","launchSafari","send","startTimeline","fn","on","stopTimeline","addClientEventListener","eventName","listener","push","removeClientEventListener","off","startConsole","stopConsole","startNetwork","stopNetwork","allow","_allowNavigationWithoutReload","getCookies","urls","deleteCookie","cookieName","url","garbageCollect","timeoutMs","checkParams","err","B","timeout","then","gcSuccess","catch","gcError","TimeoutError","message","useAppDictLock","acquire","skippedApps","_skippedApps","name","toPairs","mixins","prototype","event","events"],"sources":["../../lib/remote-debugger.js"],"sourcesContent":["import { EventEmitter } from 'events';\nimport log from './logger';\nimport { RpcClientSimulator } from './rpc';\nimport { checkParams } from './utils';\nimport { mixins, events } from './mixins';\nimport _ from 'lodash';\nimport B from 'bluebird';\nimport path from 'path';\nimport AsyncLock from 'async-lock';\n\n\nlet VERSION;\ntry {\n  VERSION = require(path.resolve(__dirname, '..', '..', 'package.json')).version;\n} catch (ign) {}\n\nconst REMOTE_DEBUGGER_PORT = 27753;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\nconst PAGE_READY_TIMEOUT = 5000;\n\nconst GARBAGE_COLLECT_TIMEOUT = 5000;\n\n\nclass RemoteDebugger extends EventEmitter {\n  /*\n   * The constructor takes an opts hash with the following properties:\n   *   - bundleId - id of the app being connected to\n   *   - additionalBundleIds - array of possible bundle ids that the inspector\n   *                           could return\n   *   - platformVersion - version of iOS\n   *   - useNewSafari - for web inspector, whether this is a new Safari instance\n   *   - pageLoadMs - the time, in ms, that should be waited for page loading\n   *   - host - the remote debugger's host address\n   *   - port - the remote debugger port through which to communicate\n   *   - logAllCommunication - log plists sent and received from Web Inspector\n   *   - logAllCommunicationHexDump - log communication from Web Inspector as hex dump\n   *   - socketChunkSize - size, in bytes, of chunks of data sent to Web Inspector (real device only)\n   *   - webInspectorMaxFrameLength - The maximum size in bytes of a single data frame\n   *                                  in the device communication protocol\n   */\n  constructor (opts = {}) {\n    super();\n\n    if (VERSION) {\n      log.info(`Remote Debugger version ${VERSION}`);\n    }\n\n    const {\n      bundleId,\n      additionalBundleIds = [],\n      platformVersion,\n      isSafari = true,\n      includeSafari = false,\n      useNewSafari = false,\n      pageLoadMs,\n      host,\n      port = REMOTE_DEBUGGER_PORT,\n      socketPath,\n      pageReadyTimeout = PAGE_READY_TIMEOUT,\n      remoteDebugProxy,\n      garbageCollectOnExecute = false,\n      logFullResponse = false,\n      logAllCommunication = false,\n      logAllCommunicationHexDump = false,\n      webInspectorMaxFrameLength,\n      socketChunkSize,\n      fullPageInitialization,\n    } = opts;\n\n    this.bundleId = bundleId;\n    this.additionalBundleIds = additionalBundleIds;\n    this.platformVersion = platformVersion;\n    this.isSafari = isSafari;\n    this.includeSafari = includeSafari;\n    this.useNewSafari = useNewSafari;\n    this.pageLoadMs = pageLoadMs;\n    log.debug(`useNewSafari --> ${this.useNewSafari}`);\n\n    this.garbageCollectOnExecute = garbageCollectOnExecute;\n\n    this.host = host;\n    this.port = port;\n    this.socketPath = socketPath;\n    this.remoteDebugProxy = remoteDebugProxy;\n    this.pageReadyTimeout = pageReadyTimeout;\n\n    this.logAllCommunication = _.isNil(logAllCommunication) ? !!logFullResponse : !!logAllCommunication;\n    this.logAllCommunicationHexDump = logAllCommunicationHexDump;\n    this.socketChunkSize = socketChunkSize;\n\n    if (_.isInteger(webInspectorMaxFrameLength)) {\n      this.webInspectorMaxFrameLength = webInspectorMaxFrameLength;\n    }\n\n    this.fullPageInitialization = fullPageInitialization;\n\n    this._lock = new AsyncLock();\n  }\n\n  setup () {\n    // app handling configuration\n    this.appDict = {};\n    this.appIdKey = null;\n    this.pageIdKey = null;\n    this.pageLoading = false;\n    this._navigatingToPage = false;\n    this.allowNavigationWithoutReload = false;\n\n    this.rpcClient = null;\n    this._clientEventListeners = {};\n  }\n\n  teardown () {\n    log.debug('Cleaning up listeners');\n\n    this.appDict = {};\n    this.appIdKey = null;\n    this.pageIdKey = null;\n    this.pageLoading = false;\n\n    this.rpcClient = null;\n\n    this.removeAllListeners(RemoteDebugger.EVENT_PAGE_CHANGE);\n    this.removeAllListeners(RemoteDebugger.EVENT_DISCONNECT);\n  }\n\n  initRpcClient () {\n    this.rpcClient = new RpcClientSimulator({\n      bundleId: this.bundleId,\n      platformVersion: this.platformVersion,\n      isSafari: this.isSafari,\n      host: this.host,\n      port: this.port,\n      socketPath: this.socketPath,\n      messageProxy: this.remoteDebugProxy,\n      logAllCommunication: this.logAllCommunication,\n      logAllCommunicationHexDump: this.logAllCommunicationHexDump,\n      fullPageInitialization: this.fullPageInitialization,\n      webInspectorMaxFrameLength: this.webInspectorMaxFrameLength,\n    });\n  }\n\n  get isConnected () {\n    return !!this.rpcClient?.isConnected;\n  }\n\n  async launchSafari () {\n    await this.rpcClient.send('launchApplication', {\n      bundleId: SAFARI_BUNDLE_ID\n    });\n  }\n\n  async startTimeline (fn) {\n    log.debug('Starting to record the timeline');\n    this.rpcClient.on('Timeline.eventRecorded', fn);\n    return await this.rpcClient.send('startTimeline', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    });\n  }\n\n  async stopTimeline () {\n    log.debug('Stopping to record the timeline');\n    await this.rpcClient.send('Timeline.stop', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    });\n  }\n\n  /*\n   * Keep track of the client event listeners so they can be removed\n   */\n  addClientEventListener (eventName, listener) {\n    this._clientEventListeners[eventName] = this._clientEventListeners[eventName] || [];\n    this._clientEventListeners[eventName].push(listener);\n    this.rpcClient.on(eventName, listener);\n  }\n\n  removeClientEventListener (eventName) {\n    for (const listener of (this._clientEventListeners[eventName] || [])) {\n      this.rpcClient.off(eventName, listener);\n    }\n  }\n\n  startConsole (listener) {\n    log.debug('Starting to listen for JavaScript console');\n    this.addClientEventListener('Console.messageAdded', listener);\n    this.addClientEventListener('Console.messageRepeatCountUpdated', listener);\n  }\n\n  stopConsole () {\n    log.debug('Stopping to listen for JavaScript console');\n    this.removeClientEventListener('Console.messageAdded');\n    this.removeClientEventListener('Console.messageRepeatCountUpdated');\n  }\n\n  startNetwork (listener) {\n    log.debug('Starting to listen for network events');\n    this.addClientEventListener('NetworkEvent', listener);\n  }\n\n  stopNetwork () {\n    log.debug('Stopping to listen for network events');\n    this.removeClientEventListener('NetworkEvent');\n  }\n\n  set allowNavigationWithoutReload (allow) {\n    this._allowNavigationWithoutReload = allow;\n  }\n\n  get allowNavigationWithoutReload () {\n    return this._allowNavigationWithoutReload;\n  }\n\n  async getCookies (urls) {\n    log.debug('Getting cookies');\n    return await this.rpcClient.send('Page.getCookies', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n      urls,\n    });\n  }\n\n  async deleteCookie (cookieName, url) {\n    log.debug(`Deleting cookie '${cookieName}' on '${url}'`);\n    return await this.rpcClient.send('Page.deleteCookie', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n      cookieName,\n      url,\n    });\n  }\n\n  async garbageCollect (timeoutMs = GARBAGE_COLLECT_TIMEOUT) {\n    log.debug(`Garbage collecting with ${timeoutMs}ms timeout`);\n    try {\n      checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n    } catch (err) {\n      log.debug(`Unable to collect garbage at this time`);\n      return;\n    }\n\n    await B.resolve(this.rpcClient.send('Heap.gc', {\n      appIdKey: this.appIdKey,\n      pageIdKey: this.pageIdKey,\n    })).timeout(timeoutMs)\n    .then(function gcSuccess () { // eslint-disable-line promise/prefer-await-to-then\n      log.debug(`Garbage collection successful`);\n    }).catch(function gcError (err) { // eslint-disable-line promise/prefer-await-to-callbacks\n      if (err instanceof B.TimeoutError) {\n        log.debug(`Garbage collection timed out after ${timeoutMs}ms`);\n      } else {\n        log.debug(`Unable to collect garbage: ${err.message}`);\n      }\n    });\n  }\n\n  async useAppDictLock (fn) {\n    return await this._lock.acquire('appDict', fn);\n  }\n\n  get skippedApps () {\n    return this._skippedApps || [];\n  }\n}\n\nfor (const [name, fn] of _.toPairs(mixins)) {\n  RemoteDebugger.prototype[name] = fn;\n}\n\nfor (const [name, event] of _.toPairs(events)) {\n  RemoteDebugger[name] = event;\n}\n\nexport default RemoteDebugger;\nexport {\n  RemoteDebugger, REMOTE_DEBUGGER_PORT, RPC_RESPONSE_TIMEOUT_MS,\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remote-debugger.js","names":["VERSION","require","path","resolve","__dirname","version","ign","REMOTE_DEBUGGER_PORT","SAFARI_BUNDLE_ID","RPC_RESPONSE_TIMEOUT_MS","PAGE_READY_TIMEOUT","GARBAGE_COLLECT_TIMEOUT","RemoteDebugger","EventEmitter","constructor","opts","log","info","bundleId","additionalBundleIds","platformVersion","isSafari","includeSafari","useNewSafari","pageLoadMs","host","port","socketPath","pageReadyTimeout","remoteDebugProxy","garbageCollectOnExecute","logFullResponse","logAllCommunication","logAllCommunicationHexDump","webInspectorMaxFrameLength","socketChunkSize","fullPageInitialization","debug","_","isNil","isInteger","_lock","AsyncLock","setup","appDict","appIdKey","pageIdKey","pageLoading","_navigatingToPage","allowNavigationWithoutReload","rpcClient","_clientEventListeners","teardown","removeAllListeners","EVENT_PAGE_CHANGE","EVENT_DISCONNECT","initRpcClient","RpcClientSimulator","messageProxy","isConnected","launchSafari","send","startTimeline","fn","on","stopTimeline","addClientEventListener","eventName","listener","push","removeClientEventListener","off","startConsole","stopConsole","startNetwork","stopNetwork","allow","_allowNavigationWithoutReload","getCookies","urls","deleteCookie","cookieName","url","garbageCollect","timeoutMs","checkParams","err","B","timeout","then","gcSuccess","catch","gcError","TimeoutError","message","useAppDictLock","acquire","skippedApps","_skippedApps","name","toPairs","mixins","prototype","event","events"],"sources":["../../lib/remote-debugger.js"],"sourcesContent":["import { EventEmitter } from 'events';\nimport log from './logger';\nimport { RpcClientSimulator } from './rpc';\nimport { checkParams } from './utils';\nimport { mixins, events } from './mixins';\nimport _ from 'lodash';\nimport B from 'bluebird';\nimport path from 'path';\nimport AsyncLock from 'async-lock';\n\n\nlet VERSION;\ntry {\n VERSION = require(path.resolve(__dirname, '..', '..', 'package.json')).version;\n} catch (ign) {}\n\nconst REMOTE_DEBUGGER_PORT = 27753;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\nconst PAGE_READY_TIMEOUT = 5000;\n\nconst GARBAGE_COLLECT_TIMEOUT = 5000;\n\n\nclass RemoteDebugger extends EventEmitter {\n /*\n * The constructor takes an opts hash with the following properties:\n * - bundleId - id of the app being connected to\n * - additionalBundleIds - array of possible bundle ids that the inspector\n * could return\n * - platformVersion - version of iOS\n * - useNewSafari - for web inspector, whether this is a new Safari instance\n * - pageLoadMs - the time, in ms, that should be waited for page loading\n * - host - the remote debugger's host address\n * - port - the remote debugger port through which to communicate\n * - logAllCommunication - log plists sent and received from Web Inspector\n * - logAllCommunicationHexDump - log communication from Web Inspector as hex dump\n * - socketChunkSize - size, in bytes, of chunks of data sent to Web Inspector (real device only)\n * - webInspectorMaxFrameLength - The maximum size in bytes of a single data frame\n * in the device communication protocol\n */\n constructor (opts = {}) {\n super();\n\n if (VERSION) {\n log.info(`Remote Debugger version ${VERSION}`);\n }\n\n const {\n bundleId,\n additionalBundleIds = [],\n platformVersion,\n isSafari = true,\n includeSafari = false,\n useNewSafari = false,\n pageLoadMs,\n host,\n port = REMOTE_DEBUGGER_PORT,\n socketPath,\n pageReadyTimeout = PAGE_READY_TIMEOUT,\n remoteDebugProxy,\n garbageCollectOnExecute = false,\n logFullResponse = false,\n logAllCommunication = false,\n logAllCommunicationHexDump = false,\n webInspectorMaxFrameLength,\n socketChunkSize,\n fullPageInitialization,\n } = opts;\n\n this.bundleId = bundleId;\n this.additionalBundleIds = additionalBundleIds;\n this.platformVersion = platformVersion;\n this.isSafari = isSafari;\n this.includeSafari = includeSafari;\n this.useNewSafari = useNewSafari;\n this.pageLoadMs = pageLoadMs;\n log.debug(`useNewSafari --> ${this.useNewSafari}`);\n\n this.garbageCollectOnExecute = garbageCollectOnExecute;\n\n this.host = host;\n this.port = port;\n this.socketPath = socketPath;\n this.remoteDebugProxy = remoteDebugProxy;\n this.pageReadyTimeout = pageReadyTimeout;\n\n this.logAllCommunication = _.isNil(logAllCommunication) ? !!logFullResponse : !!logAllCommunication;\n this.logAllCommunicationHexDump = logAllCommunicationHexDump;\n this.socketChunkSize = socketChunkSize;\n\n if (_.isInteger(webInspectorMaxFrameLength)) {\n this.webInspectorMaxFrameLength = webInspectorMaxFrameLength;\n }\n\n this.fullPageInitialization = fullPageInitialization;\n\n this._lock = new AsyncLock();\n }\n\n setup () {\n // app handling configuration\n this.appDict = {};\n this.appIdKey = null;\n this.pageIdKey = null;\n this.pageLoading = false;\n this._navigatingToPage = false;\n this.allowNavigationWithoutReload = false;\n\n this.rpcClient = null;\n this._clientEventListeners = {};\n }\n\n teardown () {\n log.debug('Cleaning up listeners');\n\n this.appDict = {};\n this.appIdKey = null;\n this.pageIdKey = null;\n this.pageLoading = false;\n\n this.rpcClient = null;\n\n this.removeAllListeners(RemoteDebugger.EVENT_PAGE_CHANGE);\n this.removeAllListeners(RemoteDebugger.EVENT_DISCONNECT);\n }\n\n initRpcClient () {\n this.rpcClient = new RpcClientSimulator({\n bundleId: this.bundleId,\n platformVersion: this.platformVersion,\n isSafari: this.isSafari,\n host: this.host,\n port: this.port,\n socketPath: this.socketPath,\n messageProxy: this.remoteDebugProxy,\n logAllCommunication: this.logAllCommunication,\n logAllCommunicationHexDump: this.logAllCommunicationHexDump,\n fullPageInitialization: this.fullPageInitialization,\n webInspectorMaxFrameLength: this.webInspectorMaxFrameLength,\n });\n }\n\n get isConnected () {\n return !!this.rpcClient?.isConnected;\n }\n\n async launchSafari () {\n await this.rpcClient.send('launchApplication', {\n bundleId: SAFARI_BUNDLE_ID\n });\n }\n\n async startTimeline (fn) {\n log.debug('Starting to record the timeline');\n this.rpcClient.on('Timeline.eventRecorded', fn);\n return await this.rpcClient.send('startTimeline', {\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n });\n }\n\n async stopTimeline () {\n log.debug('Stopping to record the timeline');\n await this.rpcClient.send('Timeline.stop', {\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n });\n }\n\n /*\n * Keep track of the client event listeners so they can be removed\n */\n addClientEventListener (eventName, listener) {\n this._clientEventListeners[eventName] = this._clientEventListeners[eventName] || [];\n this._clientEventListeners[eventName].push(listener);\n this.rpcClient.on(eventName, listener);\n }\n\n removeClientEventListener (eventName) {\n for (const listener of (this._clientEventListeners[eventName] || [])) {\n this.rpcClient.off(eventName, listener);\n }\n }\n\n startConsole (listener) {\n log.debug('Starting to listen for JavaScript console');\n this.addClientEventListener('Console.messageAdded', listener);\n this.addClientEventListener('Console.messageRepeatCountUpdated', listener);\n }\n\n stopConsole () {\n log.debug('Stopping to listen for JavaScript console');\n this.removeClientEventListener('Console.messageAdded');\n this.removeClientEventListener('Console.messageRepeatCountUpdated');\n }\n\n startNetwork (listener) {\n log.debug('Starting to listen for network events');\n this.addClientEventListener('NetworkEvent', listener);\n }\n\n stopNetwork () {\n log.debug('Stopping to listen for network events');\n this.removeClientEventListener('NetworkEvent');\n }\n\n set allowNavigationWithoutReload (allow) {\n this._allowNavigationWithoutReload = allow;\n }\n\n get allowNavigationWithoutReload () {\n return this._allowNavigationWithoutReload;\n }\n\n async getCookies (urls) {\n log.debug('Getting cookies');\n return await this.rpcClient.send('Page.getCookies', {\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n urls,\n });\n }\n\n async deleteCookie (cookieName, url) {\n log.debug(`Deleting cookie '${cookieName}' on '${url}'`);\n return await this.rpcClient.send('Page.deleteCookie', {\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n cookieName,\n url,\n });\n }\n\n async garbageCollect (timeoutMs = GARBAGE_COLLECT_TIMEOUT) {\n log.debug(`Garbage collecting with ${timeoutMs}ms timeout`);\n try {\n checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n } catch (err) {\n log.debug(`Unable to collect garbage at this time`);\n return;\n }\n\n await B.resolve(this.rpcClient.send('Heap.gc', {\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n })).timeout(timeoutMs)\n .then(function gcSuccess () { // eslint-disable-line promise/prefer-await-to-then\n log.debug(`Garbage collection successful`);\n }).catch(function gcError (err) { // eslint-disable-line promise/prefer-await-to-callbacks\n if (err instanceof B.TimeoutError) {\n log.debug(`Garbage collection timed out after ${timeoutMs}ms`);\n } else {\n log.debug(`Unable to collect garbage: ${err.message}`);\n }\n });\n }\n\n async useAppDictLock (fn) {\n return await this._lock.acquire('appDict', fn);\n }\n\n get skippedApps () {\n return this._skippedApps || [];\n }\n}\n\nfor (const [name, fn] of _.toPairs(mixins)) {\n RemoteDebugger.prototype[name] = fn;\n}\n\nfor (const [name, event] of _.toPairs(events)) {\n RemoteDebugger[name] = event;\n}\n\nexport default RemoteDebugger;\nexport {\n RemoteDebugger, REMOTE_DEBUGGER_PORT, RPC_RESPONSE_TIMEOUT_MS,\n};\n"],"mappings":"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"}
|
package/build/lib/rpc/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
@@ -17,12 +16,7 @@ Object.defineProperty(exports, "RpcClientSimulator", {
|
|
|
17
16
|
return _rpcClientSimulator.default;
|
|
18
17
|
}
|
|
19
18
|
});
|
|
20
|
-
|
|
21
19
|
require("source-map-support/register");
|
|
22
|
-
|
|
23
20
|
var _rpcClientSimulator = _interopRequireDefault(require("./rpc-client-simulator"));
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliL3JwYy9pbmRleC5qcyIsIm5hbWVzIjpbXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uIiwic291cmNlcyI6WyJsaWIvcnBjL2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBScGNDbGllbnRTaW11bGF0b3IgZnJvbSAnLi9ycGMtY2xpZW50LXNpbXVsYXRvcic7XG5pbXBvcnQgUnBjQ2xpZW50UmVhbERldmljZSBmcm9tICcuL3JwYy1jbGllbnQtcmVhbC1kZXZpY2UnO1xuXG5cbmV4cG9ydCB7IFJwY0NsaWVudFNpbXVsYXRvciwgUnBjQ2xpZW50UmVhbERldmljZSB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0EifQ==
|
|
21
|
+
var _rpcClientRealDevice = _interopRequireDefault(require("./rpc-client-real-device"));
|
|
22
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL3JwYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUnBjQ2xpZW50U2ltdWxhdG9yIGZyb20gJy4vcnBjLWNsaWVudC1zaW11bGF0b3InO1xuaW1wb3J0IFJwY0NsaWVudFJlYWxEZXZpY2UgZnJvbSAnLi9ycGMtY2xpZW50LXJlYWwtZGV2aWNlJztcblxuXG5leHBvcnQgeyBScGNDbGllbnRTaW11bGF0b3IsIFJwY0NsaWVudFJlYWxEZXZpY2UgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQ0EifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../lib/rpc/index.js"],"sourcesContent":["import RpcClientSimulator from './rpc-client-simulator';\nimport RpcClientRealDevice from './rpc-client-real-device';\n\n\nexport { RpcClientSimulator, RpcClientRealDevice };\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;AACA"}
|