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
package/CHANGELOG.md ADDED
@@ -0,0 +1 @@
1
+ ## [9.1.4](https://github.com/appium/appium-remote-debugger/compare/v9.1.3...v9.1.4) (2022-11-06)
package/build/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
  });
@@ -24,13 +23,9 @@ Object.defineProperty(exports, "RemoteDebuggerRealDevice", {
24
23
  }
25
24
  });
26
25
  exports.createRemoteDebugger = createRemoteDebugger;
27
-
28
26
  require("source-map-support/register");
29
-
30
27
  var _remoteDebugger = require("./lib/remote-debugger");
31
-
32
28
  var _remoteDebuggerRealDevice = _interopRequireDefault(require("./lib/remote-debugger-real-device"));
33
-
34
29
  function createRemoteDebugger(opts, realDevice = false) {
35
30
  if (realDevice) {
36
31
  return new _remoteDebuggerRealDevice.default(opts);
@@ -38,4 +33,4 @@ function createRemoteDebugger(opts, realDevice = false) {
38
33
  return new _remoteDebugger.RemoteDebugger(opts);
39
34
  }
40
35
  }
41
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZW1vdGVEZWJ1Z2dlciIsIm9wdHMiLCJyZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXIiXSwic291cmNlcyI6WyIuLi9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZW1vdGVEZWJ1Z2dlciwgUkVNT1RFX0RFQlVHR0VSX1BPUlQgfSBmcm9tICcuL2xpYi9yZW1vdGUtZGVidWdnZXInO1xuaW1wb3J0IFJlbW90ZURlYnVnZ2VyUmVhbERldmljZSBmcm9tICcuL2xpYi9yZW1vdGUtZGVidWdnZXItcmVhbC1kZXZpY2UnO1xuXG5cbmZ1bmN0aW9uIGNyZWF0ZVJlbW90ZURlYnVnZ2VyIChvcHRzLCByZWFsRGV2aWNlID0gZmFsc2UpIHtcbiAgaWYgKHJlYWxEZXZpY2UpIHtcbiAgICByZXR1cm4gbmV3IFJlbW90ZURlYnVnZ2VyUmVhbERldmljZShvcHRzKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gbmV3IFJlbW90ZURlYnVnZ2VyKG9wdHMpO1xuICB9XG59XG5cbmV4cG9ydCB7XG4gIGNyZWF0ZVJlbW90ZURlYnVnZ2VyLCBSZW1vdGVEZWJ1Z2dlciwgUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlLFxuICBSRU1PVEVfREVCVUdHRVJfUE9SVCxcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBR0EsU0FBU0Esb0JBQVQsQ0FBK0JDLElBQS9CLEVBQXFDQyxVQUFVLEdBQUcsS0FBbEQsRUFBeUQ7RUFDdkQsSUFBSUEsVUFBSixFQUFnQjtJQUNkLE9BQU8sSUFBSUMsaUNBQUosQ0FBNkJGLElBQTdCLENBQVA7RUFDRCxDQUZELE1BRU87SUFDTCxPQUFPLElBQUlHLDhCQUFKLENBQW1CSCxJQUFuQixDQUFQO0VBQ0Q7QUFDRiJ9
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZW1vdGVEZWJ1Z2dlciIsIm9wdHMiLCJyZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlIiwiUmVtb3RlRGVidWdnZXIiXSwic291cmNlcyI6WyIuLi9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZW1vdGVEZWJ1Z2dlciwgUkVNT1RFX0RFQlVHR0VSX1BPUlQgfSBmcm9tICcuL2xpYi9yZW1vdGUtZGVidWdnZXInO1xuaW1wb3J0IFJlbW90ZURlYnVnZ2VyUmVhbERldmljZSBmcm9tICcuL2xpYi9yZW1vdGUtZGVidWdnZXItcmVhbC1kZXZpY2UnO1xuXG5cbmZ1bmN0aW9uIGNyZWF0ZVJlbW90ZURlYnVnZ2VyIChvcHRzLCByZWFsRGV2aWNlID0gZmFsc2UpIHtcbiAgaWYgKHJlYWxEZXZpY2UpIHtcbiAgICByZXR1cm4gbmV3IFJlbW90ZURlYnVnZ2VyUmVhbERldmljZShvcHRzKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gbmV3IFJlbW90ZURlYnVnZ2VyKG9wdHMpO1xuICB9XG59XG5cbmV4cG9ydCB7XG4gIGNyZWF0ZVJlbW90ZURlYnVnZ2VyLCBSZW1vdGVEZWJ1Z2dlciwgUmVtb3RlRGVidWdnZXJSZWFsRGV2aWNlLFxuICBSRU1PVEVfREVCVUdHRVJfUE9SVCxcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFDQTtBQUdBLFNBQVNBLG9CQUFvQixDQUFFQyxJQUFJLEVBQUVDLFVBQVUsR0FBRyxLQUFLLEVBQUU7RUFDdkQsSUFBSUEsVUFBVSxFQUFFO0lBQ2QsT0FBTyxJQUFJQyxpQ0FBd0IsQ0FBQ0YsSUFBSSxDQUFDO0VBQzNDLENBQUMsTUFBTTtJQUNMLE9BQU8sSUFBSUcsOEJBQWMsQ0FBQ0gsSUFBSSxDQUFDO0VBQ2pDO0FBQ0YifQ==
@@ -1,80 +1,59 @@
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
8
  exports.getAtom = getAtom;
10
9
  exports.getScriptForAtom = getScriptForAtom;
11
-
12
10
  require("source-map-support/register");
13
-
14
11
  var _support = require("appium/support");
15
-
16
12
  var _path = _interopRequireDefault(require("path"));
17
-
18
13
  var _lodash = _interopRequireDefault(require("lodash"));
19
-
20
14
  var _logger = _interopRequireDefault(require("./logger"));
21
-
22
15
  const atomsCache = {};
23
-
24
16
  const inBuildDir = __filename.includes('build/lib/atoms');
25
-
26
17
  function getAtomFileName(atomName) {
27
18
  return inBuildDir ? _path.default.resolve(__dirname, '..', '..', 'atoms', `${atomName}.js`) : _path.default.resolve(__dirname, '..', 'atoms', `${atomName}.js`);
28
19
  }
29
-
30
20
  async function getAtom(atomName) {
31
21
  if (!_lodash.default.has(atomsCache, atomName)) {
32
22
  const atomFileName = getAtomFileName(atomName);
33
-
34
23
  try {
35
24
  atomsCache[atomName] = await _support.fs.readFile(atomFileName);
36
25
  } catch (e) {
37
26
  throw new Error(`Unable to load Atom '${atomName}' from file '${atomFileName}'`);
38
27
  }
39
28
  }
40
-
41
29
  return atomsCache[atomName];
42
30
  }
43
-
44
31
  async function wrapScriptForFrame(script, frame) {
45
32
  _logger.default.debug(`Wrapping script for frame '${frame}'`);
46
-
47
33
  const elFromCache = await getAtom('get_element_from_cache');
48
34
  return `(function (window) { var document = window.document; ` + `return (${script}); })((${elFromCache.toString('utf8')})(${JSON.stringify(frame)}))`;
49
35
  }
50
-
51
36
  async function getScriptForAtom(atom, args, frames = [], asyncCallBack = null) {
52
37
  const atomSrc = await getAtom(atom);
53
38
  let script;
54
-
55
39
  if (frames.length > 0) {
56
40
  script = atomSrc;
57
-
58
41
  for (const frame of frames) {
59
42
  script = await wrapScriptForFrame(script, frame);
60
43
  }
61
44
  } else {
62
45
  _logger.default.debug(`Executing '${atom}' atom in default context`);
63
-
64
46
  script = `(${atomSrc})`;
65
47
  }
66
48
 
67
49
  args = args.map(JSON.stringify);
68
-
69
50
  if (asyncCallBack) {
70
51
  script += `(${args.join(',')}, ${asyncCallBack}, true)`;
71
52
  } else {
72
53
  script += `(${args.join(',')})`;
73
54
  }
74
-
75
55
  return script;
76
56
  }
77
-
78
57
  var _default = getAtom;
79
58
  exports.default = _default;
80
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhdG9tc0NhY2hlIiwiaW5CdWlsZERpciIsIl9fZmlsZW5hbWUiLCJpbmNsdWRlcyIsImdldEF0b21GaWxlTmFtZSIsImF0b21OYW1lIiwicGF0aCIsInJlc29sdmUiLCJfX2Rpcm5hbWUiLCJnZXRBdG9tIiwiXyIsImhhcyIsImF0b21GaWxlTmFtZSIsImZzIiwicmVhZEZpbGUiLCJlIiwiRXJyb3IiLCJ3cmFwU2NyaXB0Rm9yRnJhbWUiLCJzY3JpcHQiLCJmcmFtZSIsImxvZyIsImRlYnVnIiwiZWxGcm9tQ2FjaGUiLCJ0b1N0cmluZyIsIkpTT04iLCJzdHJpbmdpZnkiLCJnZXRTY3JpcHRGb3JBdG9tIiwiYXRvbSIsImFyZ3MiLCJmcmFtZXMiLCJhc3luY0NhbGxCYWNrIiwiYXRvbVNyYyIsImxlbmd0aCIsIm1hcCIsImpvaW4iXSwic291cmNlcyI6WyIuLi8uLi9saWIvYXRvbXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZnMgfSBmcm9tICdhcHBpdW0vc3VwcG9ydCc7XG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgbG9nIGZyb20gJy4vbG9nZ2VyJztcblxuXG5jb25zdCBhdG9tc0NhY2hlID0ge307XG5cbmNvbnN0IGluQnVpbGREaXIgPSBfX2ZpbGVuYW1lLmluY2x1ZGVzKCdidWlsZC9saWIvYXRvbXMnKTtcblxuZnVuY3Rpb24gZ2V0QXRvbUZpbGVOYW1lIChhdG9tTmFtZSkge1xuICByZXR1cm4gaW5CdWlsZERpclxuICAgID8gcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uJywgJy4uJywgJ2F0b21zJywgYCR7YXRvbU5hbWV9LmpzYClcbiAgICA6IHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLicsICdhdG9tcycsIGAke2F0b21OYW1lfS5qc2ApO1xufVxuXG5hc3luYyBmdW5jdGlvbiBnZXRBdG9tIChhdG9tTmFtZSkge1xuICAvLyBjaGVjayBpZiB3ZSBoYXZlIGFscmVhZHkgbG9hZGVkIGFuIGNhY2hlZCB0aGlzIGF0b21cbiAgaWYgKCFfLmhhcyhhdG9tc0NhY2hlLCBhdG9tTmFtZSkpIHtcbiAgICBjb25zdCBhdG9tRmlsZU5hbWUgPSBnZXRBdG9tRmlsZU5hbWUoYXRvbU5hbWUpO1xuICAgIHRyeSB7XG4gICAgICBhdG9tc0NhY2hlW2F0b21OYW1lXSA9IGF3YWl0IGZzLnJlYWRGaWxlKGF0b21GaWxlTmFtZSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmFibGUgdG8gbG9hZCBBdG9tICcke2F0b21OYW1lfScgZnJvbSBmaWxlICcke2F0b21GaWxlTmFtZX0nYCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGF0b21zQ2FjaGVbYXRvbU5hbWVdO1xufVxuXG5hc3luYyBmdW5jdGlvbiB3cmFwU2NyaXB0Rm9yRnJhbWUgKHNjcmlwdCwgZnJhbWUpIHtcbiAgbG9nLmRlYnVnKGBXcmFwcGluZyBzY3JpcHQgZm9yIGZyYW1lICcke2ZyYW1lfSdgKTtcbiAgY29uc3QgZWxGcm9tQ2FjaGUgPSBhd2FpdCBnZXRBdG9tKCdnZXRfZWxlbWVudF9mcm9tX2NhY2hlJyk7XG4gIHJldHVybiBgKGZ1bmN0aW9uICh3aW5kb3cpIHsgdmFyIGRvY3VtZW50ID0gd2luZG93LmRvY3VtZW50OyBgICtcbiAgICAgICAgIGByZXR1cm4gKCR7c2NyaXB0fSk7IH0pKCgke2VsRnJvbUNhY2hlLnRvU3RyaW5nKCd1dGY4Jyl9KSgke0pTT04uc3RyaW5naWZ5KGZyYW1lKX0pKWA7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGdldFNjcmlwdEZvckF0b20gKGF0b20sIGFyZ3MsIGZyYW1lcyA9IFtdLCBhc3luY0NhbGxCYWNrID0gbnVsbCkge1xuICBjb25zdCBhdG9tU3JjID0gYXdhaXQgZ2V0QXRvbShhdG9tKTtcbiAgbGV0IHNjcmlwdDtcbiAgaWYgKGZyYW1lcy5sZW5ndGggPiAwKSB7XG4gICAgc2NyaXB0ID0gYXRvbVNyYztcbiAgICBmb3IgKGNvbnN0IGZyYW1lIG9mIGZyYW1lcykge1xuICAgICAgc2NyaXB0ID0gYXdhaXQgd3JhcFNjcmlwdEZvckZyYW1lKHNjcmlwdCwgZnJhbWUpO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBsb2cuZGVidWcoYEV4ZWN1dGluZyAnJHthdG9tfScgYXRvbSBpbiBkZWZhdWx0IGNvbnRleHRgKTtcbiAgICBzY3JpcHQgPSBgKCR7YXRvbVNyY30pYDtcbiAgfVxuXG4gIC8vIGFkZCB0aGUgYXJndW1lbnRzLCBhcyBzdHJpbmdzXG4gIGFyZ3MgPSBhcmdzLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIGlmIChhc3luY0NhbGxCYWNrKSB7XG4gICAgc2NyaXB0ICs9IGAoJHthcmdzLmpvaW4oJywnKX0sICR7YXN5bmNDYWxsQmFja30sIHRydWUpYDtcbiAgfSBlbHNlIHtcbiAgICBzY3JpcHQgKz0gYCgke2FyZ3Muam9pbignLCcpfSlgO1xuICB9XG5cbiAgcmV0dXJuIHNjcmlwdDtcbn1cblxuZXhwb3J0IHsgZ2V0QXRvbSwgZ2V0U2NyaXB0Rm9yQXRvbSB9O1xuZXhwb3J0IGRlZmF1bHQgZ2V0QXRvbTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUdBLE1BQU1BLFVBQVUsR0FBRyxFQUFuQjs7QUFFQSxNQUFNQyxVQUFVLEdBQUdDLFVBQVUsQ0FBQ0MsUUFBWCxDQUFvQixpQkFBcEIsQ0FBbkI7O0FBRUEsU0FBU0MsZUFBVCxDQUEwQkMsUUFBMUIsRUFBb0M7RUFDbEMsT0FBT0osVUFBVSxHQUNiSyxhQUFBLENBQUtDLE9BQUwsQ0FBYUMsU0FBYixFQUF3QixJQUF4QixFQUE4QixJQUE5QixFQUFvQyxPQUFwQyxFQUE4QyxHQUFFSCxRQUFTLEtBQXpELENBRGEsR0FFYkMsYUFBQSxDQUFLQyxPQUFMLENBQWFDLFNBQWIsRUFBd0IsSUFBeEIsRUFBOEIsT0FBOUIsRUFBd0MsR0FBRUgsUUFBUyxLQUFuRCxDQUZKO0FBR0Q7O0FBRUQsZUFBZUksT0FBZixDQUF3QkosUUFBeEIsRUFBa0M7RUFFaEMsSUFBSSxDQUFDSyxlQUFBLENBQUVDLEdBQUYsQ0FBTVgsVUFBTixFQUFrQkssUUFBbEIsQ0FBTCxFQUFrQztJQUNoQyxNQUFNTyxZQUFZLEdBQUdSLGVBQWUsQ0FBQ0MsUUFBRCxDQUFwQzs7SUFDQSxJQUFJO01BQ0ZMLFVBQVUsQ0FBQ0ssUUFBRCxDQUFWLEdBQXVCLE1BQU1RLFdBQUEsQ0FBR0MsUUFBSCxDQUFZRixZQUFaLENBQTdCO0lBQ0QsQ0FGRCxDQUVFLE9BQU9HLENBQVAsRUFBVTtNQUNWLE1BQU0sSUFBSUMsS0FBSixDQUFXLHdCQUF1QlgsUUFBUyxnQkFBZU8sWUFBYSxHQUF2RSxDQUFOO0lBQ0Q7RUFDRjs7RUFFRCxPQUFPWixVQUFVLENBQUNLLFFBQUQsQ0FBakI7QUFDRDs7QUFFRCxlQUFlWSxrQkFBZixDQUFtQ0MsTUFBbkMsRUFBMkNDLEtBQTNDLEVBQWtEO0VBQ2hEQyxlQUFBLENBQUlDLEtBQUosQ0FBVyw4QkFBNkJGLEtBQU0sR0FBOUM7O0VBQ0EsTUFBTUcsV0FBVyxHQUFHLE1BQU1iLE9BQU8sQ0FBQyx3QkFBRCxDQUFqQztFQUNBLE9BQVEsdURBQUQsR0FDQyxXQUFVUyxNQUFPLFVBQVNJLFdBQVcsQ0FBQ0MsUUFBWixDQUFxQixNQUFyQixDQUE2QixLQUFJQyxJQUFJLENBQUNDLFNBQUwsQ0FBZU4sS0FBZixDQUFzQixJQUR6RjtBQUVEOztBQUVELGVBQWVPLGdCQUFmLENBQWlDQyxJQUFqQyxFQUF1Q0MsSUFBdkMsRUFBNkNDLE1BQU0sR0FBRyxFQUF0RCxFQUEwREMsYUFBYSxHQUFHLElBQTFFLEVBQWdGO0VBQzlFLE1BQU1DLE9BQU8sR0FBRyxNQUFNdEIsT0FBTyxDQUFDa0IsSUFBRCxDQUE3QjtFQUNBLElBQUlULE1BQUo7O0VBQ0EsSUFBSVcsTUFBTSxDQUFDRyxNQUFQLEdBQWdCLENBQXBCLEVBQXVCO0lBQ3JCZCxNQUFNLEdBQUdhLE9BQVQ7O0lBQ0EsS0FBSyxNQUFNWixLQUFYLElBQW9CVSxNQUFwQixFQUE0QjtNQUMxQlgsTUFBTSxHQUFHLE1BQU1ELGtCQUFrQixDQUFDQyxNQUFELEVBQVNDLEtBQVQsQ0FBakM7SUFDRDtFQUNGLENBTEQsTUFLTztJQUNMQyxlQUFBLENBQUlDLEtBQUosQ0FBVyxjQUFhTSxJQUFLLDJCQUE3Qjs7SUFDQVQsTUFBTSxHQUFJLElBQUdhLE9BQVEsR0FBckI7RUFDRDs7RUFHREgsSUFBSSxHQUFHQSxJQUFJLENBQUNLLEdBQUwsQ0FBU1QsSUFBSSxDQUFDQyxTQUFkLENBQVA7O0VBQ0EsSUFBSUssYUFBSixFQUFtQjtJQUNqQlosTUFBTSxJQUFLLElBQUdVLElBQUksQ0FBQ00sSUFBTCxDQUFVLEdBQVYsQ0FBZSxLQUFJSixhQUFjLFNBQS9DO0VBQ0QsQ0FGRCxNQUVPO0lBQ0xaLE1BQU0sSUFBSyxJQUFHVSxJQUFJLENBQUNNLElBQUwsQ0FBVSxHQUFWLENBQWUsR0FBN0I7RUFDRDs7RUFFRCxPQUFPaEIsTUFBUDtBQUNEOztlQUdjVCxPIn0=
59
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhdG9tc0NhY2hlIiwiaW5CdWlsZERpciIsIl9fZmlsZW5hbWUiLCJpbmNsdWRlcyIsImdldEF0b21GaWxlTmFtZSIsImF0b21OYW1lIiwicGF0aCIsInJlc29sdmUiLCJfX2Rpcm5hbWUiLCJnZXRBdG9tIiwiXyIsImhhcyIsImF0b21GaWxlTmFtZSIsImZzIiwicmVhZEZpbGUiLCJlIiwiRXJyb3IiLCJ3cmFwU2NyaXB0Rm9yRnJhbWUiLCJzY3JpcHQiLCJmcmFtZSIsImxvZyIsImRlYnVnIiwiZWxGcm9tQ2FjaGUiLCJ0b1N0cmluZyIsIkpTT04iLCJzdHJpbmdpZnkiLCJnZXRTY3JpcHRGb3JBdG9tIiwiYXRvbSIsImFyZ3MiLCJmcmFtZXMiLCJhc3luY0NhbGxCYWNrIiwiYXRvbVNyYyIsImxlbmd0aCIsIm1hcCIsImpvaW4iXSwic291cmNlcyI6WyIuLi8uLi9saWIvYXRvbXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZnMgfSBmcm9tICdhcHBpdW0vc3VwcG9ydCc7XG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgbG9nIGZyb20gJy4vbG9nZ2VyJztcblxuXG5jb25zdCBhdG9tc0NhY2hlID0ge307XG5cbmNvbnN0IGluQnVpbGREaXIgPSBfX2ZpbGVuYW1lLmluY2x1ZGVzKCdidWlsZC9saWIvYXRvbXMnKTtcblxuZnVuY3Rpb24gZ2V0QXRvbUZpbGVOYW1lIChhdG9tTmFtZSkge1xuICByZXR1cm4gaW5CdWlsZERpclxuICAgID8gcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uJywgJy4uJywgJ2F0b21zJywgYCR7YXRvbU5hbWV9LmpzYClcbiAgICA6IHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLicsICdhdG9tcycsIGAke2F0b21OYW1lfS5qc2ApO1xufVxuXG5hc3luYyBmdW5jdGlvbiBnZXRBdG9tIChhdG9tTmFtZSkge1xuICAvLyBjaGVjayBpZiB3ZSBoYXZlIGFscmVhZHkgbG9hZGVkIGFuIGNhY2hlZCB0aGlzIGF0b21cbiAgaWYgKCFfLmhhcyhhdG9tc0NhY2hlLCBhdG9tTmFtZSkpIHtcbiAgICBjb25zdCBhdG9tRmlsZU5hbWUgPSBnZXRBdG9tRmlsZU5hbWUoYXRvbU5hbWUpO1xuICAgIHRyeSB7XG4gICAgICBhdG9tc0NhY2hlW2F0b21OYW1lXSA9IGF3YWl0IGZzLnJlYWRGaWxlKGF0b21GaWxlTmFtZSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmFibGUgdG8gbG9hZCBBdG9tICcke2F0b21OYW1lfScgZnJvbSBmaWxlICcke2F0b21GaWxlTmFtZX0nYCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGF0b21zQ2FjaGVbYXRvbU5hbWVdO1xufVxuXG5hc3luYyBmdW5jdGlvbiB3cmFwU2NyaXB0Rm9yRnJhbWUgKHNjcmlwdCwgZnJhbWUpIHtcbiAgbG9nLmRlYnVnKGBXcmFwcGluZyBzY3JpcHQgZm9yIGZyYW1lICcke2ZyYW1lfSdgKTtcbiAgY29uc3QgZWxGcm9tQ2FjaGUgPSBhd2FpdCBnZXRBdG9tKCdnZXRfZWxlbWVudF9mcm9tX2NhY2hlJyk7XG4gIHJldHVybiBgKGZ1bmN0aW9uICh3aW5kb3cpIHsgdmFyIGRvY3VtZW50ID0gd2luZG93LmRvY3VtZW50OyBgICtcbiAgICAgICAgIGByZXR1cm4gKCR7c2NyaXB0fSk7IH0pKCgke2VsRnJvbUNhY2hlLnRvU3RyaW5nKCd1dGY4Jyl9KSgke0pTT04uc3RyaW5naWZ5KGZyYW1lKX0pKWA7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGdldFNjcmlwdEZvckF0b20gKGF0b20sIGFyZ3MsIGZyYW1lcyA9IFtdLCBhc3luY0NhbGxCYWNrID0gbnVsbCkge1xuICBjb25zdCBhdG9tU3JjID0gYXdhaXQgZ2V0QXRvbShhdG9tKTtcbiAgbGV0IHNjcmlwdDtcbiAgaWYgKGZyYW1lcy5sZW5ndGggPiAwKSB7XG4gICAgc2NyaXB0ID0gYXRvbVNyYztcbiAgICBmb3IgKGNvbnN0IGZyYW1lIG9mIGZyYW1lcykge1xuICAgICAgc2NyaXB0ID0gYXdhaXQgd3JhcFNjcmlwdEZvckZyYW1lKHNjcmlwdCwgZnJhbWUpO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBsb2cuZGVidWcoYEV4ZWN1dGluZyAnJHthdG9tfScgYXRvbSBpbiBkZWZhdWx0IGNvbnRleHRgKTtcbiAgICBzY3JpcHQgPSBgKCR7YXRvbVNyY30pYDtcbiAgfVxuXG4gIC8vIGFkZCB0aGUgYXJndW1lbnRzLCBhcyBzdHJpbmdzXG4gIGFyZ3MgPSBhcmdzLm1hcChKU09OLnN0cmluZ2lmeSk7XG4gIGlmIChhc3luY0NhbGxCYWNrKSB7XG4gICAgc2NyaXB0ICs9IGAoJHthcmdzLmpvaW4oJywnKX0sICR7YXN5bmNDYWxsQmFja30sIHRydWUpYDtcbiAgfSBlbHNlIHtcbiAgICBzY3JpcHQgKz0gYCgke2FyZ3Muam9pbignLCcpfSlgO1xuICB9XG5cbiAgcmV0dXJuIHNjcmlwdDtcbn1cblxuZXhwb3J0IHsgZ2V0QXRvbSwgZ2V0U2NyaXB0Rm9yQXRvbSB9O1xuZXhwb3J0IGRlZmF1bHQgZ2V0QXRvbTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBR0EsTUFBTUEsVUFBVSxHQUFHLENBQUMsQ0FBQztBQUVyQixNQUFNQyxVQUFVLEdBQUdDLFVBQVUsQ0FBQ0MsUUFBUSxDQUFDLGlCQUFpQixDQUFDO0FBRXpELFNBQVNDLGVBQWUsQ0FBRUMsUUFBUSxFQUFFO0VBQ2xDLE9BQU9KLFVBQVUsR0FDYkssYUFBSSxDQUFDQyxPQUFPLENBQUNDLFNBQVMsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRyxHQUFFSCxRQUFTLEtBQUksQ0FBQyxHQUM5REMsYUFBSSxDQUFDQyxPQUFPLENBQUNDLFNBQVMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFHLEdBQUVILFFBQVMsS0FBSSxDQUFDO0FBQzlEO0FBRUEsZUFBZUksT0FBTyxDQUFFSixRQUFRLEVBQUU7RUFFaEMsSUFBSSxDQUFDSyxlQUFDLENBQUNDLEdBQUcsQ0FBQ1gsVUFBVSxFQUFFSyxRQUFRLENBQUMsRUFBRTtJQUNoQyxNQUFNTyxZQUFZLEdBQUdSLGVBQWUsQ0FBQ0MsUUFBUSxDQUFDO0lBQzlDLElBQUk7TUFDRkwsVUFBVSxDQUFDSyxRQUFRLENBQUMsR0FBRyxNQUFNUSxXQUFFLENBQUNDLFFBQVEsQ0FBQ0YsWUFBWSxDQUFDO0lBQ3hELENBQUMsQ0FBQyxPQUFPRyxDQUFDLEVBQUU7TUFDVixNQUFNLElBQUlDLEtBQUssQ0FBRSx3QkFBdUJYLFFBQVMsZ0JBQWVPLFlBQWEsR0FBRSxDQUFDO0lBQ2xGO0VBQ0Y7RUFFQSxPQUFPWixVQUFVLENBQUNLLFFBQVEsQ0FBQztBQUM3QjtBQUVBLGVBQWVZLGtCQUFrQixDQUFFQyxNQUFNLEVBQUVDLEtBQUssRUFBRTtFQUNoREMsZUFBRyxDQUFDQyxLQUFLLENBQUUsOEJBQTZCRixLQUFNLEdBQUUsQ0FBQztFQUNqRCxNQUFNRyxXQUFXLEdBQUcsTUFBTWIsT0FBTyxDQUFDLHdCQUF3QixDQUFDO0VBQzNELE9BQVEsdURBQXNELEdBQ3RELFdBQVVTLE1BQU8sVUFBU0ksV0FBVyxDQUFDQyxRQUFRLENBQUMsTUFBTSxDQUFFLEtBQUlDLElBQUksQ0FBQ0MsU0FBUyxDQUFDTixLQUFLLENBQUUsSUFBRztBQUM5RjtBQUVBLGVBQWVPLGdCQUFnQixDQUFFQyxJQUFJLEVBQUVDLElBQUksRUFBRUMsTUFBTSxHQUFHLEVBQUUsRUFBRUMsYUFBYSxHQUFHLElBQUksRUFBRTtFQUM5RSxNQUFNQyxPQUFPLEdBQUcsTUFBTXRCLE9BQU8sQ0FBQ2tCLElBQUksQ0FBQztFQUNuQyxJQUFJVCxNQUFNO0VBQ1YsSUFBSVcsTUFBTSxDQUFDRyxNQUFNLEdBQUcsQ0FBQyxFQUFFO0lBQ3JCZCxNQUFNLEdBQUdhLE9BQU87SUFDaEIsS0FBSyxNQUFNWixLQUFLLElBQUlVLE1BQU0sRUFBRTtNQUMxQlgsTUFBTSxHQUFHLE1BQU1ELGtCQUFrQixDQUFDQyxNQUFNLEVBQUVDLEtBQUssQ0FBQztJQUNsRDtFQUNGLENBQUMsTUFBTTtJQUNMQyxlQUFHLENBQUNDLEtBQUssQ0FBRSxjQUFhTSxJQUFLLDJCQUEwQixDQUFDO0lBQ3hEVCxNQUFNLEdBQUksSUFBR2EsT0FBUSxHQUFFO0VBQ3pCOztFQUdBSCxJQUFJLEdBQUdBLElBQUksQ0FBQ0ssR0FBRyxDQUFDVCxJQUFJLENBQUNDLFNBQVMsQ0FBQztFQUMvQixJQUFJSyxhQUFhLEVBQUU7SUFDakJaLE1BQU0sSUFBSyxJQUFHVSxJQUFJLENBQUNNLElBQUksQ0FBQyxHQUFHLENBQUUsS0FBSUosYUFBYyxTQUFRO0VBQ3pELENBQUMsTUFBTTtJQUNMWixNQUFNLElBQUssSUFBR1UsSUFBSSxDQUFDTSxJQUFJLENBQUMsR0FBRyxDQUFFLEdBQUU7RUFDakM7RUFFQSxPQUFPaEIsTUFBTTtBQUNmO0FBQUMsZUFHY1QsT0FBTztBQUFBIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"atoms.js","names":["atomsCache","inBuildDir","__filename","includes","getAtomFileName","atomName","path","resolve","__dirname","getAtom","_","has","atomFileName","fs","readFile","e","Error","wrapScriptForFrame","script","frame","log","debug","elFromCache","toString","JSON","stringify","getScriptForAtom","atom","args","frames","asyncCallBack","atomSrc","length","map","join"],"sources":["../../lib/atoms.js"],"sourcesContent":["import { fs } from 'appium/support';\nimport path from 'path';\nimport _ from 'lodash';\nimport log from './logger';\n\n\nconst atomsCache = {};\n\nconst inBuildDir = __filename.includes('build/lib/atoms');\n\nfunction getAtomFileName (atomName) {\n return inBuildDir\n ? path.resolve(__dirname, '..', '..', 'atoms', `${atomName}.js`)\n : path.resolve(__dirname, '..', 'atoms', `${atomName}.js`);\n}\n\nasync function getAtom (atomName) {\n // check if we have already loaded an cached this atom\n if (!_.has(atomsCache, atomName)) {\n const atomFileName = getAtomFileName(atomName);\n try {\n atomsCache[atomName] = await fs.readFile(atomFileName);\n } catch (e) {\n throw new Error(`Unable to load Atom '${atomName}' from file '${atomFileName}'`);\n }\n }\n\n return atomsCache[atomName];\n}\n\nasync function wrapScriptForFrame (script, frame) {\n log.debug(`Wrapping script for frame '${frame}'`);\n const elFromCache = await getAtom('get_element_from_cache');\n return `(function (window) { var document = window.document; ` +\n `return (${script}); })((${elFromCache.toString('utf8')})(${JSON.stringify(frame)}))`;\n}\n\nasync function getScriptForAtom (atom, args, frames = [], asyncCallBack = null) {\n const atomSrc = await getAtom(atom);\n let script;\n if (frames.length > 0) {\n script = atomSrc;\n for (const frame of frames) {\n script = await wrapScriptForFrame(script, frame);\n }\n } else {\n log.debug(`Executing '${atom}' atom in default context`);\n script = `(${atomSrc})`;\n }\n\n // add the arguments, as strings\n args = args.map(JSON.stringify);\n if (asyncCallBack) {\n script += `(${args.join(',')}, ${asyncCallBack}, true)`;\n } else {\n script += `(${args.join(',')})`;\n }\n\n return script;\n}\n\nexport { getAtom, getScriptForAtom };\nexport default getAtom;\n"],"mappings":";;;;;;;;;;AAAA;AACA;AACA;AACA;AAGA,MAAMA,UAAU,GAAG,CAAC,CAAC;AAErB,MAAMC,UAAU,GAAGC,UAAU,CAACC,QAAQ,CAAC,iBAAiB,CAAC;AAEzD,SAASC,eAAe,CAAEC,QAAQ,EAAE;EAClC,OAAOJ,UAAU,GACbK,aAAI,CAACC,OAAO,CAACC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAG,GAAEH,QAAS,KAAI,CAAC,GAC9DC,aAAI,CAACC,OAAO,CAACC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAG,GAAEH,QAAS,KAAI,CAAC;AAC9D;AAEA,eAAeI,OAAO,CAAEJ,QAAQ,EAAE;EAEhC,IAAI,CAACK,eAAC,CAACC,GAAG,CAACX,UAAU,EAAEK,QAAQ,CAAC,EAAE;IAChC,MAAMO,YAAY,GAAGR,eAAe,CAACC,QAAQ,CAAC;IAC9C,IAAI;MACFL,UAAU,CAACK,QAAQ,CAAC,GAAG,MAAMQ,WAAE,CAACC,QAAQ,CAACF,YAAY,CAAC;IACxD,CAAC,CAAC,OAAOG,CAAC,EAAE;MACV,MAAM,IAAIC,KAAK,CAAE,wBAAuBX,QAAS,gBAAeO,YAAa,GAAE,CAAC;IAClF;EACF;EAEA,OAAOZ,UAAU,CAACK,QAAQ,CAAC;AAC7B;AAEA,eAAeY,kBAAkB,CAAEC,MAAM,EAAEC,KAAK,EAAE;EAChDC,eAAG,CAACC,KAAK,CAAE,8BAA6BF,KAAM,GAAE,CAAC;EACjD,MAAMG,WAAW,GAAG,MAAMb,OAAO,CAAC,wBAAwB,CAAC;EAC3D,OAAQ,uDAAsD,GACtD,WAAUS,MAAO,UAASI,WAAW,CAACC,QAAQ,CAAC,MAAM,CAAE,KAAIC,IAAI,CAACC,SAAS,CAACN,KAAK,CAAE,IAAG;AAC9F;AAEA,eAAeO,gBAAgB,CAAEC,IAAI,EAAEC,IAAI,EAAEC,MAAM,GAAG,EAAE,EAAEC,aAAa,GAAG,IAAI,EAAE;EAC9E,MAAMC,OAAO,GAAG,MAAMtB,OAAO,CAACkB,IAAI,CAAC;EACnC,IAAIT,MAAM;EACV,IAAIW,MAAM,CAACG,MAAM,GAAG,CAAC,EAAE;IACrBd,MAAM,GAAGa,OAAO;IAChB,KAAK,MAAMZ,KAAK,IAAIU,MAAM,EAAE;MAC1BX,MAAM,GAAG,MAAMD,kBAAkB,CAACC,MAAM,EAAEC,KAAK,CAAC;IAClD;EACF,CAAC,MAAM;IACLC,eAAG,CAACC,KAAK,CAAE,cAAaM,IAAK,2BAA0B,CAAC;IACxDT,MAAM,GAAI,IAAGa,OAAQ,GAAE;EACzB;;EAGAH,IAAI,GAAGA,IAAI,CAACK,GAAG,CAACT,IAAI,CAACC,SAAS,CAAC;EAC/B,IAAIK,aAAa,EAAE;IACjBZ,MAAM,IAAK,IAAGU,IAAI,CAACM,IAAI,CAAC,GAAG,CAAE,KAAIJ,aAAc,SAAQ;EACzD,CAAC,MAAM;IACLZ,MAAM,IAAK,IAAGU,IAAI,CAACM,IAAI,CAAC,GAAG,CAAE,GAAE;EACjC;EAEA,OAAOhB,MAAM;AACf;AAAC,eAGcT,OAAO;AAAA"}
@@ -4,13 +4,9 @@ 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
  var _support = require("appium/support");
