webdriverio-automation
Version:
WebdriverIO-Automation android ios project
258 lines (186 loc) • 26.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _logger = _interopRequireDefault(require("./logger"));
var _remoteDebugger = require("./remote-debugger");
var _remoteMessages = _interopRequireDefault(require("./remote-messages"));
var _ws = _interopRequireDefault(require("ws"));
var _bluebird = _interopRequireDefault(require("bluebird"));
var _lodash = _interopRequireDefault(require("lodash"));
var _events = _interopRequireDefault(require("events"));
var _helpers = require("./helpers");
var _es6Error = _interopRequireDefault(require("es6-error"));
var _appiumSupport = require("appium-support");
const DATA_LOG_LENGTH = {
length: 200
};
class WebKitRpcClient extends _events.default.EventEmitter {
constructor(host, port = _remoteDebugger.REMOTE_DEBUGGER_PORT, responseTimeout = _remoteDebugger.RPC_RESPONSE_TIMEOUT_MS) {
super();
this.host = host || 'localhost';
this.port = port;
this.responseTimeout = responseTimeout;
this.curMsgId = 0;
this.dataHandlers = {};
this.dataMethods = {};
this.errorHandlers = {};
}
connect(pageId) {
var _this = this;
return (0, _asyncToGenerator2.default)(function* () {
return yield new _bluebird.default((resolve, reject) => {
let url = `ws://${_this.host}:${_this.port}/devtools/page/${pageId}`;
_this.pageIdKey = pageId;
_this.socket = new _ws.default(url);
_this.socket.on('open', () => {
_logger.default.debug(`WebKit debugger web socket connected to url: ${url}`);
_this.connected = true;
resolve();
});
_this.socket.on('close', () => {
_logger.default.debug('WebKit remote debugger socket disconnected');
_this.connected = false;
});
_this.socket.on('error', exception => {
if (_this.connected) {
_logger.default.debug(`WebKit debugger web socket error: ${exception.message}`);
_this.connected = false;
}
reject(exception);
});
_this.socket.on('message', _this.receive.bind(_this));
});
})();
}
disconnect() {
_logger.default.debug('Disconnecting from WebKit remote debugger');
if (this.isConnected()) {
this.socket.close(1001);
}
this.connected = false;
}
isConnected() {
return this.socket !== null && this.connected;
}
send(command, opts = {}) {
var _this2 = this;
return (0, _asyncToGenerator2.default)(function* () {
let data = (0, _remoteMessages.default)(command, _lodash.default.defaults({
connId: _this2.connId,
senderId: _this2.senderId
}, opts));
_logger.default.debug(`Sending WebKit data: ${_lodash.default.truncate(JSON.stringify(data), DATA_LOG_LENGTH)}`);
_logger.default.debug(`Webkit response timeout: ${_this2.responseTimeout}`);
_this2.curMsgId++;
data.id = _this2.curMsgId;
const id = _this2.curMsgId.toString();
return yield new _bluebird.default((resolve, reject) => {
_this2.dataHandlers[id] = resolve;
_this2.dataMethods[id] = data.method;
_this2.errorHandlers[id] = reject;
_this2.socket.send(JSON.stringify(data), function (error) {
if (_appiumSupport.util.hasValue(error)) {
_logger.default.debug(`WebKit socket error occurred: ${error}`);
reject(new Error(error));
}
});
}).catch(e => {
if (e.constructor.name !== WebKitRPCWarning.name) {
throw e;
}
_logger.default.warn(e.message);
return _bluebird.default.resolve(null);
}).finally(res => {
delete _this2.dataHandlers[id];
delete _this2.dataMethods[id];
delete _this2.errorHandlers[id];
return res;
}).timeout(_this2.responseTimeout);
})();
}
receive(data) {
_logger.default.debug(`Received WebKit data: '${_lodash.default.truncate(data, DATA_LOG_LENGTH)}'`);
data = _appiumSupport.util.safeJsonParse(data);
const rejectCall = error => {
if (data && this.errorHandlers[data.id]) {
return this.errorHandlers[data.id](error);
}
if (error.constructor.name === WebKitRPCWarning.name) {
_logger.default.warn(error.message);
} else {
_logger.default.errorAndThrow(error);
}
};
if (!_lodash.default.isPlainObject(data)) {
return rejectCall(new WebKitRPCWarning(`No parseable data found`));
}
if (data.wasThrown || data.result && data.result.wasThrown) {
const message = data.wasThrown ? data.result.value || data.result.description : data.result.result.value || data.result.result.description;
return rejectCall(new Error(message));
}
const msgId = data.id;
const method = this.dataMethods[msgId] || data.method;
if (!method) {
return rejectCall(new WebKitRPCWarning(`Did not find any handlers for ${msgId ? `'${msgId}'` : 'the recent'} message`));
}
_logger.default.debug(`Found method '${method}'${msgId ? ` for '${msgId}' message` : ''}`);
let isEventHandled = false;
switch (method) {
case 'Profiler.resetProfiles':
_logger.default.debug('Device is telling us to reset profiles. Should probably ' + 'do some kind of callback here');
isEventHandled = true;
break;
case 'Timeline.eventRecorded':
if (this.timelineEventHandler) {
this.timelineEventHandler(data.result);
isEventHandled = true;
}
break;
case 'Console.messageAdded':
if (this.consoleEventHandler) {
this.consoleEventHandler(data.params.message);
isEventHandled = true;
}
break;
case 'Page.navigate':
_logger.default.debug(`Received page navigated message: ${(0, _helpers.simpleStringify)(data)}`);
isEventHandled = true;
break;
case 'Network.dataReceived':
case 'Network.requestWillBeSent':
case 'Network.responseReceived':
case 'Network.loadingFinished':
case 'Network.loadingFailed':
if (_lodash.default.isFunction(this.networkEventHandler)) {
this.networkEventHandler(method, data.params);
return;
}
break;
}
if (!data.error && _lodash.default.has(this.dataHandlers, msgId)) {
return this.dataHandlers[msgId](data.result);
}
if (data.error && _lodash.default.has(this.errorHandlers, msgId)) {
return this.errorHandlers[msgId](data.error);
}
if (!isEventHandled) {
_logger.default.debug(`There is no handler scheduled for method '${method}' in ${msgId ? `'${msgId}'` : 'the recent'} message`);
}
}
setTimelineEventHandler(timelineEventHandler) {
this.timelineEventHandler = timelineEventHandler;
}
setConsoleLogEventHandler(consoleEventHandler) {
this.consoleEventHandler = consoleEventHandler;
}
setNetworkLogEventHandler(networkEventHandler) {
this.networkEventHandler = networkEventHandler;
}
}
exports.default = WebKitRpcClient;
class WebKitRPCWarning extends _es6Error.default {}require('source-map-support').install();
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/webkit-rpc-client.js"],"names":["DATA_LOG_LENGTH","length","WebKitRpcClient","events","EventEmitter","constructor","host","port","REMOTE_DEBUGGER_PORT","responseTimeout","RPC_RESPONSE_TIMEOUT_MS","curMsgId","dataHandlers","dataMethods","errorHandlers","connect","pageId","Promise","resolve","reject","url","pageIdKey","socket","WebSocket","on","log","debug","connected","exception","message","receive","bind","disconnect","isConnected","close","send","command","opts","data","_","defaults","connId","senderId","truncate","JSON","stringify","id","toString","method","error","util","hasValue","Error","catch","e","name","WebKitRPCWarning","warn","finally","res","timeout","safeJsonParse","rejectCall","errorAndThrow","isPlainObject","wasThrown","result","value","description","msgId","isEventHandled","timelineEventHandler","consoleEventHandler","params","isFunction","networkEventHandler","has","setTimelineEventHandler","setConsoleLogEventHandler","setNetworkLogEventHandler","ES6Error"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA,MAAMA,eAAe,GAAG;AAACC,EAAAA,MAAM,EAAE;AAAT,CAAxB;;AAEe,MAAMC,eAAN,SAA8BC,gBAAOC,YAArC,CAAkD;AAC/DC,EAAAA,WAAW,CAAEC,IAAF,EAAQC,IAAI,GAAGC,oCAAf,EAAqCC,eAAe,GAAGC,uCAAvD,EAAgF;AACzF;AAEA,SAAKJ,IAAL,GAAYA,IAAI,IAAI,WAApB;AACA,SAAKC,IAAL,GAAYA,IAAZ;AAEA,SAAKE,eAAL,GAAuBA,eAAvB;AAEA,SAAKE,QAAL,GAAgB,CAAhB;AAEA,SAAKC,YAAL,GAAoB,EAApB;AACA,SAAKC,WAAL,GAAmB,EAAnB;AACA,SAAKC,aAAL,GAAqB,EAArB;AACD;;AAEKC,EAAAA,OAAN,CAAeC,MAAf,EAAuB;AAAA;;AAAA;AACrB,mBAAa,IAAIC,iBAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAG5C,YAAIC,GAAG,GAAI,QAAO,KAAI,CAACd,IAAK,IAAG,KAAI,CAACC,IAAK,kBAAiBS,MAAO,EAAjE;AACA,QAAA,KAAI,CAACK,SAAL,GAAiBL,MAAjB;AAGA,QAAA,KAAI,CAACM,MAAL,GAAc,IAAIC,WAAJ,CAAcH,GAAd,CAAd;;AACA,QAAA,KAAI,CAACE,MAAL,CAAYE,EAAZ,CAAe,MAAf,EAAuB,MAAM;AAC3BC,0BAAIC,KAAJ,CAAW,gDAA+CN,GAAI,EAA9D;;AACA,UAAA,KAAI,CAACO,SAAL,GAAiB,IAAjB;AACAT,UAAAA,OAAO;AACR,SAJD;;AAKA,QAAA,KAAI,CAACI,MAAL,CAAYE,EAAZ,CAAe,OAAf,EAAwB,MAAM;AAC5BC,0BAAIC,KAAJ,CAAU,4CAAV;;AACA,UAAA,KAAI,CAACC,SAAL,GAAiB,KAAjB;AACD,SAHD;;AAIA,QAAA,KAAI,CAACL,MAAL,CAAYE,EAAZ,CAAe,OAAf,EAAyBI,SAAD,IAAe;AACrC,cAAI,KAAI,CAACD,SAAT,EAAoB;AAClBF,4BAAIC,KAAJ,CAAW,qCAAoCE,SAAS,CAACC,OAAQ,EAAjE;;AACA,YAAA,KAAI,CAACF,SAAL,GAAiB,KAAjB;AACD;;AAEDR,UAAAA,MAAM,CAACS,SAAD,CAAN;AACD,SAPD;;AAQA,QAAA,KAAI,CAACN,MAAL,CAAYE,EAAZ,CAAe,SAAf,EAA0B,KAAI,CAACM,OAAL,CAAaC,IAAb,CAAkB,KAAlB,CAA1B;AACD,OA1BY,CAAb;AADqB;AA4BtB;;AAEDC,EAAAA,UAAU,GAAI;AACZP,oBAAIC,KAAJ,CAAU,2CAAV;;AACA,QAAI,KAAKO,WAAL,EAAJ,EAAwB;AACtB,WAAKX,MAAL,CAAYY,KAAZ,CAAkB,IAAlB;AACD;;AACD,SAAKP,SAAL,GAAiB,KAAjB;AACD;;AAEDM,EAAAA,WAAW,GAAI;AACb,WAAQ,KAAKX,MAAL,KAAgB,IAAhB,IAAwB,KAAKK,SAArC;AACD;;AAEKQ,EAAAA,IAAN,CAAYC,OAAZ,EAAqBC,IAAI,GAAG,EAA5B,EAAgC;AAAA;;AAAA;AAC9B,UAAIC,IAAI,GAAG,6BAAiBF,OAAjB,EAA0BG,gBAAEC,QAAF,CAAW;AAACC,QAAAA,MAAM,EAAE,MAAI,CAACA,MAAd;AAAsBC,QAAAA,QAAQ,EAAE,MAAI,CAACA;AAArC,OAAX,EAA2DL,IAA3D,CAA1B,CAAX;;AAEAZ,sBAAIC,KAAJ,CAAW,wBAAuBa,gBAAEI,QAAF,CAAWC,IAAI,CAACC,SAAL,CAAeP,IAAf,CAAX,EAAiCtC,eAAjC,CAAkD,EAApF;;AACAyB,sBAAIC,KAAJ,CAAW,4BAA2B,MAAI,CAACjB,eAAgB,EAA3D;;AAEA,MAAA,MAAI,CAACE,QAAL;AACA2B,MAAAA,IAAI,CAACQ,EAAL,GAAU,MAAI,CAACnC,QAAf;;AAEA,YAAMmC,EAAE,GAAG,MAAI,CAACnC,QAAL,CAAcoC,QAAd,EAAX;;AACA,mBAAa,IAAI9B,iBAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAG5C,QAAA,MAAI,CAACP,YAAL,CAAkBkC,EAAlB,IAAwB5B,OAAxB;AACA,QAAA,MAAI,CAACL,WAAL,CAAiBiC,EAAjB,IAAuBR,IAAI,CAACU,MAA5B;AACA,QAAA,MAAI,CAAClC,aAAL,CAAmBgC,EAAnB,IAAyB3B,MAAzB;;AAGA,QAAA,MAAI,CAACG,MAAL,CAAYa,IAAZ,CAAiBS,IAAI,CAACC,SAAL,CAAeP,IAAf,CAAjB,EAAuC,UAAUW,KAAV,EAAiB;AACtD,cAAIC,oBAAKC,QAAL,CAAcF,KAAd,CAAJ,EAA0B;AACxBxB,4BAAIC,KAAJ,CAAW,iCAAgCuB,KAAM,EAAjD;;AACA9B,YAAAA,MAAM,CAAC,IAAIiC,KAAJ,CAAUH,KAAV,CAAD,CAAN;AACD;AACF,SALD;AAMD,OAdY,EAcVI,KAdU,CAcHC,CAAD,IAAO;AACd,YAAIA,CAAC,CAACjD,WAAF,CAAckD,IAAd,KAAuBC,gBAAgB,CAACD,IAA5C,EAAkD;AAChD,gBAAMD,CAAN;AACD;;AACD7B,wBAAIgC,IAAJ,CAASH,CAAC,CAACzB,OAAX;;AACA,eAAOZ,kBAAQC,OAAR,CAAgB,IAAhB,CAAP;AACD,OApBY,EAoBVwC,OApBU,CAoBDC,GAAD,IAAS;AAElB,eAAO,MAAI,CAAC/C,YAAL,CAAkBkC,EAAlB,CAAP;AACA,eAAO,MAAI,CAACjC,WAAL,CAAiBiC,EAAjB,CAAP;AACA,eAAO,MAAI,CAAChC,aAAL,CAAmBgC,EAAnB,CAAP;AAGA,eAAOa,GAAP;AACD,OA5BY,EA4BVC,OA5BU,CA4BF,MAAI,CAACnD,eA5BH,CAAb;AAV8B;AAuC/B;;AAEDqB,EAAAA,OAAO,CAAEQ,IAAF,EAAQ;AACbb,oBAAIC,KAAJ,CAAW,0BAAyBa,gBAAEI,QAAF,CAAWL,IAAX,EAAiBtC,eAAjB,CAAkC,GAAtE;;AACAsC,IAAAA,IAAI,GAAGY,oBAAKW,aAAL,CAAmBvB,IAAnB,CAAP;;AAEA,UAAMwB,UAAU,GAAIb,KAAD,IAAW;AAC5B,UAAIX,IAAI,IAAI,KAAKxB,aAAL,CAAmBwB,IAAI,CAACQ,EAAxB,CAAZ,EAAyC;AACvC,eAAO,KAAKhC,aAAL,CAAmBwB,IAAI,CAACQ,EAAxB,EAA4BG,KAA5B,CAAP;AACD;;AAED,UAAIA,KAAK,CAAC5C,WAAN,CAAkBkD,IAAlB,KAA2BC,gBAAgB,CAACD,IAAhD,EAAsD;AACpD9B,wBAAIgC,IAAJ,CAASR,KAAK,CAACpB,OAAf;AACD,OAFD,MAEO;AACLJ,wBAAIsC,aAAJ,CAAkBd,KAAlB;AACD;AACF,KAVD;;AAYA,QAAI,CAACV,gBAAEyB,aAAF,CAAgB1B,IAAhB,CAAL,EAA4B;AAC1B,aAAOwB,UAAU,CAAC,IAAIN,gBAAJ,CAAsB,yBAAtB,CAAD,CAAjB;AACD;;AAGD,QAAIlB,IAAI,CAAC2B,SAAL,IAAmB3B,IAAI,CAAC4B,MAAL,IAAe5B,IAAI,CAAC4B,MAAL,CAAYD,SAAlD,EAA8D;AAC5D,YAAMpC,OAAO,GAAGS,IAAI,CAAC2B,SAAL,GACZ3B,IAAI,CAAC4B,MAAL,CAAYC,KAAZ,IAAqB7B,IAAI,CAAC4B,MAAL,CAAYE,WADrB,GAEZ9B,IAAI,CAAC4B,MAAL,CAAYA,MAAZ,CAAmBC,KAAnB,IAA4B7B,IAAI,CAAC4B,MAAL,CAAYA,MAAZ,CAAmBE,WAFnD;AAGA,aAAON,UAAU,CAAC,IAAIV,KAAJ,CAAUvB,OAAV,CAAD,CAAjB;AACD;;AAED,UAAMwC,KAAK,GAAG/B,IAAI,CAACQ,EAAnB;AAIA,UAAME,MAAM,GAAG,KAAKnC,WAAL,CAAiBwD,KAAjB,KAA2B/B,IAAI,CAACU,MAA/C;;AACA,QAAI,CAACA,MAAL,EAAa;AACX,aAAOc,UAAU,CACf,IAAIN,gBAAJ,CAAsB,iCAAgCa,KAAK,GAAI,IAAGA,KAAM,GAAb,GAAkB,YAAa,UAA1F,CADe,CAAjB;AAED;;AACD5C,oBAAIC,KAAJ,CAAW,iBAAgBsB,MAAO,IAAGqB,KAAK,GAAI,SAAQA,KAAM,WAAlB,GAA+B,EAAG,EAA5E;;AACA,QAAIC,cAAc,GAAG,KAArB;;AACA,YAAQtB,MAAR;AACE,WAAK,wBAAL;AACEvB,wBAAIC,KAAJ,CAAU,6DACA,+BADV;;AAEA4C,QAAAA,cAAc,GAAG,IAAjB;AACA;;AACF,WAAK,wBAAL;AACE,YAAI,KAAKC,oBAAT,EAA+B;AAC7B,eAAKA,oBAAL,CAA0BjC,IAAI,CAAC4B,MAA/B;AACAI,UAAAA,cAAc,GAAG,IAAjB;AACD;;AACD;;AACF,WAAK,sBAAL;AACE,YAAI,KAAKE,mBAAT,EAA8B;AAC5B,eAAKA,mBAAL,CAAyBlC,IAAI,CAACmC,MAAL,CAAY5C,OAArC;AACAyC,UAAAA,cAAc,GAAG,IAAjB;AACD;;AACD;;AACF,WAAK,eAAL;AACE7C,wBAAIC,KAAJ,CAAW,oCAAmC,8BAAgBY,IAAhB,CAAsB,EAApE;;AACAgC,QAAAA,cAAc,GAAG,IAAjB;AACA;;AACF,WAAK,sBAAL;AACA,WAAK,2BAAL;AACA,WAAK,0BAAL;AACA,WAAK,yBAAL;AACA,WAAK,uBAAL;AACE,YAAI/B,gBAAEmC,UAAF,CAAa,KAAKC,mBAAlB,CAAJ,EAA4C;AAC1C,eAAKA,mBAAL,CAAyB3B,MAAzB,EAAiCV,IAAI,CAACmC,MAAtC;AACA;AACD;;AACD;AA/BJ;;AAiCA,QAAI,CAACnC,IAAI,CAACW,KAAN,IAAeV,gBAAEqC,GAAF,CAAM,KAAKhE,YAAX,EAAyByD,KAAzB,CAAnB,EAAoD;AAClD,aAAO,KAAKzD,YAAL,CAAkByD,KAAlB,EAAyB/B,IAAI,CAAC4B,MAA9B,CAAP;AACD;;AACD,QAAI5B,IAAI,CAACW,KAAL,IAAcV,gBAAEqC,GAAF,CAAM,KAAK9D,aAAX,EAA0BuD,KAA1B,CAAlB,EAAoD;AAClD,aAAO,KAAKvD,aAAL,CAAmBuD,KAAnB,EAA0B/B,IAAI,CAACW,KAA/B,CAAP;AACD;;AACD,QAAI,CAACqB,cAAL,EAAqB;AACnB7C,sBAAIC,KAAJ,CAAW,6CAA4CsB,MAAO,QAAOqB,KAAK,GAAI,IAAGA,KAAM,GAAb,GAAkB,YAAa,UAAzG;AACD;AACF;;AAEDQ,EAAAA,uBAAuB,CAAEN,oBAAF,EAAwB;AAC7C,SAAKA,oBAAL,GAA4BA,oBAA5B;AACD;;AAEDO,EAAAA,yBAAyB,CAAEN,mBAAF,EAAuB;AAC9C,SAAKA,mBAAL,GAA2BA,mBAA3B;AACD;;AAEDO,EAAAA,yBAAyB,CAAEJ,mBAAF,EAAuB;AAC9C,SAAKA,mBAAL,GAA2BA,mBAA3B;AACD;;AAhM8D;;;;AAoMjE,MAAMnB,gBAAN,SAA+BwB,iBAA/B,CAAwC","sourcesContent":["import log from './logger';\nimport { REMOTE_DEBUGGER_PORT, RPC_RESPONSE_TIMEOUT_MS } from './remote-debugger';\nimport getRemoteCommand from './remote-messages';\nimport WebSocket from 'ws';\nimport Promise from 'bluebird';\nimport _ from 'lodash';\nimport events from 'events';\nimport { simpleStringify } from './helpers';\nimport ES6Error from 'es6-error';\nimport { util } from 'appium-support';\n\n\nconst DATA_LOG_LENGTH = {length: 200};\n\nexport default class WebKitRpcClient extends events.EventEmitter {\n  constructor (host, port = REMOTE_DEBUGGER_PORT, responseTimeout = RPC_RESPONSE_TIMEOUT_MS) {\n    super();\n\n    this.host = host || 'localhost';\n    this.port = port;\n\n    this.responseTimeout = responseTimeout;\n\n    this.curMsgId = 0;\n\n    this.dataHandlers = {};\n    this.dataMethods = {};\n    this.errorHandlers = {};\n  }\n\n  async connect (pageId) {\n    return await new Promise((resolve, reject) => {\n      // we will only resolve this call when the socket is open\n      // WebKit url\n      let url = `ws://${this.host}:${this.port}/devtools/page/${pageId}`;\n      this.pageIdKey = pageId;\n\n      // create and set up socket with appropriate event handlers\n      this.socket = new WebSocket(url);\n      this.socket.on('open', () => {\n        log.debug(`WebKit debugger web socket connected to url: ${url}`);\n        this.connected = true;\n        resolve();\n      });\n      this.socket.on('close', () => {\n        log.debug('WebKit remote debugger socket disconnected');\n        this.connected = false;\n      });\n      this.socket.on('error', (exception) => {\n        if (this.connected) {\n          log.debug(`WebKit debugger web socket error: ${exception.message}`);\n          this.connected = false;\n        }\n\n        reject(exception);\n      });\n      this.socket.on('message', this.receive.bind(this));\n    });\n  }\n\n  disconnect () {\n    log.debug('Disconnecting from WebKit remote debugger');\n    if (this.isConnected()) {\n      this.socket.close(1001);\n    }\n    this.connected = false;\n  }\n\n  isConnected () {\n    return (this.socket !== null && this.connected);\n  }\n\n  async send (command, opts = {}) {\n    let data = getRemoteCommand(command, _.defaults({connId: this.connId, senderId: this.senderId}, opts));\n\n    log.debug(`Sending WebKit data: ${_.truncate(JSON.stringify(data), DATA_LOG_LENGTH)}`);\n    log.debug(`Webkit response timeout: ${this.responseTimeout}`);\n\n    this.curMsgId++;\n    data.id = this.curMsgId;\n\n    const id = this.curMsgId.toString();\n    return await new Promise((resolve, reject) => {\n      // only resolve the send command when WebKit returns a response\n      // store the handler and the data sent\n      this.dataHandlers[id] = resolve;\n      this.dataMethods[id] = data.method;\n      this.errorHandlers[id] = reject;\n\n      // send the data\n      this.socket.send(JSON.stringify(data), function (error) {\n        if (util.hasValue(error)) {\n          log.debug(`WebKit socket error occurred: ${error}`);\n          reject(new Error(error));\n        }\n      });\n    }).catch((e) => {\n      if (e.constructor.name !== WebKitRPCWarning.name) {\n        throw e;\n      }\n      log.warn(e.message);\n      return Promise.resolve(null);\n    }).finally((res) => {\n      // no need to hold onto anything\n      delete this.dataHandlers[id];\n      delete this.dataMethods[id];\n      delete this.errorHandlers[id];\n\n      // and pass along the result\n      return res;\n    }).timeout(this.responseTimeout);\n  }\n\n  receive (data) {\n    log.debug(`Received WebKit data: '${_.truncate(data, DATA_LOG_LENGTH)}'`);\n    data = util.safeJsonParse(data);\n\n    const rejectCall = (error) => {\n      if (data && this.errorHandlers[data.id]) {\n        return this.errorHandlers[data.id](error);\n      }\n\n      if (error.constructor.name === WebKitRPCWarning.name) {\n        log.warn(error.message);\n      } else {\n        log.errorAndThrow(error);\n      }\n    };\n\n    if (!_.isPlainObject(data)) {\n      return rejectCall(new WebKitRPCWarning(`No parseable data found`));\n    }\n\n    // we can get an error, or we can get a response that is an error\n    if (data.wasThrown || (data.result && data.result.wasThrown)) {\n      const message = data.wasThrown\n        ? data.result.value || data.result.description\n        : data.result.result.value || data.result.result.description;\n      return rejectCall(new Error(message));\n    }\n\n    const msgId = data.id;\n    // when sending we set a data method and associated callback.\n    // get that, or the generic (automatically sent, not associated\n    // with a particular request) method\n    const method = this.dataMethods[msgId] || data.method;\n    if (!method) {\n      return rejectCall(\n        new WebKitRPCWarning(`Did not find any handlers for ${msgId ? `'${msgId}'` : 'the recent'} message`));\n    }\n    log.debug(`Found method '${method}'${msgId ? ` for '${msgId}' message` : ''}`);\n    let isEventHandled = false;\n    switch (method) {\n      case 'Profiler.resetProfiles':\n        log.debug('Device is telling us to reset profiles. Should probably ' +\n                  'do some kind of callback here');\n        isEventHandled = true;\n        break;\n      case 'Timeline.eventRecorded':\n        if (this.timelineEventHandler) {\n          this.timelineEventHandler(data.result);\n          isEventHandled = true;\n        }\n        break;\n      case 'Console.messageAdded':\n        if (this.consoleEventHandler) {\n          this.consoleEventHandler(data.params.message);\n          isEventHandled = true;\n        }\n        break;\n      case 'Page.navigate':\n        log.debug(`Received page navigated message: ${simpleStringify(data)}`);\n        isEventHandled = true;\n        break;\n      case 'Network.dataReceived':\n      case 'Network.requestWillBeSent':\n      case 'Network.responseReceived':\n      case 'Network.loadingFinished':\n      case 'Network.loadingFailed':\n        if (_.isFunction(this.networkEventHandler)) {\n          this.networkEventHandler(method, data.params);\n          return;\n        }\n        break;\n    }\n    if (!data.error && _.has(this.dataHandlers, msgId)) {\n      return this.dataHandlers[msgId](data.result);\n    }\n    if (data.error && _.has(this.errorHandlers, msgId)) {\n      return this.errorHandlers[msgId](data.error);\n    }\n    if (!isEventHandled) {\n      log.debug(`There is no handler scheduled for method '${method}' in ${msgId ? `'${msgId}'` : 'the recent'} message`);\n    }\n  }\n\n  setTimelineEventHandler (timelineEventHandler) {\n    this.timelineEventHandler = timelineEventHandler;\n  }\n\n  setConsoleLogEventHandler (consoleEventHandler) {\n    this.consoleEventHandler = consoleEventHandler;\n  }\n\n  setNetworkLogEventHandler (networkEventHandler) {\n    this.networkEventHandler = networkEventHandler;\n  }\n}\n\n\nclass WebKitRPCWarning extends ES6Error {}\n"],"file":"lib/webkit-rpc-client.js","sourceRoot":"../.."}