webdriverio-automation
Version:
WebdriverIO-Automation android ios project
138 lines (100 loc) • 14.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.WebKitRemoteDebugger = exports.default = void 0;
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _logger = _interopRequireDefault(require("./logger"));
var _appiumBaseDriver = require("appium-base-driver");
var _remoteDebugger = require("./remote-debugger");
var _webkitRpcClient = _interopRequireDefault(require("./webkit-rpc-client"));
var _lodash = _interopRequireDefault(require("lodash"));
var _url = _interopRequireDefault(require("url"));
var _requestPromise = _interopRequireDefault(require("request-promise"));
var _helpers = require("./helpers");
class WebKitRemoteDebugger extends _remoteDebugger.RemoteDebugger {
constructor(opts = {}) {
opts = Object.assign({
host: 'localhost'
}, opts);
super(_lodash.default.defaults({
debuggerType: _remoteDebugger.DEBUGGER_TYPES.webkit
}, opts));
this.webkitResponseTimeout = opts.webkitResponseTimeout || _remoteDebugger.RPC_RESPONSE_TIMEOUT_MS;
this.dataMethods = {};
}
connect(pageId) {
var _this = this;
return (0, _asyncToGenerator2.default)(function* () {
_this.rpcClient = new _webkitRpcClient.default(_this.host, _this.port, _this.webkitResponseTimeout);
yield _this.rpcClient.connect(pageId);
})();
}
disconnect() {
if (this.rpcClient && this.rpcClient.isConnected()) {
this.rpcClient.disconnect();
}
}
isConnected() {
return !!(this.rpcClient && this.rpcClient.isConnected());
}
pageArrayFromJson(ignoreAboutBlankUrl = false) {
var _this2 = this;
return (0, _asyncToGenerator2.default)(function* () {
_logger.default.debug(`Getting WebKitRemoteDebugger pageArray: ${_this2.host}, ${_this2.port}`);
let pageElementJSON = yield _this2.getJsonFromUrl(_this2.host, _this2.port, '/json');
if (pageElementJSON[0] && pageElementJSON[0].deviceId) {
_logger.default.debug(`Device JSON: ${(0, _helpers.simpleStringify)(pageElementJSON)}`);
let devices = pageElementJSON.filter(device => device.deviceId !== 'SIMULATOR');
if (devices.length > 1) {
_logger.default.debug(`Connected to ${devices.length} devices. ` + `Choosing the first, with udid '${devices[0].deviceId}'.`);
}
_this2.port = devices[0].url.split(':')[1];
_logger.default.debug(`Received notification that ios-webkit-debug-proxy is listening on port '${_this2.port}'`);
pageElementJSON = yield _this2.getJsonFromUrl(_this2.host, _this2.port, '/json');
}
_logger.default.debug(`Page element JSON: ${(0, _helpers.simpleStringify)(pageElementJSON)}`);
let newPageArray = pageElementJSON.filter(pageObject => {
return pageObject.url && (!ignoreAboutBlankUrl || pageObject.url !== 'about:blank');
}).map(pageObject => {
let urlArray = pageObject.webSocketDebuggerUrl.split('/').reverse();
let id = urlArray[0];
return {
id,
title: pageObject.title,
url: pageObject.url,
isKey: !!id
};
});
return newPageArray;
})();
}
getJsonFromUrl(hostname, port, pathname) {
return (0, _asyncToGenerator2.default)(function* () {
let uri = _url.default.format({
protocol: 'http',
hostname,
port,
pathname
});
_logger.default.debug(`Sending request to: ${uri}`);
return JSON.parse((yield (0, _requestPromise.default)({
uri,
method: 'GET'
})));
})();
}
convertResult(res) {
if (res && res.wasThrown) {
let message = res.result.value || res.result;
throw new _appiumBaseDriver.errors.JavaScriptError(message);
}
if (res && res.result && res.result.type === 'undefined') {
res.result.value = {};
}
return super.convertResult(res && res.result ? res.result.value : res);
}
}
exports.WebKitRemoteDebugger = exports.default = WebKitRemoteDebugger;require('source-map-support').install();
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/webkit-remote-debugger.js"],"names":["WebKitRemoteDebugger","RemoteDebugger","constructor","opts","Object","assign","host","_","defaults","debuggerType","DEBUGGER_TYPES","webkit","webkitResponseTimeout","RPC_RESPONSE_TIMEOUT_MS","dataMethods","connect","pageId","rpcClient","WebKitRpcClient","port","disconnect","isConnected","pageArrayFromJson","ignoreAboutBlankUrl","log","debug","pageElementJSON","getJsonFromUrl","deviceId","devices","filter","device","length","url","split","newPageArray","pageObject","map","urlArray","webSocketDebuggerUrl","reverse","id","title","isKey","hostname","pathname","uri","format","protocol","JSON","parse","method","convertResult","res","wasThrown","message","result","value","errors","JavaScriptError","type"],"mappings":";;;;;;;;;;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGe,MAAMA,oBAAN,SAAmCC,8BAAnC,CAAkD;AAC/DC,EAAAA,WAAW,CAAEC,IAAI,GAAG,EAAT,EAAa;AAEtBA,IAAAA,IAAI,GAAGC,MAAM,CAACC,MAAP,CAAc;AACnBC,MAAAA,IAAI,EAAE;AADa,KAAd,EAEJH,IAFI,CAAP;AAGA,UAAMI,gBAAEC,QAAF,CAAW;AAACC,MAAAA,YAAY,EAAEC,+BAAeC;AAA9B,KAAX,EAAkDR,IAAlD,CAAN;AAEA,SAAKS,qBAAL,GAA6BT,IAAI,CAACS,qBAAL,IAA8BC,uCAA3D;AAGA,SAAKC,WAAL,GAAmB,EAAnB;AACD;;AAEKC,EAAAA,OAAN,CAAeC,MAAf,EAAuB;AAAA;;AAAA;AACrB,MAAA,KAAI,CAACC,SAAL,GAAiB,IAAIC,wBAAJ,CAAoB,KAAI,CAACZ,IAAzB,EAA+B,KAAI,CAACa,IAApC,EAA0C,KAAI,CAACP,qBAA/C,CAAjB;AACA,YAAM,KAAI,CAACK,SAAL,CAAeF,OAAf,CAAuBC,MAAvB,CAAN;AAFqB;AAGtB;;AAEDI,EAAAA,UAAU,GAAI;AACZ,QAAI,KAAKH,SAAL,IAAkB,KAAKA,SAAL,CAAeI,WAAf,EAAtB,EAAoD;AAClD,WAAKJ,SAAL,CAAeG,UAAf;AACD;AACF;;AAEDC,EAAAA,WAAW,GAAI;AACb,WAAO,CAAC,EAAE,KAAKJ,SAAL,IAAkB,KAAKA,SAAL,CAAeI,WAAf,EAApB,CAAR;AACD;;AAEKC,EAAAA,iBAAN,CAAyBC,mBAAmB,GAAG,KAA/C,EAAsD;AAAA;;AAAA;AACpDC,sBAAIC,KAAJ,CAAW,2CAA0C,MAAI,CAACnB,IAAK,KAAI,MAAI,CAACa,IAAK,EAA7E;;AACA,UAAIO,eAAe,SAAS,MAAI,CAACC,cAAL,CAAoB,MAAI,CAACrB,IAAzB,EAA+B,MAAI,CAACa,IAApC,EAA0C,OAA1C,CAA5B;;AACA,UAAIO,eAAe,CAAC,CAAD,CAAf,IAAsBA,eAAe,CAAC,CAAD,CAAf,CAAmBE,QAA7C,EAAuD;AACrDJ,wBAAIC,KAAJ,CAAW,gBAAe,8BAAgBC,eAAhB,CAAiC,EAA3D;;AAEA,YAAIG,OAAO,GAAGH,eAAe,CAACI,MAAhB,CAAwBC,MAAD,IAAYA,MAAM,CAACH,QAAP,KAAoB,WAAvD,CAAd;;AACA,YAAIC,OAAO,CAACG,MAAR,GAAiB,CAArB,EAAwB;AACtBR,0BAAIC,KAAJ,CAAW,gBAAeI,OAAO,CAACG,MAAO,YAA/B,GACC,kCAAiCH,OAAO,CAAC,CAAD,CAAP,CAAWD,QAAS,IADhE;AAED;;AACD,QAAA,MAAI,CAACT,IAAL,GAAYU,OAAO,CAAC,CAAD,CAAP,CAAWI,GAAX,CAAeC,KAAf,CAAqB,GAArB,EAA0B,CAA1B,CAAZ;;AACAV,wBAAIC,KAAJ,CAAW,2EAA0E,MAAI,CAACN,IAAK,GAA/F;;AAEAO,QAAAA,eAAe,SAAS,MAAI,CAACC,cAAL,CAAoB,MAAI,CAACrB,IAAzB,EAA+B,MAAI,CAACa,IAApC,EAA0C,OAA1C,CAAxB;AACD;;AACDK,sBAAIC,KAAJ,CAAW,sBAAqB,8BAAgBC,eAAhB,CAAiC,EAAjE;;AAGA,UAAIS,YAAY,GAAGT,eAAe,CAACI,MAAhB,CAAwBM,UAAD,IAAgB;AACxD,eAAOA,UAAU,CAACH,GAAX,KAAmB,CAACV,mBAAD,IAAwBa,UAAU,CAACH,GAAX,KAAmB,aAA9D,CAAP;AACD,OAFkB,EAEhBI,GAFgB,CAEXD,UAAD,IAAgB;AACrB,YAAIE,QAAQ,GAAGF,UAAU,CAACG,oBAAX,CAAgCL,KAAhC,CAAsC,GAAtC,EAA2CM,OAA3C,EAAf;AACA,YAAIC,EAAE,GAAGH,QAAQ,CAAC,CAAD,CAAjB;AACA,eAAO;AACLG,UAAAA,EADK;AAELC,UAAAA,KAAK,EAAEN,UAAU,CAACM,KAFb;AAGLT,UAAAA,GAAG,EAAEG,UAAU,CAACH,GAHX;AAILU,UAAAA,KAAK,EAAE,CAAC,CAACF;AAJJ,SAAP;AAMD,OAXkB,CAAnB;AAaA,aAAON,YAAP;AAhCoD;AAiCrD;;AAEKR,EAAAA,cAAN,CAAsBiB,QAAtB,EAAgCzB,IAAhC,EAAsC0B,QAAtC,EAAgD;AAAA;AAC9C,UAAIC,GAAG,GAAGb,aAAIc,MAAJ,CAAW;AACnBC,QAAAA,QAAQ,EAAE,MADS;AAEnBJ,QAAAA,QAFmB;AAGnBzB,QAAAA,IAHmB;AAInB0B,QAAAA;AAJmB,OAAX,CAAV;;AAMArB,sBAAIC,KAAJ,CAAW,uBAAsBqB,GAAI,EAArC;;AACA,aAAOG,IAAI,CAACC,KAAL,QAAiB,6BAAQ;AAACJ,QAAAA,GAAD;AAAMK,QAAAA,MAAM,EAAE;AAAd,OAAR,CAAjB,EAAP;AAR8C;AAS/C;;AAEDC,EAAAA,aAAa,CAAEC,GAAF,EAAO;AAgBlB,QAAIA,GAAG,IAAIA,GAAG,CAACC,SAAf,EAA0B;AAExB,UAAIC,OAAO,GAAGF,GAAG,CAACG,MAAJ,CAAWC,KAAX,IAAoBJ,GAAG,CAACG,MAAtC;AACA,YAAM,IAAIE,yBAAOC,eAAX,CAA2BJ,OAA3B,CAAN;AACD;;AAED,QAAIF,GAAG,IAAIA,GAAG,CAACG,MAAX,IAAqBH,GAAG,CAACG,MAAJ,CAAWI,IAAX,KAAoB,WAA7C,EAA0D;AAGxDP,MAAAA,GAAG,CAACG,MAAJ,CAAWC,KAAX,GAAmB,EAAnB;AACD;;AAGD,WAAO,MAAML,aAAN,CAAoBC,GAAG,IAAIA,GAAG,CAACG,MAAX,GAAoBH,GAAG,CAACG,MAAJ,CAAWC,KAA/B,GAAuCJ,GAA3D,CAAP;AACD;;AAzG8D","sourcesContent":["// transpile:main\n\nimport log from './logger';\nimport { errors } from 'appium-base-driver';\nimport { RemoteDebugger, DEBUGGER_TYPES, RPC_RESPONSE_TIMEOUT_MS } from './remote-debugger';\nimport WebKitRpcClient from './webkit-rpc-client';\nimport _ from 'lodash';\nimport url from 'url';\nimport request from 'request-promise';\nimport { simpleStringify } from './helpers';\n\n\nexport default class WebKitRemoteDebugger extends RemoteDebugger {\n  constructor (opts = {}) {\n    // make sure there is a host\n    opts = Object.assign({\n      host: 'localhost',\n    }, opts);\n    super(_.defaults({debuggerType: DEBUGGER_TYPES.webkit}, opts));\n\n    this.webkitResponseTimeout = opts.webkitResponseTimeout || RPC_RESPONSE_TIMEOUT_MS;\n\n    // used to store callback types when sending requests\n    this.dataMethods = {};\n  }\n\n  async connect (pageId) {\n    this.rpcClient = new WebKitRpcClient(this.host, this.port, this.webkitResponseTimeout);\n    await this.rpcClient.connect(pageId);\n  }\n\n  disconnect () {\n    if (this.rpcClient && this.rpcClient.isConnected()) {\n      this.rpcClient.disconnect();\n    }\n  }\n\n  isConnected () {\n    return !!(this.rpcClient && this.rpcClient.isConnected());\n  }\n\n  async pageArrayFromJson (ignoreAboutBlankUrl = false) {\n    log.debug(`Getting WebKitRemoteDebugger pageArray: ${this.host}, ${this.port}`);\n    let pageElementJSON = await this.getJsonFromUrl(this.host, this.port, '/json');\n    if (pageElementJSON[0] && pageElementJSON[0].deviceId) {\n      log.debug(`Device JSON: ${simpleStringify(pageElementJSON)}`);\n\n      let devices = pageElementJSON.filter((device) => device.deviceId !== 'SIMULATOR');\n      if (devices.length > 1) {\n        log.debug(`Connected to ${devices.length} devices. ` +\n                  `Choosing the first, with udid '${devices[0].deviceId}'.`);\n      }\n      this.port = devices[0].url.split(':')[1];\n      log.debug(`Received notification that ios-webkit-debug-proxy is listening on port '${this.port}'`);\n\n      pageElementJSON = await this.getJsonFromUrl(this.host, this.port, '/json');\n    }\n    log.debug(`Page element JSON: ${simpleStringify(pageElementJSON)}`);\n\n    // Add elements to an array\n    let newPageArray = pageElementJSON.filter((pageObject) => {\n      return pageObject.url && (!ignoreAboutBlankUrl || pageObject.url !== 'about:blank');\n    }).map((pageObject) => {\n      let urlArray = pageObject.webSocketDebuggerUrl.split('/').reverse();\n      let id = urlArray[0];\n      return {\n        id,\n        title: pageObject.title,\n        url: pageObject.url,\n        isKey: !!id,\n      };\n    });\n\n    return newPageArray;\n  }\n\n  async getJsonFromUrl (hostname, port, pathname) {\n    let uri = url.format({\n      protocol: 'http',\n      hostname,\n      port,\n      pathname\n    });\n    log.debug(`Sending request to: ${uri}`);\n    return JSON.parse(await request({uri, method: 'GET'}));\n  }\n\n  convertResult (res) {\n    // WebKit returns a result wrapped deeper than the Remote Debugger:\n    //   {\n    //     result: {\n    //       type: \"string\",\n    //       value: {\n    //         status: 0,\n    //         value: {\n    //           ELEMENT: \":wdc:1441819740060\"\n    //         }\n    //       }\n    //     },\n    //     wasThrown: false\n    //   }\n\n    // check for errors\n    if (res && res.wasThrown) {\n      // we got some form of error.\n      let message = res.result.value || res.result;\n      throw new errors.JavaScriptError(message);\n    }\n\n    if (res && res.result && res.result.type === 'undefined') {\n      // if it doesn't throw an error, we just want to put in a\n      // place holder. this happens when we have an async execute request\n      res.result.value = {};\n    }\n\n    // send the actual result to the Remote Debugger converter\n    return super.convertResult(res && res.result ? res.result.value : res);\n  }\n}\n\nexport { WebKitRemoteDebugger };\n"],"file":"lib/webkit-remote-debugger.js","sourceRoot":"../.."}