11
-
12
9
  const log = _support.logger.getLogger('RemoteDebugger');
13
-
14
10
  var _default = log;
15
11
  exports.default = _default;
16
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsb2ciLCJsb2dnZXIiLCJnZXRMb2dnZXIiXSwic291cmNlcyI6WyIuLi8uLi9saWIvbG9nZ2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGxvZ2dlciB9IGZyb20gJ2FwcGl1bS9zdXBwb3J0JztcblxuXG5jb25zdCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdSZW1vdGVEZWJ1Z2dlcicpO1xuXG5leHBvcnQgZGVmYXVsdCBsb2c7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUdBLE1BQU1BLEdBQUcsR0FBR0MsZUFBQSxDQUFPQyxTQUFQLENBQWlCLGdCQUFqQixDQUFaOztlQUVlRixHIn0=
12
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsb2ciLCJsb2dnZXIiLCJnZXRMb2dnZXIiXSwic291cmNlcyI6WyIuLi8uLi9saWIvbG9nZ2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGxvZ2dlciB9IGZyb20gJ2FwcGl1bS9zdXBwb3J0JztcblxuXG5jb25zdCBsb2cgPSBsb2dnZXIuZ2V0TG9nZ2VyKCdSZW1vdGVEZWJ1Z2dlcicpO1xuXG5leHBvcnQgZGVmYXVsdCBsb2c7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTtBQUdBLE1BQU1BLEdBQUcsR0FBR0MsZUFBTSxDQUFDQyxTQUFTLENBQUMsZ0JBQWdCLENBQUM7QUFBQyxlQUVoQ0YsR0FBRztBQUFBIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","names":["log","logger","getLogger"],"sources":["../../lib/logger.js"],"sourcesContent":["import { logger } from 'appium/support';\n\n\nconst log = logger.getLogger('RemoteDebugger');\n\nexport default log;\n"],"mappings":";;;;;;;AAAA;AAGA,MAAMA,GAAG,GAAGC,eAAM,CAACC,SAAS,CAAC,gBAAgB,CAAC;AAAC,eAEhCF,GAAG;AAAA"}
@@ -1,42 +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 _utils = require("../utils");
15
-
16
11
  var _events = _interopRequireDefault(require("./events"));
