appium-remote-debugger 9.1.3 → 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.
Files changed (39) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/build/index.js +1 -6
  3. package/build/lib/atoms.js +1 -22
  4. package/build/lib/atoms.js.map +1 -0
  5. package/build/lib/logger.js +1 -5
  6. package/build/lib/logger.js.map +1 -0
  7. package/build/lib/mixins/connect.js +5 -69
  8. package/build/lib/mixins/connect.js.map +1 -0
  9. package/build/lib/mixins/events.js +1 -3
  10. package/build/lib/mixins/events.js.map +1 -0
  11. package/build/lib/mixins/execute.js +3 -34
  12. package/build/lib/mixins/execute.js.map +1 -0
  13. package/build/lib/mixins/index.js +1 -9
  14. package/build/lib/mixins/index.js.map +1 -0
  15. package/build/lib/mixins/message-handlers.js +1 -33
  16. package/build/lib/mixins/message-handlers.js.map +1 -0
  17. package/build/lib/mixins/navigate.js +4 -52
  18. package/build/lib/mixins/navigate.js.map +1 -0
  19. package/build/lib/protocol/index.js +20 -7
  20. package/build/lib/protocol/index.js.map +1 -0
  21. package/build/lib/remote-debugger-real-device.js +1 -9
  22. package/build/lib/remote-debugger-real-device.js.map +1 -0
  23. package/build/lib/remote-debugger.js +2 -61
  24. package/build/lib/remote-debugger.js.map +1 -0
  25. package/build/lib/rpc/index.js +1 -5
  26. package/build/lib/rpc/index.js.map +1 -0
  27. package/build/lib/rpc/remote-messages.js +5 -28
  28. package/build/lib/rpc/remote-messages.js.map +1 -0
  29. package/build/lib/rpc/rpc-client-real-device.js +1 -16
  30. package/build/lib/rpc/rpc-client-real-device.js.map +1 -0
  31. package/build/lib/rpc/rpc-client-simulator.js +4 -30
  32. package/build/lib/rpc/rpc-client-simulator.js.map +1 -0
  33. package/build/lib/rpc/rpc-client.js +13 -109
  34. package/build/lib/rpc/rpc-client.js.map +1 -0
  35. package/build/lib/rpc/rpc-message-handler.js +1 -52
  36. package/build/lib/rpc/rpc-message-handler.js.map +1 -0
  37. package/build/lib/utils.js +9 -44
  38. package/build/lib/utils.js.map +1 -0
  39. package/package.json +4 -3
@@ -4,9 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
-
8
7
  require("source-map-support/register");
