UNPKG

webdriverio-automation

Version:

WebdriverIO-Automation android ios project

211 lines (167 loc) 27.9 kB
"use strict"; 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 _lodash = _interopRequireDefault(require("lodash")); class RpcMessageHandler { constructor(specialHandlers) { this.setHandlers(); this.errorHandlers = {}; this.specialHandlers = _lodash.default.clone(specialHandlers); this.dataHandlers = {}; this.willNavigateWithoutReload = false; } setDataMessageHandler(key, errorHandler, handler) { this.errorHandlers[key] = errorHandler; this.dataHandlers[key] = handler; } setSpecialMessageHandler(key, errorHandler, handler) { this.errorHandlers[key] = errorHandler; this.specialHandlers[key] = handler; } getSpecialMessageHandler(key) { return this.specialHandlers[key]; } setTimelineEventHandler(timelineEventHandler) { this.timelineEventHandler = timelineEventHandler; } setConsoleLogEventHandler(consoleLogEventHandler) { this.consoleLogEventHandler = consoleLogEventHandler; } setNetworkEventHandler(networkLogEventHandler) { this.networkLogEventHandler = networkLogEventHandler; } hasErrorHandler(key) { return _lodash.default.has(this.errorHandlers, key); } hasSpecialMessageHandler(key) { return _lodash.default.has(this.specialHandlers, key); } allowNavigationWithoutReload(allow = true) { this.willNavigateWithoutReload = allow; } handleMessage(plist) { let handlerFor = plist.__selector; if (!handlerFor) { _logger.default.debug('Got an invalid plist'); return; } if (_lodash.default.has(this.handlers, handlerFor)) { this.handlers[handlerFor](plist); } else { _logger.default.debug(`Debugger got a message for '${handlerFor}' and have no ` + `handler, doing nothing.`); } } handleSpecialMessage(handler, ...args) { const fn = this.specialHandlers[handler]; if (fn) { if (handler !== '_rpc_forwardGetListing:' && handler !== '_rpc_applicationDisconnected:' && handler !== '_rpc_applicationConnected:' && handler !== '_rpc_applicationUpdated:' && handler !== '_rpc_reportConnectedDriverList:') { this.specialHandlers[handler] = null; } fn(...args); } else { _logger.default.warn(`Tried to access special message handler '${handler}' ` + `but none was found`); } } parseDataKey(plist) { try { return JSON.parse(plist.__argument.WIRMessageDataKey.toString('utf8')); } catch (err) { _logger.default.error(`Unparseable message data: ${_lodash.default.truncate(JSON.stringify(plist), { length: 100 })}`); throw new Error(`Unable to parse message data: ${err.message}`); } } handleDataMessage(plist) { var _this = this; return (0, _asyncToGenerator2.default)(function* () { const dataKey = _this.parseDataKey(plist); const msgId = (dataKey.id || '').toString(); let result = dataKey.result; let error = dataKey.error || null; if (result && result.wasThrown) { let message = result.result && (result.result.value || result.result.description) ? result.result.value || result.result.description : 'Error occurred in handling data message'; error = new Error(message); } if (error) { if (_this.hasErrorHandler(msgId)) { _this.errorHandlers[msgId](error); } else { _logger.default.error(`Error occurred in handling data message: ${error}`); _logger.default.error('No error handler present, ignoring'); } return; } if (dataKey.method === 'Profiler.resetProfiles') { _logger.default.debug('Device is telling us to reset profiles. Should probably ' + 'do some kind of callback here'); } else if (dataKey.method === 'Page.frameNavigated') { if (!_this.willNavigateWithoutReload && !_this.pageLoading) { _logger.default.debug('Frame navigated, unloading page'); if (_lodash.default.isFunction(_this.specialHandlers['Page.frameNavigated'])) { _this.specialHandlers['Page.frameNavigated']('remote-debugger'); _this.specialHandlers['Page.frameNavigated'] = null; } } else { _logger.default.debug('Frame navigated but we were warned about it, not ' + 'considering page state unloaded'); _this.willNavigateWithoutReload = false; } } else if (dataKey.method === 'Page.loadEventFired' && _lodash.default.isFunction(_this.specialHandlers.pageLoad)) { yield _this.specialHandlers.pageLoad(); } else if (dataKey.method === 'Page.frameDetached' && _lodash.default.isFunction(_this.specialHandlers.frameDetached)) { yield _this.specialHandlers.frameDetached(); } else if (dataKey.method === 'Timeline.eventRecorded' && _lodash.default.isFunction(_this.timelineEventHandler)) { _this.timelineEventHandler(dataKey.params.record); } else if (dataKey.method === 'Console.messageAdded' && _lodash.default.isFunction(_this.consoleLogEventHandler)) { _this.consoleLogEventHandler(dataKey.params.message); } else if (dataKey.method && dataKey.method.startsWith('Network.') && _lodash.default.isFunction(_this.networkLogEventHandler)) { _this.networkLogEventHandler(dataKey.method, dataKey.params); } else if (_lodash.default.isFunction(_this.dataHandlers[msgId])) { _logger.default.debug('Found data handler for response'); if (result.result && result.result.value) { result = result.result.value; } _this.dataHandlers[msgId](result); _this.dataHandlers[msgId] = null; } else if (_this.dataHandlers[msgId] === null) { _logger.default.error(`Debugger returned data for message ${msgId} ` + `but we already ran that callback! WTF??`); } else { if (msgId || result || error) { _logger.default.error(`Debugger returned data for message '${msgId}' ` + `but we were not waiting for that message! ` + `result: '${JSON.stringify(result)}'; ` + `error: '${error}'`); } } })(); } setHandlers() { this.handlers = { '_rpc_reportSetup:': plist => { this.handleSpecialMessage('_rpc_reportIdentifier:', plist.__argument.WIRSimulatorNameKey, plist.__argument.WIRSimulatorBuildKey, plist.__argument.WIRSimulatorProductVersionKey); }, '_rpc_reportConnectedApplicationList:': plist => { this.handleSpecialMessage('_rpc_reportConnectedApplicationList:', plist.__argument.WIRApplicationDictionaryKey); }, '_rpc_applicationSentListing:': plist => { this.handleSpecialMessage('_rpc_forwardGetListing:', plist.__argument.WIRApplicationIdentifierKey, plist.__argument.WIRListingKey); }, '_rpc_applicationConnected:': plist => { this.handleSpecialMessage('_rpc_applicationConnected:', plist.__argument); }, '_rpc_applicationDisconnected:': plist => { this.handleSpecialMessage('_rpc_applicationDisconnected:', plist.__argument); }, '_rpc_applicationUpdated:': plist => { this.handleSpecialMessage('_rpc_applicationUpdated:', plist.__argument); }, '_rpc_reportConnectedDriverList:': plist => { this.handleSpecialMessage('_rpc_reportConnectedDriverList:', plist.__argument); }, '_rpc_applicationSentData:': this.handleDataMessage.bind(this) }; } } exports.default = RpcMessageHandler;require('source-map-support').install(); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/remote-debugger-message-handler.js"],"names":["RpcMessageHandler","constructor","specialHandlers","setHandlers","errorHandlers","_","clone","dataHandlers","willNavigateWithoutReload","setDataMessageHandler","key","errorHandler","handler","setSpecialMessageHandler","getSpecialMessageHandler","setTimelineEventHandler","timelineEventHandler","setConsoleLogEventHandler","consoleLogEventHandler","setNetworkEventHandler","networkLogEventHandler","hasErrorHandler","has","hasSpecialMessageHandler","allowNavigationWithoutReload","allow","handleMessage","plist","handlerFor","__selector","log","debug","handlers","handleSpecialMessage","args","fn","warn","parseDataKey","JSON","parse","__argument","WIRMessageDataKey","toString","err","error","truncate","stringify","length","Error","message","handleDataMessage","dataKey","msgId","id","result","wasThrown","value","description","method","pageLoading","isFunction","pageLoad","frameDetached","params","record","startsWith","WIRSimulatorNameKey","WIRSimulatorBuildKey","WIRSimulatorProductVersionKey","WIRApplicationDictionaryKey","WIRApplicationIdentifierKey","WIRListingKey","bind"],"mappings":"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","sourcesContent":["import log from './logger';\nimport _ from 'lodash';\n\n\nexport default class RpcMessageHandler {\n  constructor (specialHandlers) {\n    this.setHandlers();\n    this.errorHandlers = {};\n    this.specialHandlers = _.clone(specialHandlers);\n    this.dataHandlers = {};\n    this.willNavigateWithoutReload = false;\n  }\n\n  setDataMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.dataHandlers[key] = handler;\n  }\n\n  setSpecialMessageHandler (key, errorHandler, handler) {\n    this.errorHandlers[key] = errorHandler;\n    this.specialHandlers[key] = handler;\n  }\n\n  getSpecialMessageHandler (key) {\n    return this.specialHandlers[key];\n  }\n\n  setTimelineEventHandler (timelineEventHandler) {\n    this.timelineEventHandler = timelineEventHandler;\n  }\n\n  setConsoleLogEventHandler (consoleLogEventHandler) {\n    this.consoleLogEventHandler = consoleLogEventHandler;\n  }\n\n  setNetworkEventHandler (networkLogEventHandler) {\n    this.networkLogEventHandler = networkLogEventHandler;\n  }\n\n  hasErrorHandler (key) {\n    return _.has(this.errorHandlers, key);\n  }\n\n  hasSpecialMessageHandler (key) {\n    return _.has(this.specialHandlers, key);\n  }\n\n  allowNavigationWithoutReload (allow = true) {\n    this.willNavigateWithoutReload = allow;\n  }\n\n  handleMessage (plist) {\n    let handlerFor = plist.__selector;\n    if (!handlerFor) {\n      log.debug('Got an invalid plist');\n      return;\n    }\n\n    if (_.has(this.handlers, handlerFor)) {\n      this.handlers[handlerFor](plist);\n    } else {\n      log.debug(`Debugger got a message for '${handlerFor}' and have no ` +\n                `handler, doing nothing.`);\n    }\n  }\n\n  handleSpecialMessage (handler, ...args) {\n    const fn = this.specialHandlers[handler];\n\n    if (fn) {\n      // most responses are only to be called once, then\n      // removed. But not the ones below, which handle\n      // page change and app connect/disconnect\n      if (handler !== '_rpc_forwardGetListing:' &&\n          handler !== '_rpc_applicationDisconnected:' &&\n          handler !== '_rpc_applicationConnected:' &&\n          handler !== '_rpc_applicationUpdated:' &&\n          handler !== '_rpc_reportConnectedDriverList:') {\n        this.specialHandlers[handler] = null;\n      }\n      fn(...args);\n    } else {\n      log.warn(`Tried to access special message handler '${handler}' ` +\n               `but none was found`);\n    }\n  }\n\n  parseDataKey (plist) {\n    try {\n      return JSON.parse(plist.__argument.WIRMessageDataKey.toString('utf8'));\n    } catch (err) {\n      log.error(`Unparseable message data: ${_.truncate(JSON.stringify(plist), {length: 100})}`);\n      throw new Error(`Unable to parse message data: ${err.message}`);\n    }\n  }\n\n  async handleDataMessage (plist) {\n    const dataKey = this.parseDataKey(plist);\n    const msgId = (dataKey.id || '').toString();\n    let result = dataKey.result;\n    let error = dataKey.error || null;\n\n    // we can get an error, or we can get a response that is an error\n    if (result && result.wasThrown) {\n      let message = (result.result && (result.result.value || result.result.description))\n        ? (result.result.value || result.result.description)\n        : 'Error occurred in handling data message';\n      error = new Error(message);\n    }\n\n    if (error) {\n      if (this.hasErrorHandler(msgId)) {\n        this.errorHandlers[msgId](error);\n      } else {\n        log.error(`Error occurred in handling data message: ${error}`);\n        log.error('No error handler present, ignoring');\n      }\n\n      // short circuit\n      return;\n    }\n\n    if (dataKey.method === 'Profiler.resetProfiles') {\n      log.debug('Device is telling us to reset profiles. Should probably ' +\n                'do some kind of callback here');\n    } else if (dataKey.method === 'Page.frameNavigated') {\n      if (!this.willNavigateWithoutReload && !this.pageLoading) {\n        log.debug('Frame navigated, unloading page');\n        if (_.isFunction(this.specialHandlers['Page.frameNavigated'])) {\n          this.specialHandlers['Page.frameNavigated']('remote-debugger');\n          this.specialHandlers['Page.frameNavigated'] = null;\n        }\n      } else {\n        log.debug('Frame navigated but we were warned about it, not ' +\n                  'considering page state unloaded');\n        this.willNavigateWithoutReload = false;\n      }\n    } else if (dataKey.method === 'Page.loadEventFired' && _.isFunction(this.specialHandlers.pageLoad)) {\n      await this.specialHandlers.pageLoad();\n    } else if (dataKey.method === 'Page.frameDetached' && _.isFunction(this.specialHandlers.frameDetached)) {\n      await this.specialHandlers.frameDetached();\n    } else if (dataKey.method === 'Timeline.eventRecorded' && _.isFunction(this.timelineEventHandler)) {\n      this.timelineEventHandler(dataKey.params.record);\n    } else if (dataKey.method === 'Console.messageAdded' && _.isFunction(this.consoleLogEventHandler)) {\n      this.consoleLogEventHandler(dataKey.params.message);\n    } else if (dataKey.method && dataKey.method.startsWith('Network.') && _.isFunction(this.networkLogEventHandler)) {\n      this.networkLogEventHandler(dataKey.method, dataKey.params);\n    } else if (_.isFunction(this.dataHandlers[msgId])) {\n      log.debug('Found data handler for response');\n      // we will either get back a result object that has a result.value\n      // in which case that is what we want,\n      // or else we return the whole thing\n      if (result.result && result.result.value) {\n        result = result.result.value;\n      }\n      this.dataHandlers[msgId](result);\n      this.dataHandlers[msgId] = null;\n    } else if (this.dataHandlers[msgId] === null) {\n      log.error(`Debugger returned data for message ${msgId} ` +\n                `but we already ran that callback! WTF??`);\n    } else {\n      if (msgId || result || error) {\n        log.error(`Debugger returned data for message '${msgId}' ` +\n                  `but we were not waiting for that message! ` +\n                  `result: '${JSON.stringify(result)}'; ` +\n                  `error: '${error}'`);\n      }\n    }\n  }\n\n  setHandlers () {\n    this.handlers = {\n      '_rpc_reportSetup:': (plist) => {\n        this.handleSpecialMessage('_rpc_reportIdentifier:',\n            plist.__argument.WIRSimulatorNameKey,\n            plist.__argument.WIRSimulatorBuildKey,\n            plist.__argument.WIRSimulatorProductVersionKey);\n      },\n      '_rpc_reportConnectedApplicationList:': (plist) => {\n        this.handleSpecialMessage('_rpc_reportConnectedApplicationList:',\n            plist.__argument.WIRApplicationDictionaryKey);\n      },\n      '_rpc_applicationSentListing:': (plist) => {\n        this.handleSpecialMessage('_rpc_forwardGetListing:',\n            plist.__argument.WIRApplicationIdentifierKey,\n            plist.__argument.WIRListingKey);\n      },\n      '_rpc_applicationConnected:': (plist) => {\n        this.handleSpecialMessage('_rpc_applicationConnected:',\n            plist.__argument);\n      },\n      '_rpc_applicationDisconnected:': (plist) => {\n        this.handleSpecialMessage('_rpc_applicationDisconnected:',\n            plist.__argument);\n      },\n      '_rpc_applicationUpdated:': (plist) => {\n        this.handleSpecialMessage('_rpc_applicationUpdated:',\n            plist.__argument);\n      },\n      '_rpc_reportConnectedDriverList:': (plist) => {\n        this.handleSpecialMessage('_rpc_reportConnectedDriverList:',\n            plist.__argument);\n      },\n      '_rpc_applicationSentData:': this.handleDataMessage.bind(this),\n    };\n  }\n}\n"],"file":"lib/remote-debugger-message-handler.js","sourceRoot":"../.."}