17
-
18
12
  var _support = require("appium/support");
19
-
20
13
  var _asyncbox = require("asyncbox");
21
-
22
14
  var _lodash = _interopRequireDefault(require("lodash"));
23
-
24
15
  const APP_CONNECT_TIMEOUT_MS = 0;
25
16
  const APP_CONNECT_INTERVAL_MS = 100;
26
17
  const SELECT_APP_RETRIES = 20;
27
18
  const SELECT_APP_RETRY_SLEEP_MS = 500;
28
19
  const SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';
29
20
  const BLANK_PAGE_URL = 'about:blank';
30
-
31
21
  async function setConnectionKey() {
32
22
  _logger.default.debug('Sending connection key request');
33
-
34
23
  await this.rpcClient.send('setConnectionKey', {}, false);
35
24
  }
36
-
37
25
  async function connect(timeout = APP_CONNECT_TIMEOUT_MS) {
38
26
  this.setup();
27
+
39
28
  this.initRpcClient();
29
+
40
30
  this.rpcClient.on('_rpc_reportSetup:', _lodash.default.noop);
41
31
  this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));
42
32
  this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));
@@ -50,10 +40,8 @@ async function connect(timeout = APP_CONNECT_TIMEOUT_MS) {
50
40
 
51
41
  try {
52
42
  await this.setConnectionKey();
53
-
54
43
  if (timeout) {
55
44
  _logger.default.debug(`Waiting up to ${timeout}ms for applications to be reported`);
56
-
57
45
  try {
58
46
  await (0, _asyncbox.waitForCondition)(() => !_lodash.default.isEmpty(this.appDict), {
59
47
  waitMs: timeout,
@@ -63,40 +51,30 @@ async function connect(timeout = APP_CONNECT_TIMEOUT_MS) {
63
51
  _logger.default.debug(`Timed out waiting for applications to be reported`);
64
52
  }
65
53
  }
66
-
67
54
  return this.appDict || {};
68
55
  } catch (err) {
69
56
  _logger.default.error(`Error setting connection key: ${err.message}`);
70
-
71
57
  await this.disconnect();
72
58
  throw err;
73
59
  }
74
60
  }
75
-
76
61
  async function disconnect() {
77
62
  if (this.rpcClient) {
78
63
  await this.rpcClient.disconnect();
79
64
  }
80
-
81
65
  this.emit(_events.default.EVENT_DISCONNECT, true);
82
66
  this.teardown();
83
67
  }
84
-
85
68
  async function selectApp(currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {
86
69
  const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;
87
70
  this.rpcClient.shouldCheckForTarget = false;
88
-
89
71
  try {
90
72
  const timer = new _support.timing.Timer().start();
91
-
92
73
  _logger.default.debug('Selecting application');
93
-
94
74
  if (!this.appDict || _lodash.default.isEmpty(this.appDict)) {
95
75
  _logger.default.debug('No applications currently connected.');
96
-
97
76
  return [];
98
77
  }
99
-
100
78
  const {
101
79
  appIdKey,
102
80
  pageDict
@@ -105,81 +83,61 @@ async function selectApp(currentUrl = null, maxTries = SELECT_APP_RETRIES, ignor
105
83
  if (!appIdKey || !pageDict) {
106
84
  _logger.default.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);
107
85
  }
108
-
109
86
  if (this.appIdKey !== appIdKey) {
110
87
  _logger.default.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);
111
-
112
88
  this.appIdKey = appIdKey;
113
89
  }
114
-
115
90
  logApplicationDictionary(this.appDict);
116
- const pageArray = _lodash.default.isEmpty(this.appDict[appIdKey].pageArray) ? (0, _utils.pageArrayFromDict)(pageDict) : this.appDict[appIdKey].pageArray;
117
91
 
92
+ const pageArray = _lodash.default.isEmpty(this.appDict[appIdKey].pageArray) ? (0, _utils.pageArrayFromDict)(pageDict) : this.appDict[appIdKey].pageArray;
118
93
  _logger.default.debug(`Finally selecting app ${this.appIdKey}: ${(0, _utils.simpleStringify)(pageArray)}`);
119
-
120
94
  let fullPageArray = [];
121
-
122
95
  for (const [app, info] of _lodash.default.toPairs(this.appDict)) {
123
96
  if (!_lodash.default.isArray(info.pageArray) || !info.isActive) {
124
97
  continue;
125
98
  }
126
-
127
99
  const id = app.replace('PID:', '');
128
-
129
100
  for (const page of info.pageArray) {
130
101
  if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {
131
102
  let pageDict = _lodash.default.clone(page);
132
-
133
103
  pageDict.id = `${id}.${pageDict.id}`;
134
104
  pageDict.bundleId = info.bundleId;
135
105
  fullPageArray.push(pageDict);
136
106
  }
137
107
  }
138
108
  }
139
-
140
109
  _logger.default.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
141
-
142
110
  return fullPageArray;
143
111
  } finally {
144
112
  this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;
145
113
  }
146
114
  }
147
-
148
115
  async function searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl) {
149
116
  const bundleIds = this.includeSafari && !this.isSafari ? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID] : [this.bundleId, ...this.additionalBundleIds];
150
-
151
117
  try {
152
118
  return await (0, _asyncbox.retryInterval)(maxTries, SELECT_APP_RETRY_SLEEP_MS, async retryCount => {
153
119
  logApplicationDictionary(this.appDict);
154
120
  const possibleAppIds = (0, _utils.getPossibleDebuggerAppKeys)(bundleIds, this.appDict);
155
-
156
121
  _logger.default.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);
157
-
158
122
  for (const attemptedAppIdKey of possibleAppIds) {
159
123
  try {
160
124
  if (!this.appDict[attemptedAppIdKey].isActive) {
161
125
  _logger.default.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);
162
-
163
126
  continue;
164
127
  }
165
-
166
128
  _logger.default.debug(`Attempting app '${attemptedAppIdKey}'`);
167
-
168
129
  const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey, this.onAppConnect.bind(this));
169
-
170
130
  if (_lodash.default.isEmpty(pageDict)) {
171
131
  _logger.default.debug('Empty page dictionary received. Trying again.');
172
-
173
132
  continue;
174
133
  }
175
134
 
176
135
  this.appDict[appIdKey].pageArray = (0, _utils.pageArrayFromDict)(pageDict);
177
- const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);
178
136
 
137
+ const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);
179
138
  if (result) {
180
139
  return result;
181
140
  }
182
-
183
141
  if (currentUrl) {
184
142
  _logger.default.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);
185
143
  } else {
@@ -189,7 +147,6 @@ async function searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl) {
189
147
  _logger.default.debug(`Error checking application: '${err.message}'. Retrying connection`);
190
148
  }
191
149
  }
192
-
193
150
  retryCount++;
194
151
  throw new Error('Failed to find an app to select');
195
152
  }, 0);