9
-
10
8
  const events = {
11
9
  EVENT_PAGE_CHANGE: 'remote_debugger_page_change',
12
10
  EVENT_FRAMES_DETACHED: 'remote_debugger_frames_detached',
@@ -14,4 +12,4 @@ const events = {
14
12
  };
15
13
  var _default = events;
16
14
  exports.default = _default;
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJldmVudHMiLCJFVkVOVF9QQUdFX0NIQU5HRSIsIkVWRU5UX0ZSQU1FU19ERVRBQ0hFRCIsIkVWRU5UX0RJU0NPTk5FQ1QiXSwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWl4aW5zL2V2ZW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBldmVudCBlbWl0dGVkIHB1YmxpY2FsbHlcbmNvbnN0IGV2ZW50cyA9IHtcbiAgRVZFTlRfUEFHRV9DSEFOR0U6ICdyZW1vdGVfZGVidWdnZXJfcGFnZV9jaGFuZ2UnLFxuICBFVkVOVF9GUkFNRVNfREVUQUNIRUQ6ICdyZW1vdGVfZGVidWdnZXJfZnJhbWVzX2RldGFjaGVkJyxcbiAgRVZFTlRfRElTQ09OTkVDVDogJ3JlbW90ZV9kZWJ1Z2dlcl9kaXNjb25uZWN0Jyxcbn07XG5cblxuZXhwb3J0IGRlZmF1bHQgZXZlbnRzO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFDQSxNQUFNQSxNQUFNLEdBQUc7RUFDYkMsaUJBQWlCLEVBQUUsNkJBRE47RUFFYkMscUJBQXFCLEVBQUUsaUNBRlY7RUFHYkMsZ0JBQWdCLEVBQUU7QUFITCxDQUFmO2VBT2VILE0ifQ==
15
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJldmVudHMiLCJFVkVOVF9QQUdFX0NIQU5HRSIsIkVWRU5UX0ZSQU1FU19ERVRBQ0hFRCIsIkVWRU5UX0RJU0NPTk5FQ1QiXSwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWl4aW5zL2V2ZW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBldmVudCBlbWl0dGVkIHB1YmxpY2FsbHlcbmNvbnN0IGV2ZW50cyA9IHtcbiAgRVZFTlRfUEFHRV9DSEFOR0U6ICdyZW1vdGVfZGVidWdnZXJfcGFnZV9jaGFuZ2UnLFxuICBFVkVOVF9GUkFNRVNfREVUQUNIRUQ6ICdyZW1vdGVfZGVidWdnZXJfZnJhbWVzX2RldGFjaGVkJyxcbiAgRVZFTlRfRElTQ09OTkVDVDogJ3JlbW90ZV9kZWJ1Z2dlcl9kaXNjb25uZWN0Jyxcbn07XG5cblxuZXhwb3J0IGRlZmF1bHQgZXZlbnRzO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0EsTUFBTUEsTUFBTSxHQUFHO0VBQ2JDLGlCQUFpQixFQUFFLDZCQUE2QjtFQUNoREMscUJBQXFCLEVBQUUsaUNBQWlDO0VBQ3hEQyxnQkFBZ0IsRUFBRTtBQUNwQixDQUFDO0FBQUMsZUFHYUgsTUFBTTtBQUFBIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.js","names":["events","EVENT_PAGE_CHANGE","EVENT_FRAMES_DETACHED","EVENT_DISCONNECT"],"sources":["../../../lib/mixins/events.js"],"sourcesContent":["// event emitted publically\nconst events = {\n EVENT_PAGE_CHANGE: 'remote_debugger_page_change',\n EVENT_FRAMES_DETACHED: 'remote_debugger_frames_detached',\n EVENT_DISCONNECT: 'remote_debugger_disconnect',\n};\n\n\nexport default events;\n"],"mappings":";;;;;;;AACA,MAAMA,MAAM,GAAG;EACbC,iBAAiB,EAAE,6BAA6B;EAChDC,qBAAqB,EAAE,iCAAiC;EACxDC,gBAAgB,EAAE;AACpB,CAAC;AAAC,eAGaH,MAAM;AAAA"}
@@ -1,47 +1,32 @@
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 = void 0;
9
-
10
8
  require("source-map-support/register");
11
-
12
9
  var _logger = _interopRequireDefault(require("../logger"));
13
-
14
10
  var _driver = require("appium/driver");
15
-
16
11
  var _utils = require("../utils");
17
-
18
12
  var _atoms = require("../atoms");
19
-
20
13
  var _support = require("appium/support");
21
-
22
14
  var _asyncbox = require("asyncbox");
23
-
24
15
  var _lodash = _interopRequireDefault(require("lodash"));
25
-
26
16
  const RPC_RESPONSE_TIMEOUT_MS = 5000;
27
17
 
28
18
  async function executeAtom(atom, args, frames) {
29
19
  if (!this.rpcClient.isConnected) {
30
20
  throw new Error('Remote debugger is not connected');
31
21
  }
32
-
33
22
  _logger.default.debug(`Executing atom '${atom}' with 'args=${JSON.stringify(args)}; frames=${frames}'`);
34
-
35
23
  const script = await (0, _atoms.getScriptForAtom)(atom, args, frames);
36
24
  const value = await this.execute(script, true);
37
-
38
25
  _logger.default.debug(`Received result for atom '${atom}' execution: ${_lodash.default.truncate((0, _utils.simpleStringify)(value), {
39
26
  length: _utils.RESPONSE_LOG_LENGTH
40
27
  })}`);
41
-
42
28
  return value;
43
29
  }
44
-
45
30
  async function executeAtomAsync(atom, args, frames) {
46
31
  const evaluate = async (method, opts) => await this.rpcClient.send(method, Object.assign({
47
32
  appIdKey: this.appIdKey,
@@ -62,14 +47,15 @@ async function executeAtomAsync(atom, args, frames) {
62
47
  expression: script
63
48
  });
64
49
  const promiseObjectId = obj.result.objectId;
50
+
65
51
  const asyncCallBack = `function (res) {
66
52
  window.${promiseName}.resolve(res);
67
53
  window.${promiseName}Value = res;
68
54
  }`;
69
55
  await this.execute(await (0, _atoms.getScriptForAtom)(atom, args, frames, asyncCallBack));
56
+
70
57
  let res;
71
58
  const subcommandTimeout = 1000;
72
-
73
59
  try {
74
60
  res = await evaluate('Runtime.awaitPromise', {
75
61
  promiseObjectId,
@@ -81,27 +67,22 @@ async function executeAtomAsync(atom, args, frames) {
81
67
  if (!err.message.includes(`'Runtime.awaitPromise' was not found`)) {
82
68
  throw err;
83
69
  }
84
-
85
70
  const retryWait = 100;
86
71
  const timeout = args.length >= 3 ? args[2] : RPC_RESPONSE_TIMEOUT_MS;
87
72
  const retries = parseInt(timeout / retryWait, 10) || 1;
88
73
  const timer = new _support.timing.Timer().start();
89
-
90
74
  _logger.default.debug(`Waiting up to ${timeout}ms for async execute to finish`);
91
-
92
75
  res = await (0, _asyncbox.retryInterval)(retries, retryWait, async () => {
93
76
  const hasValue = await evaluate('Runtime.evaluate', {
94
77
  expression: `window.hasOwnProperty('${promiseName}Value');`,
95
78
  returnByValue: true
96
79
  });
97
-
98
80
  if (hasValue) {
99
81
  return await evaluate('Runtime.evaluate', {
100
82
  expression: `window.${promiseName}Value;`,
101
83
  returnByValue: true
102
84
  });
103
85
  }
104
-
105
86
  throw new _driver.errors.TimeoutError(`Timed out waiting for asynchronous script ` + `result after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms'));`);
106
87
  });
107
88
  } finally {
@@ -109,30 +90,23 @@ async function executeAtomAsync(atom, args, frames) {
109
90
  await this.executeAtom('execute_script', [`delete window.${promiseName};`, [null, null], subcommandTimeout], frames);
110
91
  } catch (ign) {}
111
92
  }
112
-
113
93
  return (0, _utils.convertResult)(res);
114
94
  }
115
-
116
95
  async function execute(command, override) {
117
96
  if (this.pageLoading && !override) {
118
97
  _logger.default.debug('Trying to execute but page is not loaded.');
119
-
120
98
  await this.waitForDom();
121
99
  }
122
-
123
100
  (0, _utils.checkParams)({
124
101
  appIdKey: this.appIdKey,
125
102
  pageIdKey: this.pageIdKey
126
103
  });
127
-
128
104
  if (this.garbageCollectOnExecute) {
129
105
  await this.garbageCollect();
130
106
  }
131
-
132
107
  _logger.default.debug(`Sending javascript command: '${_lodash.default.truncate(command, {
133
108
  length: 50
134
109
  })}'`);
135
-
136
110
  const res = await this.rpcClient.send('Runtime.evaluate', {
137
111
  expression: command,
138
112
  returnByValue: true,
@@ -141,19 +115,15 @@ async function execute(command, override) {
141
115
  });
142
116
  return (0, _utils.convertResult)(res);
143
117
  }
144
-
145
118
  async function callFunction(objectId, fn, args) {
146
119
  (0, _utils.checkParams)({
147
120
  appIdKey: this.appIdKey,
148
121
  pageIdKey: this.pageIdKey
149
122
  });
150
-
151
123
  if (this.garbageCollectOnExecute) {
152
124
  await this.garbageCollect();
153
125
  }
154
-
155
126
  _logger.default.debug('Calling javascript function');
156
-
157
127
  const res = await this.rpcClient.send('Runtime.callFunctionOn', {
158
128
  objectId,
159
129
  functionDeclaration: fn,
@@ -164,7 +134,6 @@ async function callFunction(objectId, fn, args) {
164
134
  });
165
135
  return (0, _utils.convertResult)(res);
166
136
  }
167
-
168
137
  var _default = {
169
138
  executeAtom,
170
139
  executeAtomAsync,
@@ -172,4 +141,4 @@ var _default = {
172
141
  callFunction
173
142
  };
174
143
  exports.default = _default;
175
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RPC_RESPONSE_TIMEOUT_MS","executeAtom","atom","args","frames","rpcClient","isConnected","Error","log","debug","JSON","stringify","script","getScriptForAtom","value","execute","_","truncate","simpleStringify","length","RESPONSE_LOG_LENGTH","executeAtomAsync","evaluate","method","opts","send","Object","assign","appIdKey","pageIdKey","returnByValue","promiseName","util","uuidV4","replace","obj","expression","promiseObjectId","result","objectId","asyncCallBack","res","subcommandTimeout","generatePreview","saveResult","err","message","includes","retryWait","timeout","retries","parseInt","timer","timing","Timer","start","retryInterval","hasValue","errors","TimeoutError","getDuration","asMilliSeconds","toFixed","ign","convertResult","command","override","pageLoading","waitForDom","checkParams","garbageCollectOnExecute","garbageCollect","callFunction","fn","functionDeclaration","arguments"],"sources":["../../../lib/mixins/execute.js"],"sourcesContent":["import log from '../logger';\nimport { errors } from 'appium/driver';\nimport { checkParams, simpleStringify, convertResult, RESPONSE_LOG_LENGTH } from '../utils';\nimport { getScriptForAtom } from '../atoms';\nimport { util, timing } from 'appium/support';\nimport { retryInterval } from 'asyncbox';\nimport _ from 'lodash';\n\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\n/**\n * Execute a Selenium atom in Safari\n * @param {string} atom Name of Selenium atom (see atoms/ directory)\n * @param {Array<*>} args Arguments passed to the atom\n * @param {Array<string>} frames\n * @returns {string} The result received from the atom\n */\nasync function executeAtom (atom, args, frames) {\n  if (!this.rpcClient.isConnected) {\n    throw new Error('Remote debugger is not connected');\n  }\n\n  log.debug(`Executing atom '${atom}' with 'args=${JSON.stringify(args)}; frames=${frames}'`);\n  const script = await getScriptForAtom(atom, args, frames);\n  const value = await this.execute(script, true);\n  log.debug(`Received result for atom '${atom}' execution: ${_.truncate(simpleStringify(value), {length: RESPONSE_LOG_LENGTH})}`);\n  return value;\n}\n\nasync function executeAtomAsync (atom, args, frames) {\n  // helper to send directly to the web inspector\n  const evaluate = async (method, opts) => await this.rpcClient.send(method, Object.assign({\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n    returnByValue: false,\n  }, opts));\n\n  // first create a Promise on the page, saving the resolve/reject functions\n  // as properties\n  const promiseName = `appiumAsyncExecutePromise${util.uuidV4().replace(/-/g, '')}`;\n  const script =\n    `var res, rej;\n    window.${promiseName} = new Promise(function (resolve, reject) {\n      res = resolve;\n      rej = reject;\n    });\n    window.${promiseName}.resolve = res;\n    window.${promiseName}.reject = rej;\n    window.${promiseName};`;\n  const obj = await evaluate('Runtime.evaluate', {\n    expression: script,\n  });\n  const promiseObjectId = obj.result.objectId;\n\n  // execute the atom, calling back to the resolve function\n  const asyncCallBack =\n    `function (res) {\n      window.${promiseName}.resolve(res);\n      window.${promiseName}Value = res;\n    }`;\n  await this.execute(await getScriptForAtom(atom, args, frames, asyncCallBack));\n\n  // wait for the promise to be resolved\n  let res;\n  const subcommandTimeout = 1000; // timeout on individual commands\n  try {\n    res = await evaluate('Runtime.awaitPromise', {\n      promiseObjectId,\n      returnByValue: true,\n      generatePreview: true,\n      saveResult: true,\n    });\n  } catch (err) {\n    if (!err.message.includes(`'Runtime.awaitPromise' was not found`)) {\n      throw err;\n    }\n    // awaitPromise is not always available, so simulate it with poll\n    const retryWait = 100;\n    const timeout = (args.length >= 3) ? args[2] : RPC_RESPONSE_TIMEOUT_MS;\n    // if the timeout math turns up 0 retries, make sure it happens once\n    const retries = parseInt(timeout / retryWait, 10) || 1;\n    const timer = new timing.Timer().start();\n    log.debug(`Waiting up to ${timeout}ms for async execute to finish`);\n    res = await retryInterval(retries, retryWait, async () => {\n      // the atom _will_ return, either because it finished or an error\n      // including a timeout error\n      const hasValue = await evaluate('Runtime.evaluate', {\n        expression: `window.hasOwnProperty('${promiseName}Value');`,\n        returnByValue: true,\n      });\n      if (hasValue) {\n        // we only put the property on `window` when the callback is called,\n        // so if it is there, everything is done\n        return await evaluate('Runtime.evaluate', {\n          expression: `window.${promiseName}Value;`,\n          returnByValue: true,\n        });\n      }\n      // throw a TimeoutError, or else it needs to be caught and re-thrown\n      throw new errors.TimeoutError(`Timed out waiting for asynchronous script ` +\n                                    `result after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms'));`);\n    });\n  } finally {\n    try {\n      // try to get rid of the promise\n      await this.executeAtom('execute_script', [`delete window.${promiseName};`, [null, null], subcommandTimeout], frames);\n    } catch (ign) {}\n  }\n  return convertResult(res);\n}\n\nasync function execute (command, override) {\n  // if the page is not loaded yet, wait for it\n  if (this.pageLoading && !override) {\n    log.debug('Trying to execute but page is not loaded.');\n    await this.waitForDom();\n  }\n\n  checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n  if (this.garbageCollectOnExecute) {\n    await this.garbageCollect();\n  }\n\n  log.debug(`Sending javascript command: '${_.truncate(command, {length: 50})}'`);\n  const res = await this.rpcClient.send('Runtime.evaluate', {\n    expression: command,\n    returnByValue: true,\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n  });\n\n  return convertResult(res);\n}\n\nasync function callFunction (objectId, fn, args) {\n  checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n  if (this.garbageCollectOnExecute) {\n    await this.garbageCollect();\n  }\n\n  log.debug('Calling javascript function');\n  const res = await this.rpcClient.send('Runtime.callFunctionOn', {\n    objectId,\n    functionDeclaration: fn,\n    arguments: args,\n    returnByValue: true,\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n  });\n\n  return convertResult(res);\n}\n\n\nexport default { executeAtom, executeAtomAsync, execute, callFunction };\n"],"mappings":"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"}
144
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["RPC_RESPONSE_TIMEOUT_MS","executeAtom","atom","args","frames","rpcClient","isConnected","Error","log","debug","JSON","stringify","script","getScriptForAtom","value","execute","_","truncate","simpleStringify","length","RESPONSE_LOG_LENGTH","executeAtomAsync","evaluate","method","opts","send","Object","assign","appIdKey","pageIdKey","returnByValue","promiseName","util","uuidV4","replace","obj","expression","promiseObjectId","result","objectId","asyncCallBack","res","subcommandTimeout","generatePreview","saveResult","err","message","includes","retryWait","timeout","retries","parseInt","timer","timing","Timer","start","retryInterval","hasValue","errors","TimeoutError","getDuration","asMilliSeconds","toFixed","ign","convertResult","command","override","pageLoading","waitForDom","checkParams","garbageCollectOnExecute","garbageCollect","callFunction","fn","functionDeclaration","arguments"],"sources":["../../../lib/mixins/execute.js"],"sourcesContent":["import log from '../logger';\nimport { errors } from 'appium/driver';\nimport { checkParams, simpleStringify, convertResult, RESPONSE_LOG_LENGTH } from '../utils';\nimport { getScriptForAtom } from '../atoms';\nimport { util, timing } from 'appium/support';\nimport { retryInterval } from 'asyncbox';\nimport _ from 'lodash';\n\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\n/**\n * Execute a Selenium atom in Safari\n * @param {string} atom Name of Selenium atom (see atoms/ directory)\n * @param {Array<*>} args Arguments passed to the atom\n * @param {Array<string>} frames\n * @returns {string} The result received from the atom\n */\nasync function executeAtom (atom, args, frames) {\n  if (!this.rpcClient.isConnected) {\n    throw new Error('Remote debugger is not connected');\n  }\n\n  log.debug(`Executing atom '${atom}' with 'args=${JSON.stringify(args)}; frames=${frames}'`);\n  const script = await getScriptForAtom(atom, args, frames);\n  const value = await this.execute(script, true);\n  log.debug(`Received result for atom '${atom}' execution: ${_.truncate(simpleStringify(value), {length: RESPONSE_LOG_LENGTH})}`);\n  return value;\n}\n\nasync function executeAtomAsync (atom, args, frames) {\n  // helper to send directly to the web inspector\n  const evaluate = async (method, opts) => await this.rpcClient.send(method, Object.assign({\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n    returnByValue: false,\n  }, opts));\n\n  // first create a Promise on the page, saving the resolve/reject functions\n  // as properties\n  const promiseName = `appiumAsyncExecutePromise${util.uuidV4().replace(/-/g, '')}`;\n  const script =\n    `var res, rej;\n    window.${promiseName} = new Promise(function (resolve, reject) {\n      res = resolve;\n      rej = reject;\n    });\n    window.${promiseName}.resolve = res;\n    window.${promiseName}.reject = rej;\n    window.${promiseName};`;\n  const obj = await evaluate('Runtime.evaluate', {\n    expression: script,\n  });\n  const promiseObjectId = obj.result.objectId;\n\n  // execute the atom, calling back to the resolve function\n  const asyncCallBack =\n    `function (res) {\n      window.${promiseName}.resolve(res);\n      window.${promiseName}Value = res;\n    }`;\n  await this.execute(await getScriptForAtom(atom, args, frames, asyncCallBack));\n\n  // wait for the promise to be resolved\n  let res;\n  const subcommandTimeout = 1000; // timeout on individual commands\n  try {\n    res = await evaluate('Runtime.awaitPromise', {\n      promiseObjectId,\n      returnByValue: true,\n      generatePreview: true,\n      saveResult: true,\n    });\n  } catch (err) {\n    if (!err.message.includes(`'Runtime.awaitPromise' was not found`)) {\n      throw err;\n    }\n    // awaitPromise is not always available, so simulate it with poll\n    const retryWait = 100;\n    const timeout = (args.length >= 3) ? args[2] : RPC_RESPONSE_TIMEOUT_MS;\n    // if the timeout math turns up 0 retries, make sure it happens once\n    const retries = parseInt(timeout / retryWait, 10) || 1;\n    const timer = new timing.Timer().start();\n    log.debug(`Waiting up to ${timeout}ms for async execute to finish`);\n    res = await retryInterval(retries, retryWait, async () => {\n      // the atom _will_ return, either because it finished or an error\n      // including a timeout error\n      const hasValue = await evaluate('Runtime.evaluate', {\n        expression: `window.hasOwnProperty('${promiseName}Value');`,\n        returnByValue: true,\n      });\n      if (hasValue) {\n        // we only put the property on `window` when the callback is called,\n        // so if it is there, everything is done\n        return await evaluate('Runtime.evaluate', {\n          expression: `window.${promiseName}Value;`,\n          returnByValue: true,\n        });\n      }\n      // throw a TimeoutError, or else it needs to be caught and re-thrown\n      throw new errors.TimeoutError(`Timed out waiting for asynchronous script ` +\n                                    `result after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms'));`);\n    });\n  } finally {\n    try {\n      // try to get rid of the promise\n      await this.executeAtom('execute_script', [`delete window.${promiseName};`, [null, null], subcommandTimeout], frames);\n    } catch (ign) {}\n  }\n  return convertResult(res);\n}\n\nasync function execute (command, override) {\n  // if the page is not loaded yet, wait for it\n  if (this.pageLoading && !override) {\n    log.debug('Trying to execute but page is not loaded.');\n    await this.waitForDom();\n  }\n\n  checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n  if (this.garbageCollectOnExecute) {\n    await this.garbageCollect();\n  }\n\n  log.debug(`Sending javascript command: '${_.truncate(command, {length: 50})}'`);\n  const res = await this.rpcClient.send('Runtime.evaluate', {\n    expression: command,\n    returnByValue: true,\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n  });\n\n  return convertResult(res);\n}\n\nasync function callFunction (objectId, fn, args) {\n  checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n  if (this.garbageCollectOnExecute) {\n    await this.garbageCollect();\n  }\n\n  log.debug('Calling javascript function');\n  const res = await this.rpcClient.send('Runtime.callFunctionOn', {\n    objectId,\n    functionDeclaration: fn,\n    arguments: args,\n    returnByValue: true,\n    appIdKey: this.appIdKey,\n    pageIdKey: this.pageIdKey,\n  });\n\n  return convertResult(res);\n}\n\n\nexport default { executeAtom, executeAtomAsync, execute, callFunction };\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execute.js","names":["RPC_RESPONSE_TIMEOUT_MS","executeAtom","atom","args","frames","rpcClient","isConnected","Error","log","debug","JSON","stringify","script","getScriptForAtom","value","execute","_","truncate","simpleStringify","length","RESPONSE_LOG_LENGTH","executeAtomAsync","evaluate","method","opts","send","Object","assign","appIdKey","pageIdKey","returnByValue","promiseName","util","uuidV4","replace","obj","expression","promiseObjectId","result","objectId","asyncCallBack","res","subcommandTimeout","generatePreview","saveResult","err","message","includes","retryWait","timeout","retries","parseInt","timer","timing","Timer","start","retryInterval","hasValue","errors","TimeoutError","getDuration","asMilliSeconds","toFixed","ign","convertResult","command","override","pageLoading","waitForDom","checkParams","garbageCollectOnExecute","garbageCollect","callFunction","fn","functionDeclaration","arguments"],"sources":["../../../lib/mixins/execute.js"],"sourcesContent":["import log from '../logger';\nimport { errors } from 'appium/driver';\nimport { checkParams, simpleStringify, convertResult, RESPONSE_LOG_LENGTH } from '../utils';\nimport { getScriptForAtom } from '../atoms';\nimport { util, timing } from 'appium/support';\nimport { retryInterval } from 'asyncbox';\nimport _ from 'lodash';\n\n\n/* How many milliseconds to wait for webkit to return a response before timing out */\nconst RPC_RESPONSE_TIMEOUT_MS = 5000;\n\n/**\n * Execute a Selenium atom in Safari\n * @param {string} atom Name of Selenium atom (see atoms/ directory)\n * @param {Array<*>} args Arguments passed to the atom\n * @param {Array<string>} frames\n * @returns {string} The result received from the atom\n */\nasync function executeAtom (atom, args, frames) {\n if (!this.rpcClient.isConnected) {\n throw new Error('Remote debugger is not connected');\n }\n\n log.debug(`Executing atom '${atom}' with 'args=${JSON.stringify(args)}; frames=${frames}'`);\n const script = await getScriptForAtom(atom, args, frames);\n const value = await this.execute(script, true);\n log.debug(`Received result for atom '${atom}' execution: ${_.truncate(simpleStringify(value), {length: RESPONSE_LOG_LENGTH})}`);\n return value;\n}\n\nasync function executeAtomAsync (atom, args, frames) {\n // helper to send directly to the web inspector\n const evaluate = async (method, opts) => await this.rpcClient.send(method, Object.assign({\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n returnByValue: false,\n }, opts));\n\n // first create a Promise on the page, saving the resolve/reject functions\n // as properties\n const promiseName = `appiumAsyncExecutePromise${util.uuidV4().replace(/-/g, '')}`;\n const script =\n `var res, rej;\n window.${promiseName} = new Promise(function (resolve, reject) {\n res = resolve;\n rej = reject;\n });\n window.${promiseName}.resolve = res;\n window.${promiseName}.reject = rej;\n window.${promiseName};`;\n const obj = await evaluate('Runtime.evaluate', {\n expression: script,\n });\n const promiseObjectId = obj.result.objectId;\n\n // execute the atom, calling back to the resolve function\n const asyncCallBack =\n `function (res) {\n window.${promiseName}.resolve(res);\n window.${promiseName}Value = res;\n }`;\n await this.execute(await getScriptForAtom(atom, args, frames, asyncCallBack));\n\n // wait for the promise to be resolved\n let res;\n const subcommandTimeout = 1000; // timeout on individual commands\n try {\n res = await evaluate('Runtime.awaitPromise', {\n promiseObjectId,\n returnByValue: true,\n generatePreview: true,\n saveResult: true,\n });\n } catch (err) {\n if (!err.message.includes(`'Runtime.awaitPromise' was not found`)) {\n throw err;\n }\n // awaitPromise is not always available, so simulate it with poll\n const retryWait = 100;\n const timeout = (args.length >= 3) ? args[2] : RPC_RESPONSE_TIMEOUT_MS;\n // if the timeout math turns up 0 retries, make sure it happens once\n const retries = parseInt(timeout / retryWait, 10) || 1;\n const timer = new timing.Timer().start();\n log.debug(`Waiting up to ${timeout}ms for async execute to finish`);\n res = await retryInterval(retries, retryWait, async () => {\n // the atom _will_ return, either because it finished or an error\n // including a timeout error\n const hasValue = await evaluate('Runtime.evaluate', {\n expression: `window.hasOwnProperty('${promiseName}Value');`,\n returnByValue: true,\n });\n if (hasValue) {\n // we only put the property on `window` when the callback is called,\n // so if it is there, everything is done\n return await evaluate('Runtime.evaluate', {\n expression: `window.${promiseName}Value;`,\n returnByValue: true,\n });\n }\n // throw a TimeoutError, or else it needs to be caught and re-thrown\n throw new errors.TimeoutError(`Timed out waiting for asynchronous script ` +\n `result after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms'));`);\n });\n } finally {\n try {\n // try to get rid of the promise\n await this.executeAtom('execute_script', [`delete window.${promiseName};`, [null, null], subcommandTimeout], frames);\n } catch (ign) {}\n }\n return convertResult(res);\n}\n\nasync function execute (command, override) {\n // if the page is not loaded yet, wait for it\n if (this.pageLoading && !override) {\n log.debug('Trying to execute but page is not loaded.');\n await this.waitForDom();\n }\n\n checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n if (this.garbageCollectOnExecute) {\n await this.garbageCollect();\n }\n\n log.debug(`Sending javascript command: '${_.truncate(command, {length: 50})}'`);\n const res = await this.rpcClient.send('Runtime.evaluate', {\n expression: command,\n returnByValue: true,\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n });\n\n return convertResult(res);\n}\n\nasync function callFunction (objectId, fn, args) {\n checkParams({appIdKey: this.appIdKey, pageIdKey: this.pageIdKey});\n\n if (this.garbageCollectOnExecute) {\n await this.garbageCollect();\n }\n\n log.debug('Calling javascript function');\n const res = await this.rpcClient.send('Runtime.callFunctionOn', {\n objectId,\n functionDeclaration: fn,\n arguments: args,\n returnByValue: true,\n appIdKey: this.appIdKey,\n pageIdKey: this.pageIdKey,\n });\n\n return convertResult(res);\n}\n\n\nexport default { executeAtom, executeAtomAsync, execute, callFunction };\n"],"mappings":"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"}
@@ -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
  });
@@ -13,21 +12,14 @@ Object.defineProperty(exports, "events", {
13
12
  }
14
13
  });
15
14
  exports.mixins = void 0;
16
-
17
15
  require("source-map-support/register");
18
-
19
16
  var _connect = _interopRequireDefault(require("./connect"));
20
-
21
17
  var _events = _interopRequireDefault(require("./events"));
22
-
23
18
  var _execute = _interopRequireDefault(require("./execute"));
24
-
25
19
  var _navigate = _interopRequireDefault(require("./navigate"));
26
-
27
20
  var _messageHandlers = _interopRequireDefault(require("./message-handlers"));
28
-
29
21
  const mixins = Object.assign({}, _connect.default, _events.default, _execute.default, _navigate.default, _messageHandlers.default);
30
22
  exports.mixins = mixins;
31
23
  var _default = mixins;
32
24
  exports.default = _default;
33
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtaXhpbnMiLCJPYmplY3QiLCJhc3NpZ24iLCJjb25uZWN0IiwiZXZlbnRzIiwiZXhlY3V0ZSIsIm5hdmlnYXRlIiwibWVzc2FnZUhhbmRsZXJzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL21peGlucy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29ubmVjdCBmcm9tICcuL2Nvbm5lY3QnO1xuaW1wb3J0IGV2ZW50cyBmcm9tICcuL2V2ZW50cyc7XG5pbXBvcnQgZXhlY3V0ZSBmcm9tICcuL2V4ZWN1dGUnO1xuaW1wb3J0IG5hdmlnYXRlIGZyb20gJy4vbmF2aWdhdGUnO1xuaW1wb3J0IG1lc3NhZ2VIYW5kbGVycyBmcm9tICcuL21lc3NhZ2UtaGFuZGxlcnMnO1xuXG5cbmNvbnN0IG1peGlucyA9IE9iamVjdC5hc3NpZ24oe30sXG4gIGNvbm5lY3QsIGV2ZW50cywgZXhlY3V0ZSwgbmF2aWdhdGUsIG1lc3NhZ2VIYW5kbGVyc1xuKTtcblxuXG5leHBvcnQgeyBtaXhpbnMsIGV2ZW50cyB9O1xuZXhwb3J0IGRlZmF1bHQgbWl4aW5zO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFHQSxNQUFNQSxNQUFNLEdBQUdDLE1BQU0sQ0FBQ0MsTUFBUCxDQUFjLEVBQWQsRUFDYkMsZ0JBRGEsRUFDSkMsZUFESSxFQUNJQyxnQkFESixFQUNhQyxpQkFEYixFQUN1QkMsd0JBRHZCLENBQWY7O2VBTWVQLE0ifQ==
25
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtaXhpbnMiLCJPYmplY3QiLCJhc3NpZ24iLCJjb25uZWN0IiwiZXZlbnRzIiwiZXhlY3V0ZSIsIm5hdmlnYXRlIiwibWVzc2FnZUhhbmRsZXJzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vbGliL21peGlucy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY29ubmVjdCBmcm9tICcuL2Nvbm5lY3QnO1xuaW1wb3J0IGV2ZW50cyBmcm9tICcuL2V2ZW50cyc7XG5pbXBvcnQgZXhlY3V0ZSBmcm9tICcuL2V4ZWN1dGUnO1xuaW1wb3J0IG5hdmlnYXRlIGZyb20gJy4vbmF2aWdhdGUnO1xuaW1wb3J0IG1lc3NhZ2VIYW5kbGVycyBmcm9tICcuL21lc3NhZ2UtaGFuZGxlcnMnO1xuXG5cbmNvbnN0IG1peGlucyA9IE9iamVjdC5hc3NpZ24oe30sXG4gIGNvbm5lY3QsIGV2ZW50cywgZXhlY3V0ZSwgbmF2aWdhdGUsIG1lc3NhZ2VIYW5kbGVyc1xuKTtcblxuXG5leHBvcnQgeyBtaXhpbnMsIGV2ZW50cyB9O1xuZXhwb3J0IGRlZmF1bHQgbWl4aW5zO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0EsTUFBTUEsTUFBTSxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFDN0JDLGdCQUFPLEVBQUVDLGVBQU0sRUFBRUMsZ0JBQU8sRUFBRUMsaUJBQVEsRUFBRUMsd0JBQWUsQ0FDcEQ7QUFBQztBQUFBLGVBSWFQLE1BQU07QUFBQSJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["mixins","Object","assign","connect","events","execute","navigate","messageHandlers"],"sources":["../../../lib/mixins/index.js"],"sourcesContent":["import connect from './connect';\nimport events from './events';\nimport execute from './execute';\nimport navigate from './navigate';\nimport messageHandlers from './message-handlers';\n\n\nconst mixins = Object.assign({},\n connect, events, execute, navigate, messageHandlers\n);\n\n\nexport { mixins, events };\nexport default mixins;\n"],"mappings":";;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AAGA,MAAMA,MAAM,GAAGC,MAAM,CAACC,MAAM,CAAC,CAAC,CAAC,EAC7BC,gBAAO,EAAEC,eAAM,EAAEC,gBAAO,EAAEC,iBAAQ,EAAEC,wBAAe,CACpD;AAAC;AAAA,eAIaP,MAAM;AAAA"}
@@ -1,27 +1,20 @@
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 = void 0;
9
-
10
8
  require("source-map-support/register");
11
-
12
9
  var _logger = _interopRequireDefault(require("../logger"));
13
-
14
10
  var _events = _interopRequireDefault(require("./events"));
15
-
16
11
  var _utils = require("../utils");
17
-
18
12
  var _lodash = _interopRequireDefault(require("lodash"));
19
13
 
20
14
  async function onPageChange(err, appIdKey, pageDict) {
21
15
  if (_lodash.default.isEmpty(pageDict)) {
22
16
  return;
23
17
  }
24
-
25
18
  const pageArray = (0, _utils.pageArrayFromDict)(pageDict);
26
19
  await this.useAppDictLock(done => {
27
20
  try {
@@ -32,36 +25,28 @@ async function onPageChange(err, appIdKey, pageDict) {
32
25
  } else {
33
26
  if (_lodash.default.isEqual(this.appDict[appIdKey].pageArray, pageArray)) {
34
27
  _logger.default.debug(`Received page change notice for app '${appIdKey}' ` + `but the listing has not changed. Ignoring.`);
35
-
36
28
  return done();
37
29
  }
38
30
  }
39
31
  }
40
-
41
32
  this.appDict[appIdKey].pageArray = pageArray;
42
33
  }
43
34
  } finally {
44
35
  done();
45
36
  }
46
37
  });
47
-
48
38
  if (this._navigatingToPage) {
49
39
  return;
50
40
  }
51
-
52
41
  _logger.default.debug(`Page changed: ${(0, _utils.simpleStringify)(pageDict, true)}`);
53
-
54
42
  this.emit(_events.default.EVENT_PAGE_CHANGE, {
55
43
  appIdKey: appIdKey.replace('PID:', ''),
56
44
  pageArray
57
45
  });
58
46
  }
59
-
60
47
  async function onAppConnect(err, dict) {
61
48
  const appIdKey = dict.WIRApplicationIdentifierKey;
62
-
63
49
  _logger.default.debug(`Notified that new application '${appIdKey}' has connected`);
64
-
65
50
  await this.useAppDictLock(done => {
66
51
  try {
67
52
  this.updateAppsWithDict(dict);
@@ -70,30 +55,23 @@ async function onAppConnect(err, dict) {
70
55
  }
71
56
  });
72
57
  }
73
-
74
58
  function onAppDisconnect(err, dict) {
75
59
  const appIdKey = dict.WIRApplicationIdentifierKey;
76
-
77
60
  _logger.default.debug(`Application '${appIdKey}' disconnected. Removing from app dictionary.`);
78
-
79
61
  _logger.default.debug(`Current app is '${this.appIdKey}'`);
80
62
 
81
63
  delete this.appDict[appIdKey];
82
64
 
83
65
  if (this.appIdKey === appIdKey) {
84
66
  _logger.default.debug(`No longer have app id. Attempting to find new one.`);
85
-
86
67
  this.appIdKey = (0, _utils.getDebuggerAppKey)(this.bundleId, this.appDict);
87
68
  }
88
-
89
69
  if (!this.appDict) {
90
70
  _logger.default.debug('Main app disconnected. Disconnecting altogether.');
91
-
92
71
  this.connected = false;
93
72
  this.emit(_events.default.EVENT_DISCONNECT, true);
94
73
  }
95
74
  }
96
-
97
75
  async function onAppUpdate(err, dict) {
98
76
  await this.useAppDictLock(done => {
99
77
  try {
@@ -103,34 +81,25 @@ async function onAppUpdate(err, dict) {
103
81
  }
104
82
  });
105
83
  }
106
-
107
84
  function onConnectedDriverList(err, drivers) {
108
85
  this.connectedDrivers = drivers.WIRDriverDictionaryKey;
109
-
110
86
  _logger.default.debug(`Received connected driver list: ${JSON.stringify(this.connectedDrivers)}`);
111
87
  }
112
-
113
88
  function onCurrentState(err, state) {
114
89
  this.currentState = state.WIRAutomationAvailabilityKey;
115
-
116
90
  _logger.default.debug(`Received connected automation availability state: ${JSON.stringify(this.currentState)}`);
117
91
  }
118
-
119
92
  async function onConnectedApplicationList(err, apps) {
120
93
  _logger.default.debug(`Received connected applications list: ${_lodash.default.keys(apps).join(', ')}`);
121
94
 
122
95
  let newDict = {};
123
-
124
96
  for (const dict of _lodash.default.values(apps)) {
125
97
  const [id, entry] = (0, _utils.appInfoFromDict)(dict);
126
-
127
98
  if (this.skippedApps.includes(entry.name)) {
128
99
  continue;
129
100
  }
130
-
131
101
  newDict[id] = entry;
132
102
  }
133
-
134
103
  await this.useAppDictLock(done => {
135
104
  try {
136
105
  _lodash.default.defaults(this.appDict, newDict);
@@ -139,7 +108,6 @@ async function onConnectedApplicationList(err, apps) {
139
108
  }
140
109
  });
141
110
  }
142
-
143
111
  const messageHandlers = {
144
112
  onPageChange,
145
113
  onAppConnect,
@@ -151,4 +119,4 @@ const messageHandlers = {
151
119
  };
152
120
  var _default = messageHandlers;
153
121
  exports.default = _default;
154
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["onPageChange","err","appIdKey","pageDict","_","isEmpty","pageArray","pageArrayFromDict","useAppDictLock","done","appDict","resolve","isEqual","log","debug","_navigatingToPage","simpleStringify","emit","events","EVENT_PAGE_CHANGE","replace","onAppConnect","dict","WIRApplicationIdentifierKey","updateAppsWithDict","onAppDisconnect","getDebuggerAppKey","bundleId","connected","EVENT_DISCONNECT","onAppUpdate","onConnectedDriverList","drivers","connectedDrivers","WIRDriverDictionaryKey","JSON","stringify","onCurrentState","state","currentState","WIRAutomationAvailabilityKey","onConnectedApplicationList","apps","keys","join","newDict","values","id","entry","appInfoFromDict","skippedApps","includes","name","defaults","messageHandlers"],"sources":["../../../lib/mixins/message-handlers.js"],"sourcesContent":["import log from '../logger';\nimport events from './events';\nimport { pageArrayFromDict, getDebuggerAppKey, simpleStringify, appInfoFromDict } from '../utils';\nimport _ from 'lodash';\n\n\n/*\n * Generic callbacks used throughout the lifecycle of the Remote Debugger.\n * These will be added to the prototype.\n */\n\nasync function onPageChange (err, appIdKey, pageDict) {\n  if (_.isEmpty(pageDict)) {\n    return;\n  }\n\n  const pageArray = pageArrayFromDict(pageDict);\n\n  await this.useAppDictLock((done) => {\n    try {\n      // save the page dict for this app\n      if (this.appDict[appIdKey]) {\n        if (this.appDict[appIdKey].pageArray) {\n          if (this.appDict[appIdKey].pageArray.resolve) {\n            // pageDict is a pending promise, so resolve\n            this.appDict[appIdKey].pageArray.resolve();\n          } else {\n            // we have a pre-existing pageDict\n            if (_.isEqual(this.appDict[appIdKey].pageArray, pageArray)) {\n              log.debug(`Received page change notice for app '${appIdKey}' ` +\n                        `but the listing has not changed. Ignoring.`);\n              return done();\n            }\n          }\n        }\n        // keep track of the page dictionary\n        this.appDict[appIdKey].pageArray = pageArray;\n      }\n    } finally {\n      done();\n    }\n  });\n\n  if (this._navigatingToPage) {\n    // in the middle of navigating, so reporting a page change will cause problems\n    return;\n  }\n\n  log.debug(`Page changed: ${simpleStringify(pageDict, true)}`);\n\n  this.emit(events.EVENT_PAGE_CHANGE, {\n    appIdKey: appIdKey.replace('PID:', ''),\n    pageArray,\n  });\n}\n\nasync function onAppConnect (err, dict) {\n  const appIdKey = dict.WIRApplicationIdentifierKey;\n  log.debug(`Notified that new application '${appIdKey}' has connected`);\n  await this.useAppDictLock((done) => {\n    try {\n      this.updateAppsWithDict(dict);\n    } finally {\n      done();\n    }\n  });\n}\n\nfunction onAppDisconnect (err, dict) {\n  const appIdKey = dict.WIRApplicationIdentifierKey;\n  log.debug(`Application '${appIdKey}' disconnected. Removing from app dictionary.`);\n  log.debug(`Current app is '${this.appIdKey}'`);\n\n  // get rid of the entry in our app dictionary,\n  // since it is no longer available\n  delete this.appDict[appIdKey];\n\n  // if the disconnected app is the one we are connected to, try to find another\n  if (this.appIdKey === appIdKey) {\n    log.debug(`No longer have app id. Attempting to find new one.`);\n    this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n  }\n\n  if (!this.appDict) {\n    // this means we no longer have any apps. what the what?\n    log.debug('Main app disconnected. Disconnecting altogether.');\n    this.connected = false;\n    this.emit(events.EVENT_DISCONNECT, true);\n  }\n}\n\nasync function onAppUpdate (err, dict) {\n  await this.useAppDictLock((done) => {\n    try {\n      this.updateAppsWithDict(dict);\n    } finally {\n      done();\n    }\n  });\n}\n\nfunction onConnectedDriverList (err, drivers) {\n  this.connectedDrivers = drivers.WIRDriverDictionaryKey;\n  log.debug(`Received connected driver list: ${JSON.stringify(this.connectedDrivers)}`);\n}\n\nfunction onCurrentState (err, state) {\n  this.currentState = state.WIRAutomationAvailabilityKey;\n  // This state changes when 'Remote Automation' in 'Settings app' > 'Safari' > 'Advanced' > 'Remote Automation' changes\n  // WIRAutomationAvailabilityAvailable or WIRAutomationAvailabilityNotAvailable\n  log.debug(`Received connected automation availability state: ${JSON.stringify(this.currentState)}`);\n}\n\nasync function onConnectedApplicationList (err, apps) {\n  log.debug(`Received connected applications list: ${_.keys(apps).join(', ')}`);\n\n  // translate the received information into an easier-to-manage\n  // hash with app id as key, and app info as value\n  let newDict = {};\n  for (const dict of _.values(apps)) {\n    const [id, entry] = appInfoFromDict(dict);\n    if (this.skippedApps.includes(entry.name)) {\n      continue;\n    }\n    newDict[id] = entry;\n  }\n  // update the object's list of apps\n  await this.useAppDictLock((done) => {\n    try {\n      _.defaults(this.appDict, newDict);\n    } finally {\n      done();\n    }\n  });\n}\n\nconst messageHandlers = {\n  onPageChange,\n  onAppConnect,\n  onAppDisconnect,\n  onAppUpdate,\n  onConnectedDriverList,\n  onCurrentState,\n  onConnectedApplicationList,\n};\n\nexport default messageHandlers;\n"],"mappings":"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"}
122
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["onPageChange","err","appIdKey","pageDict","_","isEmpty","pageArray","pageArrayFromDict","useAppDictLock","done","appDict","resolve","isEqual","log","debug","_navigatingToPage","simpleStringify","emit","events","EVENT_PAGE_CHANGE","replace","onAppConnect","dict","WIRApplicationIdentifierKey","updateAppsWithDict","onAppDisconnect","getDebuggerAppKey","bundleId","connected","EVENT_DISCONNECT","onAppUpdate","onConnectedDriverList","drivers","connectedDrivers","WIRDriverDictionaryKey","JSON","stringify","onCurrentState","state","currentState","WIRAutomationAvailabilityKey","onConnectedApplicationList","apps","keys","join","newDict","values","id","entry","appInfoFromDict","skippedApps","includes","name","defaults","messageHandlers"],"sources":["../../../lib/mixins/message-handlers.js"],"sourcesContent":["import log from '../logger';\nimport events from './events';\nimport { pageArrayFromDict, getDebuggerAppKey, simpleStringify, appInfoFromDict } from '../utils';\nimport _ from 'lodash';\n\n\n/*\n * Generic callbacks used throughout the lifecycle of the Remote Debugger.\n * These will be added to the prototype.\n */\n\nasync function onPageChange (err, appIdKey, pageDict) {\n  if (_.isEmpty(pageDict)) {\n    return;\n  }\n\n  const pageArray = pageArrayFromDict(pageDict);\n\n  await this.useAppDictLock((done) => {\n    try {\n      // save the page dict for this app\n      if (this.appDict[appIdKey]) {\n        if (this.appDict[appIdKey].pageArray) {\n          if (this.appDict[appIdKey].pageArray.resolve) {\n            // pageDict is a pending promise, so resolve\n            this.appDict[appIdKey].pageArray.resolve();\n          } else {\n            // we have a pre-existing pageDict\n            if (_.isEqual(this.appDict[appIdKey].pageArray, pageArray)) {\n              log.debug(`Received page change notice for app '${appIdKey}' ` +\n                        `but the listing has not changed. Ignoring.`);\n              return done();\n            }\n          }\n        }\n        // keep track of the page dictionary\n        this.appDict[appIdKey].pageArray = pageArray;\n      }\n    } finally {\n      done();\n    }\n  });\n\n  if (this._navigatingToPage) {\n    // in the middle of navigating, so reporting a page change will cause problems\n    return;\n  }\n\n  log.debug(`Page changed: ${simpleStringify(pageDict, true)}`);\n\n  this.emit(events.EVENT_PAGE_CHANGE, {\n    appIdKey: appIdKey.replace('PID:', ''),\n    pageArray,\n  });\n}\n\nasync function onAppConnect (err, dict) {\n  const appIdKey = dict.WIRApplicationIdentifierKey;\n  log.debug(`Notified that new application '${appIdKey}' has connected`);\n  await this.useAppDictLock((done) => {\n    try {\n      this.updateAppsWithDict(dict);\n    } finally {\n      done();\n    }\n  });\n}\n\nfunction onAppDisconnect (err, dict) {\n  const appIdKey = dict.WIRApplicationIdentifierKey;\n  log.debug(`Application '${appIdKey}' disconnected. Removing from app dictionary.`);\n  log.debug(`Current app is '${this.appIdKey}'`);\n\n  // get rid of the entry in our app dictionary,\n  // since it is no longer available\n  delete this.appDict[appIdKey];\n\n  // if the disconnected app is the one we are connected to, try to find another\n  if (this.appIdKey === appIdKey) {\n    log.debug(`No longer have app id. Attempting to find new one.`);\n    this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n  }\n\n  if (!this.appDict) {\n    // this means we no longer have any apps. what the what?\n    log.debug('Main app disconnected. Disconnecting altogether.');\n    this.connected = false;\n    this.emit(events.EVENT_DISCONNECT, true);\n  }\n}\n\nasync function onAppUpdate (err, dict) {\n  await this.useAppDictLock((done) => {\n    try {\n      this.updateAppsWithDict(dict);\n    } finally {\n      done();\n    }\n  });\n}\n\nfunction onConnectedDriverList (err, drivers) {\n  this.connectedDrivers = drivers.WIRDriverDictionaryKey;\n  log.debug(`Received connected driver list: ${JSON.stringify(this.connectedDrivers)}`);\n}\n\nfunction onCurrentState (err, state) {\n  this.currentState = state.WIRAutomationAvailabilityKey;\n  // This state changes when 'Remote Automation' in 'Settings app' > 'Safari' > 'Advanced' > 'Remote Automation' changes\n  // WIRAutomationAvailabilityAvailable or WIRAutomationAvailabilityNotAvailable\n  log.debug(`Received connected automation availability state: ${JSON.stringify(this.currentState)}`);\n}\n\nasync function onConnectedApplicationList (err, apps) {\n  log.debug(`Received connected applications list: ${_.keys(apps).join(', ')}`);\n\n  // translate the received information into an easier-to-manage\n  // hash with app id as key, and app info as value\n  let newDict = {};\n  for (const dict of _.values(apps)) {\n    const [id, entry] = appInfoFromDict(dict);\n    if (this.skippedApps.includes(entry.name)) {\n      continue;\n    }\n    newDict[id] = entry;\n  }\n  // update the object's list of apps\n  await this.useAppDictLock((done) => {\n    try {\n      _.defaults(this.appDict, newDict);\n    } finally {\n      done();\n    }\n  });\n}\n\nconst messageHandlers = {\n  onPageChange,\n  onAppConnect,\n  onAppDisconnect,\n  onAppUpdate,\n  onConnectedDriverList,\n  onCurrentState,\n  onConnectedApplicationList,\n};\n\nexport default messageHandlers;\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"message-handlers.js","names":["onPageChange","err","appIdKey","pageDict","_","isEmpty","pageArray","pageArrayFromDict","useAppDictLock","done","appDict","resolve","isEqual","log","debug","_navigatingToPage","simpleStringify","emit","events","EVENT_PAGE_CHANGE","replace","onAppConnect","dict","WIRApplicationIdentifierKey","updateAppsWithDict","onAppDisconnect","getDebuggerAppKey","bundleId","connected","EVENT_DISCONNECT","onAppUpdate","onConnectedDriverList","drivers","connectedDrivers","WIRDriverDictionaryKey","JSON","stringify","onCurrentState","state","currentState","WIRAutomationAvailabilityKey","onConnectedApplicationList","apps","keys","join","newDict","values","id","entry","appInfoFromDict","skippedApps","includes","name","defaults","messageHandlers"],"sources":["../../../lib/mixins/message-handlers.js"],"sourcesContent":["import log from '../logger';\nimport events from './events';\nimport { pageArrayFromDict, getDebuggerAppKey, simpleStringify, appInfoFromDict } from '../utils';\nimport _ from 'lodash';\n\n\n/*\n * Generic callbacks used throughout the lifecycle of the Remote Debugger.\n * These will be added to the prototype.\n */\n\nasync function onPageChange (err, appIdKey, pageDict) {\n if (_.isEmpty(pageDict)) {\n return;\n }\n\n const pageArray = pageArrayFromDict(pageDict);\n\n await this.useAppDictLock((done) => {\n try {\n // save the page dict for this app\n if (this.appDict[appIdKey]) {\n if (this.appDict[appIdKey].pageArray) {\n if (this.appDict[appIdKey].pageArray.resolve) {\n // pageDict is a pending promise, so resolve\n this.appDict[appIdKey].pageArray.resolve();\n } else {\n // we have a pre-existing pageDict\n if (_.isEqual(this.appDict[appIdKey].pageArray, pageArray)) {\n log.debug(`Received page change notice for app '${appIdKey}' ` +\n `but the listing has not changed. Ignoring.`);\n return done();\n }\n }\n }\n // keep track of the page dictionary\n this.appDict[appIdKey].pageArray = pageArray;\n }\n } finally {\n done();\n }\n });\n\n if (this._navigatingToPage) {\n // in the middle of navigating, so reporting a page change will cause problems\n return;\n }\n\n log.debug(`Page changed: ${simpleStringify(pageDict, true)}`);\n\n this.emit(events.EVENT_PAGE_CHANGE, {\n appIdKey: appIdKey.replace('PID:', ''),\n pageArray,\n });\n}\n\nasync function onAppConnect (err, dict) {\n const appIdKey = dict.WIRApplicationIdentifierKey;\n log.debug(`Notified that new application '${appIdKey}' has connected`);\n await this.useAppDictLock((done) => {\n try {\n this.updateAppsWithDict(dict);\n } finally {\n done();\n }\n });\n}\n\nfunction onAppDisconnect (err, dict) {\n const appIdKey = dict.WIRApplicationIdentifierKey;\n log.debug(`Application '${appIdKey}' disconnected. Removing from app dictionary.`);\n log.debug(`Current app is '${this.appIdKey}'`);\n\n // get rid of the entry in our app dictionary,\n // since it is no longer available\n delete this.appDict[appIdKey];\n\n // if the disconnected app is the one we are connected to, try to find another\n if (this.appIdKey === appIdKey) {\n log.debug(`No longer have app id. Attempting to find new one.`);\n this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n }\n\n if (!this.appDict) {\n // this means we no longer have any apps. what the what?\n log.debug('Main app disconnected. Disconnecting altogether.');\n this.connected = false;\n this.emit(events.EVENT_DISCONNECT, true);\n }\n}\n\nasync function onAppUpdate (err, dict) {\n await this.useAppDictLock((done) => {\n try {\n this.updateAppsWithDict(dict);\n } finally {\n done();\n }\n });\n}\n\nfunction onConnectedDriverList (err, drivers) {\n this.connectedDrivers = drivers.WIRDriverDictionaryKey;\n log.debug(`Received connected driver list: ${JSON.stringify(this.connectedDrivers)}`);\n}\n\nfunction onCurrentState (err, state) {\n this.currentState = state.WIRAutomationAvailabilityKey;\n // This state changes when 'Remote Automation' in 'Settings app' > 'Safari' > 'Advanced' > 'Remote Automation' changes\n // WIRAutomationAvailabilityAvailable or WIRAutomationAvailabilityNotAvailable\n log.debug(`Received connected automation availability state: ${JSON.stringify(this.currentState)}`);\n}\n\nasync function onConnectedApplicationList (err, apps) {\n log.debug(`Received connected applications list: ${_.keys(apps).join(', ')}`);\n\n // translate the received information into an easier-to-manage\n // hash with app id as key, and app info as value\n let newDict = {};\n for (const dict of _.values(apps)) {\n const [id, entry] = appInfoFromDict(dict);\n if (this.skippedApps.includes(entry.name)) {\n continue;\n }\n newDict[id] = entry;\n }\n // update the object's list of apps\n await this.useAppDictLock((done) => {\n try {\n _.defaults(this.appDict, newDict);\n } finally {\n done();\n }\n });\n}\n\nconst messageHandlers = {\n onPageChange,\n onAppConnect,\n onAppDisconnect,\n onAppUpdate,\n onConnectedDriverList,\n onCurrentState,\n onConnectedApplicationList,\n};\n\nexport default messageHandlers;\n"],"mappings":"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"}