UNPKG

selenium-webdriver

Version:

The official WebDriver JavaScript bindings from the Selenium project

81 lines (69 loc) 2.44 kB
// Licensed to the Software Freedom Conservancy (SFC) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The SFC licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. const logging = require('../lib/logging') const RESPONSE_TIMEOUT = 1000 * 30 class CDPConnection { constructor(wsConnection) { this._wsConnection = wsConnection this.cmd_id = 0 this.targetID = null this.sessionId = null } execute(method, params, callback) { let message = { method, id: this.cmd_id++, } if (this.sessionId) { message['sessionId'] = this.sessionId } const mergedMessage = Object.assign({ params: params }, message) this._wsConnection.send(JSON.stringify(mergedMessage), callback) } async send(method, params) { let cdp_id = this.cmd_id++ let message = { method, id: cdp_id, } if (this.sessionId) { message['sessionId'] = this.sessionId } const mergedMessage = Object.assign({ params: params }, message) this._wsConnection.send(JSON.stringify(mergedMessage)) return new Promise((resolve, reject) => { const timeoutId = setTimeout(() => { reject(new Error(`Request with id ${cdp_id} timed out`)) handler.off('message', listener) }, RESPONSE_TIMEOUT) const listener = (data) => { try { const payload = JSON.parse(data.toString()) if (payload.id === cdp_id) { clearTimeout(timeoutId) handler.off('message', listener) resolve(payload) } } catch (err) { logging.getLogger(logging.Type.BROWSER).severe(`Failed parse message: ${err.message}`) } } const handler = this._wsConnection.on('message', listener) }) } } exports.CdpConnection = CDPConnection