@@ -197,13 +154,11 @@ async function searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl) {
197
154
  _logger.default.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);
198
155
  }
199
156
  }
200
-
201
157
  function searchForPage(appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {
202
158
  for (const appDict of _lodash.default.values(appsDict)) {
203
159
  if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {
204
160
  continue;
205
161
  }
206
-
207
162
  for (const dict of appDict.pageArray) {
208
163
  if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) && (!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {
209
164
  return {
@@ -213,74 +168,56 @@ function searchForPage(appsDict, currentUrl = null, ignoreAboutBlankUrl = false)
213
168
  }
214
169
  }
215
170
  }
216
-
217
171
  return null;
218
172
  }
219
-
220
173
  async function selectPage(appIdKey, pageIdKey, skipReadyCheck = false) {
221
174
  this.appIdKey = `PID:${appIdKey}`;
222
175
  this.pageIdKey = pageIdKey;
223
-
224
176
  _logger.default.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);
225
-
226
177
  const timer = new _support.timing.Timer().start();
227
178
  await this.rpcClient.selectPage(this.appIdKey, pageIdKey);
228
179
 
229
180
  if (!skipReadyCheck && !(await this.checkPageIsReady())) {
230
181
  await this.pageUnload();
231
182
  }
232
-
233
183
  _logger.default.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
234
184
  }
235
-
236
185
  function logApplicationDictionary(apps) {
237
186
  function getValueString(key, value) {
238
187
  if (_lodash.default.isFunction(value)) {
239
188
  return '[Function]';
240
189
  }
241
-
242
190
  if (key === 'pageArray' && !_lodash.default.isArray(value)) {
243
191
  return `"Waiting for data"`;
244
192
  }
245
-
246
193
  return JSON.stringify(value);
247
194
  }
248
-
249
195
  _logger.default.debug('Current applications available:');
250
-
251
196
  for (const [app, info] of _lodash.default.toPairs(apps)) {
252
197
  _logger.default.debug(` Application: "${app}"`);
253
-
254
198
  for (const [key, value] of _lodash.default.toPairs(info)) {
255
199
  if (key === 'pageArray' && Array.isArray(value) && value.length) {
256
200
  _logger.default.debug(` ${key}:`);
257
-
258
201
  for (const page of value) {
259
202
  let prefix = '- ';
260
-
261
203
  for (const [k, v] of _lodash.default.toPairs(page)) {
262
204
  _logger.default.debug(` ${prefix}${k}: ${JSON.stringify(v)}`);
263
-
264
205
  prefix = ' ';
265
206
  }
266
207
  }
267
208
  } else {
268
209
  const valueString = getValueString(key, value);
269
-
270
210
  _logger.default.debug(` ${key}: ${valueString}`);
271
211
  }
272
212
  }
273
213
  }
274
214
  }
275
-
276
215
  function updateAppsWithDict(dict) {
277
216
  this.appDict = this.appDict || {};
278
217
  let [id, entry] = (0, _utils.appInfoFromDict)(dict);
279
-
280
218
  if (this.appDict[id]) {
281
219
  entry.pageArray = this.appDict[id].pageArray;
282
220
  }
283
-
284
221
  this.appDict[id] = entry;
285
222
 
286
223
  if (_lodash.default.isUndefined(entry.pageArray)) {
@@ -291,7 +228,6 @@ function updateAppsWithDict(dict) {
291
228
  this.appIdKey = (0, _utils.getDebuggerAppKey)(this.bundleId, this.appDict);
292
229
  }
293
230
  }
294
-
295
231
  var _default = {
296
232
  setConnectionKey,
297
233
  connect,
@@ -303,4 +239,4 @@ var _default = {
303
239
  updateAppsWithDict
304
240
  };
305
241
  exports.default = _default;
306
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["APP_CONNECT_TIMEOUT_MS","APP_CONNECT_INTERVAL_MS","SELECT_APP_RETRIES","SELECT_APP_RETRY_SLEEP_MS","SAFARI_BUNDLE_ID","BLANK_PAGE_URL","setConnectionKey","log","debug","rpcClient","send","connect","timeout","setup","initRpcClient","on","_","noop","onPageChange","bind","onConnectedApplicationList","onAppConnect","onAppDisconnect","onAppUpdate","onConnectedDriverList","onCurrentState","frameDetached","waitForCondition","isEmpty","appDict","waitMs","interval","err","error","message","disconnect","emit","events","EVENT_DISCONNECT","teardown","selectApp","currentUrl","maxTries","ignoreAboutBlankUrl","shouldCheckForTarget","timer","timing","Timer","start","appIdKey","pageDict","searchForApp","errorAndThrow","logApplicationDictionary","pageArray","pageArrayFromDict","simpleStringify","fullPageArray","app","info","toPairs","isArray","isActive","id","replace","page","url","clone","bundleId","push","getDuration","asMilliSeconds","toFixed","bundleIds","includeSafari","isSafari","additionalBundleIds","retryInterval","retryCount","possibleAppIds","getPossibleDebuggerAppKeys","join","attemptedAppIdKey","result","searchForPage","Error","ign","appsDict","values","promise","dict","selectPage","pageIdKey","skipReadyCheck","checkPageIsReady","pageUnload","apps","getValueString","key","value","isFunction","JSON","stringify","Array","length","prefix","k","v","valueString","updateAppsWithDict","entry","appInfoFromDict","isUndefined","deferredPromise","getDebuggerAppKey"],"sources":["../../../lib/mixins/connect.js"],"sourcesContent":["import log from '../logger';\nimport { appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n         getPossibleDebuggerAppKeys, simpleStringify, deferredPromise } from '../utils';\nimport events from './events';\nimport { timing } from 'appium/support';\nimport { retryInterval, waitForCondition } from 'asyncbox';\nimport _ from 'lodash';\n\n\nconst APP_CONNECT_TIMEOUT_MS = 0;\nconst APP_CONNECT_INTERVAL_MS = 100;\nconst SELECT_APP_RETRIES = 20;\nconst SELECT_APP_RETRY_SLEEP_MS = 500;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\nconst BLANK_PAGE_URL = 'about:blank';\n\n\nasync function setConnectionKey () {\n  log.debug('Sending connection key request');\n  // send but only wait to make sure the socket worked\n  // as response from Web Inspector can take a long time\n  await this.rpcClient.send('setConnectionKey', {}, false);\n}\n\nasync function connect (timeout = APP_CONNECT_TIMEOUT_MS) {\n  this.setup();\n\n  // initialize the rpc client\n  this.initRpcClient();\n\n  // listen for basic debugger-level events\n  this.rpcClient.on('_rpc_reportSetup:', _.noop);\n  this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));\n  this.rpcClient.on('_rpc_applicationConnected:', this.onAppConnect.bind(this));\n  this.rpcClient.on('_rpc_applicationDisconnected:', this.onAppDisconnect.bind(this));\n  this.rpcClient.on('_rpc_applicationUpdated:', this.onAppUpdate.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedDriverList:', this.onConnectedDriverList.bind(this));\n  this.rpcClient.on('_rpc_reportCurrentState:', this.onCurrentState.bind(this));\n  this.rpcClient.on('Page.frameDetached', this.frameDetached.bind(this));\n\n  await this.rpcClient.connect();\n\n  // get the connection information about the app\n  try {\n    await this.setConnectionKey();\n    if (timeout) {\n      log.debug(`Waiting up to ${timeout}ms for applications to be reported`);\n      try {\n        await waitForCondition(() => !_.isEmpty(this.appDict), {\n          waitMs: timeout,\n          interval: APP_CONNECT_INTERVAL_MS,\n        });\n      } catch (err) {\n        log.debug(`Timed out waiting for applications to be reported`);\n      }\n    }\n    return this.appDict || {};\n  } catch (err) {\n    log.error(`Error setting connection key: ${err.message}`);\n    await this.disconnect();\n    throw err;\n  }\n}\n\nasync function disconnect () {\n  if (this.rpcClient) {\n    await this.rpcClient.disconnect();\n  }\n  this.emit(events.EVENT_DISCONNECT, true);\n  this.teardown();\n}\n\nasync function selectApp (currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {\n  const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;\n  this.rpcClient.shouldCheckForTarget = false;\n  try {\n    const timer = new timing.Timer().start();\n    log.debug('Selecting application');\n    if (!this.appDict || _.isEmpty(this.appDict)) {\n      log.debug('No applications currently connected.');\n      return [];\n    }\n\n    const {appIdKey, pageDict} = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);\n\n    // if, after all this, we have no dictionary, we have failed\n    if (!appIdKey || !pageDict) {\n      log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n    }\n\n    if (this.appIdKey !== appIdKey) {\n      log.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);\n      this.appIdKey = appIdKey;\n    }\n\n    logApplicationDictionary(this.appDict);\n\n    // translate the dictionary into a useful form, and return to sender\n    const pageArray = _.isEmpty(this.appDict[appIdKey].pageArray)\n      ? pageArrayFromDict(pageDict)\n      : this.appDict[appIdKey].pageArray;\n    log.debug(`Finally selecting app ${this.appIdKey}: ${simpleStringify(pageArray)}`);\n\n    let fullPageArray = [];\n    for (const [app, info] of _.toPairs(this.appDict)) {\n      if (!_.isArray(info.pageArray) || !info.isActive) {\n        continue;\n      }\n      const id = app.replace('PID:', '');\n      for (const page of info.pageArray) {\n        if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {\n          let pageDict = _.clone(page);\n          pageDict.id = `${id}.${pageDict.id}`;\n          pageDict.bundleId = info.bundleId;\n          fullPageArray.push(pageDict);\n        }\n      }\n    }\n\n    log.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n    return fullPageArray;\n  } finally {\n    this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;\n  }\n}\n\nasync function searchForApp (currentUrl, maxTries, ignoreAboutBlankUrl) {\n  const bundleIds = this.includeSafari && !this.isSafari\n    ? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID]\n    : [this.bundleId, ...this.additionalBundleIds];\n  try {\n    return await retryInterval(maxTries, SELECT_APP_RETRY_SLEEP_MS, async (retryCount) => {\n      logApplicationDictionary(this.appDict);\n      const possibleAppIds = getPossibleDebuggerAppKeys(bundleIds, this.appDict);\n      log.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);\n      for (const attemptedAppIdKey of possibleAppIds) {\n        try {\n          if (!this.appDict[attemptedAppIdKey].isActive) {\n            log.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);\n            continue;\n          }\n          log.debug(`Attempting app '${attemptedAppIdKey}'`);\n          const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey, this.onAppConnect.bind(this));\n          // in iOS 8.2 the connect logic happens, but with an empty dictionary\n          // which leads to the remote debugger getting disconnected, and into a loop\n          if (_.isEmpty(pageDict)) {\n            log.debug('Empty page dictionary received. Trying again.');\n            continue;\n          }\n\n          // save the page array for this app\n          this.appDict[appIdKey].pageArray = pageArrayFromDict(pageDict);\n\n          // if we are looking for a particular url, make sure we\n          // have the right page. Ignore empty or undefined urls.\n          // Ignore about:blank if requested.\n          const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);\n          if (result) {\n            return result;\n          }\n\n          if (currentUrl) {\n            log.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);\n          } else {\n            log.debug('Received app, but no match was found. Trying again.');\n          }\n        } catch (err) {\n          log.debug(`Error checking application: '${err.message}'. Retrying connection`);\n        }\n      }\n      retryCount++;\n      throw new Error('Failed to find an app to select');\n    }, 0);\n  } catch (ign) {\n    log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n  }\n}\n\nfunction searchForPage (appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {\n  for (const appDict of _.values(appsDict)) {\n    if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {\n      continue;\n    }\n\n    for (const dict of appDict.pageArray) {\n      if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) &&\n          (!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {\n        return { appIdKey: appDict.id, pageDict: dict };\n      }\n    }\n  }\n  return null;\n}\n\nasync function selectPage (appIdKey, pageIdKey, skipReadyCheck = false) {\n  this.appIdKey = `PID:${appIdKey}`;\n  this.pageIdKey = pageIdKey;\n\n  log.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);\n\n  const timer = new timing.Timer().start();\n\n  await this.rpcClient.selectPage(this.appIdKey, pageIdKey);\n\n  // make sure everything is ready to go\n  if (!skipReadyCheck && !await this.checkPageIsReady()) {\n    await this.pageUnload();\n  }\n\n  log.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n}\n\nfunction logApplicationDictionary (apps) {\n  function getValueString (key, value) {\n    if (_.isFunction(value)) {\n      return '[Function]';\n    }\n    if (key === 'pageArray' && !_.isArray(value)) {\n      return `\"Waiting for data\"`;\n    }\n    return JSON.stringify(value);\n  }\n  log.debug('Current applications available:');\n  for (const [app, info] of _.toPairs(apps)) {\n    log.debug(`    Application: \"${app}\"`);\n    for (const [key, value] of _.toPairs(info)) {\n      if (key === 'pageArray' && Array.isArray(value) && value.length) {\n        log.debug(`        ${key}:`);\n        for (const page of value) {\n          let prefix = '- ';\n          for (const [k, v] of _.toPairs(page)) {\n            log.debug(`          ${prefix}${k}: ${JSON.stringify(v)}`);\n            prefix = '  ';\n          }\n        }\n      } else {\n        const valueString = getValueString(key, value);\n        log.debug(`        ${key}: ${valueString}`);\n      }\n    }\n  }\n}\n\nfunction updateAppsWithDict (dict) {\n  // get the dictionary entry into a nice form, and add it to the\n  // application dictionary\n  this.appDict = this.appDict || {};\n  let [id, entry] = appInfoFromDict(dict);\n  if (this.appDict[id]) {\n    // preserve the page dictionary for this entry\n    entry.pageArray = this.appDict[id].pageArray;\n  }\n  this.appDict[id] = entry;\n\n  // add a promise to get the page dictionary\n  if (_.isUndefined(entry.pageArray)) {\n    entry.pageArray = deferredPromise();\n  }\n\n  // try to get the app id from our connected apps\n  if (!this.appIdKey) {\n    this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n  }\n}\n\nexport default { setConnectionKey, connect, disconnect, selectApp, searchForApp, searchForPage, selectPage, updateAppsWithDict };\n"],"mappings":"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"}
242
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["APP_CONNECT_TIMEOUT_MS","APP_CONNECT_INTERVAL_MS","SELECT_APP_RETRIES","SELECT_APP_RETRY_SLEEP_MS","SAFARI_BUNDLE_ID","BLANK_PAGE_URL","setConnectionKey","log","debug","rpcClient","send","connect","timeout","setup","initRpcClient","on","_","noop","onPageChange","bind","onConnectedApplicationList","onAppConnect","onAppDisconnect","onAppUpdate","onConnectedDriverList","onCurrentState","frameDetached","waitForCondition","isEmpty","appDict","waitMs","interval","err","error","message","disconnect","emit","events","EVENT_DISCONNECT","teardown","selectApp","currentUrl","maxTries","ignoreAboutBlankUrl","shouldCheckForTarget","timer","timing","Timer","start","appIdKey","pageDict","searchForApp","errorAndThrow","logApplicationDictionary","pageArray","pageArrayFromDict","simpleStringify","fullPageArray","app","info","toPairs","isArray","isActive","id","replace","page","url","clone","bundleId","push","getDuration","asMilliSeconds","toFixed","bundleIds","includeSafari","isSafari","additionalBundleIds","retryInterval","retryCount","possibleAppIds","getPossibleDebuggerAppKeys","join","attemptedAppIdKey","result","searchForPage","Error","ign","appsDict","values","promise","dict","selectPage","pageIdKey","skipReadyCheck","checkPageIsReady","pageUnload","apps","getValueString","key","value","isFunction","JSON","stringify","Array","length","prefix","k","v","valueString","updateAppsWithDict","entry","appInfoFromDict","isUndefined","deferredPromise","getDebuggerAppKey"],"sources":["../../../lib/mixins/connect.js"],"sourcesContent":["import log from '../logger';\nimport { appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n         getPossibleDebuggerAppKeys, simpleStringify, deferredPromise } from '../utils';\nimport events from './events';\nimport { timing } from 'appium/support';\nimport { retryInterval, waitForCondition } from 'asyncbox';\nimport _ from 'lodash';\n\n\nconst APP_CONNECT_TIMEOUT_MS = 0;\nconst APP_CONNECT_INTERVAL_MS = 100;\nconst SELECT_APP_RETRIES = 20;\nconst SELECT_APP_RETRY_SLEEP_MS = 500;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\nconst BLANK_PAGE_URL = 'about:blank';\n\n\nasync function setConnectionKey () {\n  log.debug('Sending connection key request');\n  // send but only wait to make sure the socket worked\n  // as response from Web Inspector can take a long time\n  await this.rpcClient.send('setConnectionKey', {}, false);\n}\n\nasync function connect (timeout = APP_CONNECT_TIMEOUT_MS) {\n  this.setup();\n\n  // initialize the rpc client\n  this.initRpcClient();\n\n  // listen for basic debugger-level events\n  this.rpcClient.on('_rpc_reportSetup:', _.noop);\n  this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));\n  this.rpcClient.on('_rpc_applicationConnected:', this.onAppConnect.bind(this));\n  this.rpcClient.on('_rpc_applicationDisconnected:', this.onAppDisconnect.bind(this));\n  this.rpcClient.on('_rpc_applicationUpdated:', this.onAppUpdate.bind(this));\n  this.rpcClient.on('_rpc_reportConnectedDriverList:', this.onConnectedDriverList.bind(this));\n  this.rpcClient.on('_rpc_reportCurrentState:', this.onCurrentState.bind(this));\n  this.rpcClient.on('Page.frameDetached', this.frameDetached.bind(this));\n\n  await this.rpcClient.connect();\n\n  // get the connection information about the app\n  try {\n    await this.setConnectionKey();\n    if (timeout) {\n      log.debug(`Waiting up to ${timeout}ms for applications to be reported`);\n      try {\n        await waitForCondition(() => !_.isEmpty(this.appDict), {\n          waitMs: timeout,\n          interval: APP_CONNECT_INTERVAL_MS,\n        });\n      } catch (err) {\n        log.debug(`Timed out waiting for applications to be reported`);\n      }\n    }\n    return this.appDict || {};\n  } catch (err) {\n    log.error(`Error setting connection key: ${err.message}`);\n    await this.disconnect();\n    throw err;\n  }\n}\n\nasync function disconnect () {\n  if (this.rpcClient) {\n    await this.rpcClient.disconnect();\n  }\n  this.emit(events.EVENT_DISCONNECT, true);\n  this.teardown();\n}\n\nasync function selectApp (currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {\n  const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;\n  this.rpcClient.shouldCheckForTarget = false;\n  try {\n    const timer = new timing.Timer().start();\n    log.debug('Selecting application');\n    if (!this.appDict || _.isEmpty(this.appDict)) {\n      log.debug('No applications currently connected.');\n      return [];\n    }\n\n    const {appIdKey, pageDict} = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);\n\n    // if, after all this, we have no dictionary, we have failed\n    if (!appIdKey || !pageDict) {\n      log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n    }\n\n    if (this.appIdKey !== appIdKey) {\n      log.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);\n      this.appIdKey = appIdKey;\n    }\n\n    logApplicationDictionary(this.appDict);\n\n    // translate the dictionary into a useful form, and return to sender\n    const pageArray = _.isEmpty(this.appDict[appIdKey].pageArray)\n      ? pageArrayFromDict(pageDict)\n      : this.appDict[appIdKey].pageArray;\n    log.debug(`Finally selecting app ${this.appIdKey}: ${simpleStringify(pageArray)}`);\n\n    let fullPageArray = [];\n    for (const [app, info] of _.toPairs(this.appDict)) {\n      if (!_.isArray(info.pageArray) || !info.isActive) {\n        continue;\n      }\n      const id = app.replace('PID:', '');\n      for (const page of info.pageArray) {\n        if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {\n          let pageDict = _.clone(page);\n          pageDict.id = `${id}.${pageDict.id}`;\n          pageDict.bundleId = info.bundleId;\n          fullPageArray.push(pageDict);\n        }\n      }\n    }\n\n    log.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n    return fullPageArray;\n  } finally {\n    this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;\n  }\n}\n\nasync function searchForApp (currentUrl, maxTries, ignoreAboutBlankUrl) {\n  const bundleIds = this.includeSafari && !this.isSafari\n    ? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID]\n    : [this.bundleId, ...this.additionalBundleIds];\n  try {\n    return await retryInterval(maxTries, SELECT_APP_RETRY_SLEEP_MS, async (retryCount) => {\n      logApplicationDictionary(this.appDict);\n      const possibleAppIds = getPossibleDebuggerAppKeys(bundleIds, this.appDict);\n      log.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);\n      for (const attemptedAppIdKey of possibleAppIds) {\n        try {\n          if (!this.appDict[attemptedAppIdKey].isActive) {\n            log.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);\n            continue;\n          }\n          log.debug(`Attempting app '${attemptedAppIdKey}'`);\n          const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey, this.onAppConnect.bind(this));\n          // in iOS 8.2 the connect logic happens, but with an empty dictionary\n          // which leads to the remote debugger getting disconnected, and into a loop\n          if (_.isEmpty(pageDict)) {\n            log.debug('Empty page dictionary received. Trying again.');\n            continue;\n          }\n\n          // save the page array for this app\n          this.appDict[appIdKey].pageArray = pageArrayFromDict(pageDict);\n\n          // if we are looking for a particular url, make sure we\n          // have the right page. Ignore empty or undefined urls.\n          // Ignore about:blank if requested.\n          const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);\n          if (result) {\n            return result;\n          }\n\n          if (currentUrl) {\n            log.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);\n          } else {\n            log.debug('Received app, but no match was found. Trying again.');\n          }\n        } catch (err) {\n          log.debug(`Error checking application: '${err.message}'. Retrying connection`);\n        }\n      }\n      retryCount++;\n      throw new Error('Failed to find an app to select');\n    }, 0);\n  } catch (ign) {\n    log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n  }\n}\n\nfunction searchForPage (appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {\n  for (const appDict of _.values(appsDict)) {\n    if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {\n      continue;\n    }\n\n    for (const dict of appDict.pageArray) {\n      if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) &&\n          (!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {\n        return { appIdKey: appDict.id, pageDict: dict };\n      }\n    }\n  }\n  return null;\n}\n\nasync function selectPage (appIdKey, pageIdKey, skipReadyCheck = false) {\n  this.appIdKey = `PID:${appIdKey}`;\n  this.pageIdKey = pageIdKey;\n\n  log.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);\n\n  const timer = new timing.Timer().start();\n\n  await this.rpcClient.selectPage(this.appIdKey, pageIdKey);\n\n  // make sure everything is ready to go\n  if (!skipReadyCheck && !await this.checkPageIsReady()) {\n    await this.pageUnload();\n  }\n\n  log.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n}\n\nfunction logApplicationDictionary (apps) {\n  function getValueString (key, value) {\n    if (_.isFunction(value)) {\n      return '[Function]';\n    }\n    if (key === 'pageArray' && !_.isArray(value)) {\n      return `\"Waiting for data\"`;\n    }\n    return JSON.stringify(value);\n  }\n  log.debug('Current applications available:');\n  for (const [app, info] of _.toPairs(apps)) {\n    log.debug(`    Application: \"${app}\"`);\n    for (const [key, value] of _.toPairs(info)) {\n      if (key === 'pageArray' && Array.isArray(value) && value.length) {\n        log.debug(`        ${key}:`);\n        for (const page of value) {\n          let prefix = '- ';\n          for (const [k, v] of _.toPairs(page)) {\n            log.debug(`          ${prefix}${k}: ${JSON.stringify(v)}`);\n            prefix = '  ';\n          }\n        }\n      } else {\n        const valueString = getValueString(key, value);\n        log.debug(`        ${key}: ${valueString}`);\n      }\n    }\n  }\n}\n\nfunction updateAppsWithDict (dict) {\n  // get the dictionary entry into a nice form, and add it to the\n  // application dictionary\n  this.appDict = this.appDict || {};\n  let [id, entry] = appInfoFromDict(dict);\n  if (this.appDict[id]) {\n    // preserve the page dictionary for this entry\n    entry.pageArray = this.appDict[id].pageArray;\n  }\n  this.appDict[id] = entry;\n\n  // add a promise to get the page dictionary\n  if (_.isUndefined(entry.pageArray)) {\n    entry.pageArray = deferredPromise();\n  }\n\n  // try to get the app id from our connected apps\n  if (!this.appIdKey) {\n    this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n  }\n}\n\nexport default { setConnectionKey, connect, disconnect, selectApp, searchForApp, searchForPage, selectPage, updateAppsWithDict };\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect.js","names":["APP_CONNECT_TIMEOUT_MS","APP_CONNECT_INTERVAL_MS","SELECT_APP_RETRIES","SELECT_APP_RETRY_SLEEP_MS","SAFARI_BUNDLE_ID","BLANK_PAGE_URL","setConnectionKey","log","debug","rpcClient","send","connect","timeout","setup","initRpcClient","on","_","noop","onPageChange","bind","onConnectedApplicationList","onAppConnect","onAppDisconnect","onAppUpdate","onConnectedDriverList","onCurrentState","frameDetached","waitForCondition","isEmpty","appDict","waitMs","interval","err","error","message","disconnect","emit","events","EVENT_DISCONNECT","teardown","selectApp","currentUrl","maxTries","ignoreAboutBlankUrl","shouldCheckForTarget","timer","timing","Timer","start","appIdKey","pageDict","searchForApp","errorAndThrow","logApplicationDictionary","pageArray","pageArrayFromDict","simpleStringify","fullPageArray","app","info","toPairs","isArray","isActive","id","replace","page","url","clone","bundleId","push","getDuration","asMilliSeconds","toFixed","bundleIds","includeSafari","isSafari","additionalBundleIds","retryInterval","retryCount","possibleAppIds","getPossibleDebuggerAppKeys","join","attemptedAppIdKey","result","searchForPage","Error","ign","appsDict","values","promise","dict","selectPage","pageIdKey","skipReadyCheck","checkPageIsReady","pageUnload","apps","getValueString","key","value","isFunction","JSON","stringify","Array","length","prefix","k","v","valueString","updateAppsWithDict","entry","appInfoFromDict","isUndefined","deferredPromise","getDebuggerAppKey"],"sources":["../../../lib/mixins/connect.js"],"sourcesContent":["import log from '../logger';\nimport { appInfoFromDict, pageArrayFromDict, getDebuggerAppKey,\n getPossibleDebuggerAppKeys, simpleStringify, deferredPromise } from '../utils';\nimport events from './events';\nimport { timing } from 'appium/support';\nimport { retryInterval, waitForCondition } from 'asyncbox';\nimport _ from 'lodash';\n\n\nconst APP_CONNECT_TIMEOUT_MS = 0;\nconst APP_CONNECT_INTERVAL_MS = 100;\nconst SELECT_APP_RETRIES = 20;\nconst SELECT_APP_RETRY_SLEEP_MS = 500;\nconst SAFARI_BUNDLE_ID = 'com.apple.mobilesafari';\nconst BLANK_PAGE_URL = 'about:blank';\n\n\nasync function setConnectionKey () {\n log.debug('Sending connection key request');\n // send but only wait to make sure the socket worked\n // as response from Web Inspector can take a long time\n await this.rpcClient.send('setConnectionKey', {}, false);\n}\n\nasync function connect (timeout = APP_CONNECT_TIMEOUT_MS) {\n this.setup();\n\n // initialize the rpc client\n this.initRpcClient();\n\n // listen for basic debugger-level events\n this.rpcClient.on('_rpc_reportSetup:', _.noop);\n this.rpcClient.on('_rpc_forwardGetListing:', this.onPageChange.bind(this));\n this.rpcClient.on('_rpc_reportConnectedApplicationList:', this.onConnectedApplicationList.bind(this));\n this.rpcClient.on('_rpc_applicationConnected:', this.onAppConnect.bind(this));\n this.rpcClient.on('_rpc_applicationDisconnected:', this.onAppDisconnect.bind(this));\n this.rpcClient.on('_rpc_applicationUpdated:', this.onAppUpdate.bind(this));\n this.rpcClient.on('_rpc_reportConnectedDriverList:', this.onConnectedDriverList.bind(this));\n this.rpcClient.on('_rpc_reportCurrentState:', this.onCurrentState.bind(this));\n this.rpcClient.on('Page.frameDetached', this.frameDetached.bind(this));\n\n await this.rpcClient.connect();\n\n // get the connection information about the app\n try {\n await this.setConnectionKey();\n if (timeout) {\n log.debug(`Waiting up to ${timeout}ms for applications to be reported`);\n try {\n await waitForCondition(() => !_.isEmpty(this.appDict), {\n waitMs: timeout,\n interval: APP_CONNECT_INTERVAL_MS,\n });\n } catch (err) {\n log.debug(`Timed out waiting for applications to be reported`);\n }\n }\n return this.appDict || {};\n } catch (err) {\n log.error(`Error setting connection key: ${err.message}`);\n await this.disconnect();\n throw err;\n }\n}\n\nasync function disconnect () {\n if (this.rpcClient) {\n await this.rpcClient.disconnect();\n }\n this.emit(events.EVENT_DISCONNECT, true);\n this.teardown();\n}\n\nasync function selectApp (currentUrl = null, maxTries = SELECT_APP_RETRIES, ignoreAboutBlankUrl = false) {\n const shouldCheckForTarget = this.rpcClient.shouldCheckForTarget;\n this.rpcClient.shouldCheckForTarget = false;\n try {\n const timer = new timing.Timer().start();\n log.debug('Selecting application');\n if (!this.appDict || _.isEmpty(this.appDict)) {\n log.debug('No applications currently connected.');\n return [];\n }\n\n const {appIdKey, pageDict} = await this.searchForApp(currentUrl, maxTries, ignoreAboutBlankUrl);\n\n // if, after all this, we have no dictionary, we have failed\n if (!appIdKey || !pageDict) {\n log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n }\n\n if (this.appIdKey !== appIdKey) {\n log.debug(`Received altered app id, updating from '${this.appIdKey}' to '${appIdKey}'`);\n this.appIdKey = appIdKey;\n }\n\n logApplicationDictionary(this.appDict);\n\n // translate the dictionary into a useful form, and return to sender\n const pageArray = _.isEmpty(this.appDict[appIdKey].pageArray)\n ? pageArrayFromDict(pageDict)\n : this.appDict[appIdKey].pageArray;\n log.debug(`Finally selecting app ${this.appIdKey}: ${simpleStringify(pageArray)}`);\n\n let fullPageArray = [];\n for (const [app, info] of _.toPairs(this.appDict)) {\n if (!_.isArray(info.pageArray) || !info.isActive) {\n continue;\n }\n const id = app.replace('PID:', '');\n for (const page of info.pageArray) {\n if (!(ignoreAboutBlankUrl && page.url === BLANK_PAGE_URL)) {\n let pageDict = _.clone(page);\n pageDict.id = `${id}.${pageDict.id}`;\n pageDict.bundleId = info.bundleId;\n fullPageArray.push(pageDict);\n }\n }\n }\n\n log.debug(`Selected app after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n return fullPageArray;\n } finally {\n this.rpcClient.shouldCheckForTarget = shouldCheckForTarget;\n }\n}\n\nasync function searchForApp (currentUrl, maxTries, ignoreAboutBlankUrl) {\n const bundleIds = this.includeSafari && !this.isSafari\n ? [this.bundleId, ...this.additionalBundleIds, SAFARI_BUNDLE_ID]\n : [this.bundleId, ...this.additionalBundleIds];\n try {\n return await retryInterval(maxTries, SELECT_APP_RETRY_SLEEP_MS, async (retryCount) => {\n logApplicationDictionary(this.appDict);\n const possibleAppIds = getPossibleDebuggerAppKeys(bundleIds, this.appDict);\n log.debug(`Trying out the possible app ids: ${possibleAppIds.join(', ')} (try #${retryCount + 1} of ${maxTries})`);\n for (const attemptedAppIdKey of possibleAppIds) {\n try {\n if (!this.appDict[attemptedAppIdKey].isActive) {\n log.debug(`Skipping app '${attemptedAppIdKey}' because it is not active`);\n continue;\n }\n log.debug(`Attempting app '${attemptedAppIdKey}'`);\n const [appIdKey, pageDict] = await this.rpcClient.selectApp(attemptedAppIdKey, this.onAppConnect.bind(this));\n // in iOS 8.2 the connect logic happens, but with an empty dictionary\n // which leads to the remote debugger getting disconnected, and into a loop\n if (_.isEmpty(pageDict)) {\n log.debug('Empty page dictionary received. Trying again.');\n continue;\n }\n\n // save the page array for this app\n this.appDict[appIdKey].pageArray = pageArrayFromDict(pageDict);\n\n // if we are looking for a particular url, make sure we\n // have the right page. Ignore empty or undefined urls.\n // Ignore about:blank if requested.\n const result = this.searchForPage(this.appDict, currentUrl, ignoreAboutBlankUrl);\n if (result) {\n return result;\n }\n\n if (currentUrl) {\n log.debug(`Received app, but expected url ('${currentUrl}') was not found. Trying again.`);\n } else {\n log.debug('Received app, but no match was found. Trying again.');\n }\n } catch (err) {\n log.debug(`Error checking application: '${err.message}'. Retrying connection`);\n }\n }\n retryCount++;\n throw new Error('Failed to find an app to select');\n }, 0);\n } catch (ign) {\n log.errorAndThrow(`Could not connect to a valid app after ${maxTries} tries.`);\n }\n}\n\nfunction searchForPage (appsDict, currentUrl = null, ignoreAboutBlankUrl = false) {\n for (const appDict of _.values(appsDict)) {\n if (!appDict || !appDict.isActive || !appDict.pageArray || appDict.pageArray.promise) {\n continue;\n }\n\n for (const dict of appDict.pageArray) {\n if ((!ignoreAboutBlankUrl || dict.url !== BLANK_PAGE_URL) &&\n (!currentUrl || dict.url === currentUrl || dict.url === `${currentUrl}/`)) {\n return { appIdKey: appDict.id, pageDict: dict };\n }\n }\n }\n return null;\n}\n\nasync function selectPage (appIdKey, pageIdKey, skipReadyCheck = false) {\n this.appIdKey = `PID:${appIdKey}`;\n this.pageIdKey = pageIdKey;\n\n log.debug(`Selecting page '${pageIdKey}' on app '${this.appIdKey}' and forwarding socket setup`);\n\n const timer = new timing.Timer().start();\n\n await this.rpcClient.selectPage(this.appIdKey, pageIdKey);\n\n // make sure everything is ready to go\n if (!skipReadyCheck && !await this.checkPageIsReady()) {\n await this.pageUnload();\n }\n\n log.debug(`Selected page after ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);\n}\n\nfunction logApplicationDictionary (apps) {\n function getValueString (key, value) {\n if (_.isFunction(value)) {\n return '[Function]';\n }\n if (key === 'pageArray' && !_.isArray(value)) {\n return `\"Waiting for data\"`;\n }\n return JSON.stringify(value);\n }\n log.debug('Current applications available:');\n for (const [app, info] of _.toPairs(apps)) {\n log.debug(` Application: \"${app}\"`);\n for (const [key, value] of _.toPairs(info)) {\n if (key === 'pageArray' && Array.isArray(value) && value.length) {\n log.debug(` ${key}:`);\n for (const page of value) {\n let prefix = '- ';\n for (const [k, v] of _.toPairs(page)) {\n log.debug(` ${prefix}${k}: ${JSON.stringify(v)}`);\n prefix = ' ';\n }\n }\n } else {\n const valueString = getValueString(key, value);\n log.debug(` ${key}: ${valueString}`);\n }\n }\n }\n}\n\nfunction updateAppsWithDict (dict) {\n // get the dictionary entry into a nice form, and add it to the\n // application dictionary\n this.appDict = this.appDict || {};\n let [id, entry] = appInfoFromDict(dict);\n if (this.appDict[id]) {\n // preserve the page dictionary for this entry\n entry.pageArray = this.appDict[id].pageArray;\n }\n this.appDict[id] = entry;\n\n // add a promise to get the page dictionary\n if (_.isUndefined(entry.pageArray)) {\n entry.pageArray = deferredPromise();\n }\n\n // try to get the app id from our connected apps\n if (!this.appIdKey) {\n this.appIdKey = getDebuggerAppKey(this.bundleId, this.appDict);\n }\n}\n\nexport default { setConnectionKey, connect, disconnect, selectApp, searchForApp, searchForPage, selectPage, updateAppsWithDict };\n"],"mappings":"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"}