Socket
Socket
Sign inDemoInstall

webdriver

Package Overview
Dependencies
Maintainers
1
Versions
476
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

webdriver - npm Package Compare versions

Comparing version 5.0.0-beta.1 to 5.0.0-beta.2

3

build/command.js

@@ -102,2 +102,3 @@ 'use strict';

this.emit('command', { method, endpoint, body });
log.info('COMMAND', (0, _utils.commandCallStructure)(command, args));
return request.makeRequest(this.options, this.sessionId).then(result => {

@@ -132,2 +133,2 @@ if (result.value) {

module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/command.js"],"names":["method","endpointUri","commandInfo","command","ref","parameters","variables","args","endpoint","commandParams","map","v","Object","assign","required","type","commandUsage","p","name","join","moreInfo","body","minAllowedParams","filter","param","length","parameterDescription","description","Error","entries","i","arg","commandParam","replace","request","WebDriverRequest","emit","makeRequest","options","sessionId","then","result","value","log","info"],"mappings":"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","file":"command.js","sourcesContent":["import logger from 'wdio-logger'\nimport WebDriverRequest from './request'\nimport { isValidParameter } from './utils'\n\nconst log = logger('webdriver')\n\nexport default function (method, endpointUri, commandInfo) {\n    const { command, ref, parameters, variables = [] } = commandInfo\n\n    return function (...args) {\n        let endpoint = endpointUri // clone endpointUri in case we change it\n        const commandParams = [...variables.map((v) => Object.assign(v, {\n            /**\n             * url variables are:\n             */\n            required: true, // always required as they are part of the endpoint\n            type: 'string'  // have to be always type of string\n        })), ...parameters]\n\n        const commandUsage = `${command}(${commandParams.map((p) => p.name).join(', ')})`\n        const moreInfo = `\\n\\nFor more info see ${ref}\\n`\n        const body = {}\n\n        /**\n         * parameter check\n         */\n        const minAllowedParams = commandParams.filter((param) => param.required).length\n        if (args.length < minAllowedParams || args.length > commandParams.length) {\n            const parameterDescription = commandParams.length\n                ? `\\n\\nProperty Description:\\n${commandParams.map((p) => `  \"${p.name}\" (${p.type}): ${p.description}`).join('\\n')}`\n                : ''\n\n            throw new Error(\n                `Wrong parameters applied for ${command}\\n` +\n                `Usage: ${commandUsage}` +\n                parameterDescription +\n                moreInfo\n            )\n        }\n\n        /**\n         * parameter type check\n         */\n        for (const [i, arg] of Object.entries(args)) {\n            const commandParam = commandParams[i]\n\n            if (!isValidParameter(arg, commandParam.type)) {\n                /**\n                 * ignore if argument is not required\n                 */\n                if (typeof arg === 'undefined' && !commandParam.required) {\n                    continue\n                }\n\n                throw new Error(\n                    `Malformed type for \"${commandParam.name}\" parameter of command ${command}\\n` +\n                    `Expected: ${commandParam.type}\\n` +\n                    `Actual: ${typeof arg}` +\n                    moreInfo\n                )\n            }\n\n            /**\n             * inject url variables\n             */\n            if (i < variables.length) {\n                endpoint = endpoint.replace(`:${commandParams[i].name}`, arg)\n                continue\n            }\n\n            /**\n             * rest of args are part of body payload\n             */\n            body[commandParams[i].name] = arg\n        }\n\n        const request = new WebDriverRequest(method, endpoint, body)\n        this.emit('command', { method, endpoint, body })\n        return request.makeRequest(this.options, this.sessionId).then((result) => {\n            if (result.value) {\n                log.info('RESULT', result.value)\n            }\n\n            this.emit('result', { method, endpoint, body, result })\n            return result.value\n        })\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/command.js"],"names":["method","endpointUri","commandInfo","command","ref","parameters","variables","args","endpoint","commandParams","map","v","Object","assign","required","type","commandUsage","p","name","join","moreInfo","body","minAllowedParams","filter","param","length","parameterDescription","description","Error","entries","i","arg","commandParam","replace","request","WebDriverRequest","emit","log","info","makeRequest","options","sessionId","then","result","value"],"mappings":"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","file":"command.js","sourcesContent":["import logger from 'wdio-logger'\nimport WebDriverRequest from './request'\nimport { isValidParameter, commandCallStructure } from './utils'\n\nconst log = logger('webdriver')\n\nexport default function (method, endpointUri, commandInfo) {\n    const { command, ref, parameters, variables = [] } = commandInfo\n\n    return function (...args) {\n        let endpoint = endpointUri // clone endpointUri in case we change it\n        const commandParams = [...variables.map((v) => Object.assign(v, {\n            /**\n             * url variables are:\n             */\n            required: true, // always required as they are part of the endpoint\n            type: 'string'  // have to be always type of string\n        })), ...parameters]\n\n        const commandUsage = `${command}(${commandParams.map((p) => p.name).join(', ')})`\n        const moreInfo = `\\n\\nFor more info see ${ref}\\n`\n        const body = {}\n\n        /**\n         * parameter check\n         */\n        const minAllowedParams = commandParams.filter((param) => param.required).length\n        if (args.length < minAllowedParams || args.length > commandParams.length) {\n            const parameterDescription = commandParams.length\n                ? `\\n\\nProperty Description:\\n${commandParams.map((p) => `  \"${p.name}\" (${p.type}): ${p.description}`).join('\\n')}`\n                : ''\n\n            throw new Error(\n                `Wrong parameters applied for ${command}\\n` +\n                `Usage: ${commandUsage}` +\n                parameterDescription +\n                moreInfo\n            )\n        }\n\n        /**\n         * parameter type check\n         */\n        for (const [i, arg] of Object.entries(args)) {\n            const commandParam = commandParams[i]\n\n            if (!isValidParameter(arg, commandParam.type)) {\n                /**\n                 * ignore if argument is not required\n                 */\n                if (typeof arg === 'undefined' && !commandParam.required) {\n                    continue\n                }\n\n                throw new Error(\n                    `Malformed type for \"${commandParam.name}\" parameter of command ${command}\\n` +\n                    `Expected: ${commandParam.type}\\n` +\n                    `Actual: ${typeof arg}` +\n                    moreInfo\n                )\n            }\n\n            /**\n             * inject url variables\n             */\n            if (i < variables.length) {\n                endpoint = endpoint.replace(`:${commandParams[i].name}`, arg)\n                continue\n            }\n\n            /**\n             * rest of args are part of body payload\n             */\n            body[commandParams[i].name] = arg\n        }\n\n        const request = new WebDriverRequest(method, endpoint, body)\n        this.emit('command', { method, endpoint, body })\n        log.info('COMMAND', commandCallStructure(command, args))\n        return request.makeRequest(this.options, this.sessionId).then((result) => {\n            if (result.value) {\n                log.info('RESULT', result.value)\n            }\n\n            this.emit('result', { method, endpoint, body, result })\n            return result.value\n        })\n    }\n}\n"]}

@@ -6,3 +6,3 @@ 'use strict';

});
exports.DEFAULTS = exports.ERROR_CODES = undefined;
exports.DEFAULTS = undefined;

@@ -16,115 +16,2 @@ var _sourceMapSupport2 = require('source-map-support');

/**
* Webdriver Errors
*/
const Unknown = { id: 'Unknown', status: -1, message: 'Remote end send an unknown status code.' };
const Success = { id: 'Success', status: 0, message: 'The command executed successfully.' };
const NoSuchDriver = { id: 'NoSuchDriver', status: 6, message: 'A session is either terminated or not started' };
const NoSuchElement = { id: 'NoSuchElement', status: 404, message: 'An element could not be located on the page using the given search parameters.' };
const NoSuchFrame = { id: 'NoSuchFrame', status: 400, message: 'A request to switch to a frame could not be satisfied because the frame could not be found.' };
const UnknownCommand = { id: 'UnknownCommand', status: 404, message: 'The requested resource could not be found, or a request was received using an HTTP method that is not supported by the mapped resource.' };
const StaleElementReference = { id: 'StaleElementReference', status: 400, message: 'An element command failed because the referenced element is no longer attached to the DOM.' };
const ElementNotVisible = { id: 'ElementNotVisible', status: 11, message: 'An element command could not be completed because the element is not visible on the page.' };
const InvalidElementState = { id: 'InvalidElementState', status: 400, message: 'An element command could not be completed because the element is in an invalid state (e.g. attempting to click a disabled element).' };
const UnknownError = { id: 'UnknownError', status: 500, message: 'An unknown server-side error occurred while processing the command.' };
const ElementIsNotSelectable = { id: 'ElementIsNotSelectable', status: 400, message: 'An attempt was made to select an element that cannot be selected.' };
const JavaScriptError = { id: 'JavaScriptError', status: 500, message: 'An error occurred while executing user supplied JavaScript.' };
const XPathLookupError = { id: 'XPathLookupError', status: 19, message: 'An error occurred while searching for an element by XPath.' };
const Timeout = { id: 'Timeout', status: 408, message: 'An operation did not complete before its timeout expired.' };
const NoSuchWindow = { id: 'NoSuchWindow', status: 400, message: 'A request to switch to a different window could not be satisfied because the window could not be found.' };
const InvalidCookieDomain = { id: 'InvalidCookieDomain', status: 400, message: 'An illegal attempt was made to set a cookie under a different domain than the current page.' };
const UnableToSetCookie = { id: 'UnableToSetCookie', status: 500, message: 'A request to set a cookie\'s value could not be satisfied.' };
const UnexpectedAlertOpen = { id: 'UnexpectedAlertOpen', status: 500, message: 'A modal dialog was open, blocking this operation' };
const NoAlertOpenError = { id: 'NoAlertOpenError', status: 400, message: 'An attempt was made to operate on a modal dialog when one was not open.' };
const ScriptTimeout = { id: 'ScriptTimeout', status: 408, message: 'A script did not complete before its timeout expired.' };
const InvalidElementCoordinates = { id: 'InvalidElementCoordinates', status: 400, message: 'The coordinates provided to an interactions operation are invalid.' };
const IMENotAvailable = { id: 'IMENotAvailable', status: 30, message: 'IME was not available.' };
const IMEEngineActivationFailed = { id: 'IMEEngineActivationFailed', status: 31, message: 'An IME engine could not be started.' };
const InvalidSelector = { id: 'InvalidSelector', status: 400, message: 'Argument was an invalid selector (e.g. XPath/CSS).' };
const SessionNotCreatedException = { id: 'SessionNotCreatedException', status: 500, message: 'A new session could not be created.' };
const ElementNotScrollable = { id: 'ElementNotScrollable', status: 34, message: 'Element cannot be scrolled into view.' };
const SelectorTimeoutError = { id: 'SelectorTimeoutError', status: 100, message: 'Request timed out after the element was still found on the page.' };
const NoSessionIdError = { id: 'NoSessionIdError', status: 101, message: 'A session id is required for this command but wasn\'t found in the response payload' };
const GridApiError = { id: 'GridApiError', status: 102, message: 'A call to the Selenium Grid API failed' };
const ElementClickIntercepted = { id: 'ElementClickIntercepted', status: 400, message: 'The Element Click command could not be completed because the element receiving the events is obscuring the element that was requested clicked.' };
const ElementNotInteractable = { id: 'ElementNotInteractable', status: 400, message: 'A command could not be completed because the element is not pointer- or keyboard interactable.' };
const InsecureCertificate = { id: 'InsecureCertificate', status: 400, message: 'Navigation caused the user agent to hit a certificate warning, which is usually the result of an expired or invalid TLS certificate.' };
const InvalidArgument = { id: 'InvalidArgument', status: 400, message: 'The arguments passed to a command are either invalid or malformed.' };
const InvalidSessionId = { id: 'InvalidSessionId', status: 404, message: 'Occurs if the given session id is not in the list of active sessions, meaning the session either does not exist or that it’s not active.' };
const MoveTargetOutOfBounds = { id: 'MoveTargetOutOfBounds', status: 500, message: 'The target for mouse interaction is not in the browser’s viewport and cannot be brought into that viewport.' };
const NoSuchCookie = { id: 'NoSuchCookie', status: 404, message: 'No cookie matching the given path name was found amongst the associated cookies of the current browsing context’s active document.' };
const UnableToCaptureScreen = { id: 'UnableToCaptureScreen', status: 500, message: 'A screen capture was made impossible.' };
const UnknownMethod = { id: 'UnknownMethod', status: 405, message: 'The requested command matched a known URL but did not match an method for that URL.' };
const UnsupportedOperation = { id: 'UnsupportedOperation', status: 500, message: 'Indicates that a command that should have executed properly cannot be supported for some reason.'
/**
* selenium error codes
* https://w3c.github.io/webdriver/webdriver-spec.html#dfn-error-code
*/
};const ERROR_CODES = {
'-1': Unknown,
'0': Success,
'6': NoSuchDriver,
'7': NoSuchElement,
'8': NoSuchFrame,
'9': UnknownCommand,
'10': StaleElementReference,
'11': ElementNotVisible,
'12': InvalidElementState,
'13': UnknownError,
'15': ElementIsNotSelectable,
'17': JavaScriptError,
'19': XPathLookupError,
'21': Timeout,
'23': NoSuchWindow,
'24': InvalidCookieDomain,
'25': UnableToSetCookie,
'26': UnexpectedAlertOpen,
'27': NoAlertOpenError,
'28': ScriptTimeout,
'29': InvalidElementCoordinates,
'30': IMENotAvailable,
'31': IMEEngineActivationFailed,
'32': InvalidSelector,
'33': SessionNotCreatedException,
'34': ElementNotScrollable,
// WebdriverIO specific error codes
'100': SelectorTimeoutError,
'101': NoSessionIdError,
'102': GridApiError,
// W3C Webdriver errors
'element click intercepted': ElementClickIntercepted,
'element not selectable': ElementIsNotSelectable,
'element not interactable': ElementNotInteractable,
'insecure certificate': InsecureCertificate,
'invalid argument': InvalidArgument,
'invalid cookie domain': InvalidCookieDomain,
'invalid coordinates': InvalidElementCoordinates,
'invalid element state': InvalidElementState,
'invalid selector': InvalidSelector,
'invalid session id': InvalidSessionId,
'javascript error': JavaScriptError,
'move target out of bounds': MoveTargetOutOfBounds,
'no such alert': NoAlertOpenError,
'no such cookie': NoSuchCookie,
'no such element': NoSuchElement,
'no such frame': NoSuchFrame,
'no such window': NoSuchWindow,
'script timeout': ScriptTimeout,
'session not created': SessionNotCreatedException,
'stale element reference': StaleElementReference,
'timeout': Timeout,
'unable to set cookie': UnableToSetCookie,
'unable to capture screen': UnableToCaptureScreen,
'unexpected alert open': UnexpectedAlertOpen,
'unknown command': UnknownCommand,
'unknown error': UnknownError,
'unknown method': UnknownMethod,
'unsupported operation': UnsupportedOperation
};
const DEFAULTS = {

@@ -221,4 +108,3 @@ /**

exports.ERROR_CODES = ERROR_CODES;
exports.DEFAULTS = DEFAULTS;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/constants.js"],"names":["Unknown","id","status","message","Success","NoSuchDriver","NoSuchElement","NoSuchFrame","UnknownCommand","StaleElementReference","ElementNotVisible","InvalidElementState","UnknownError","ElementIsNotSelectable","JavaScriptError","XPathLookupError","Timeout","NoSuchWindow","InvalidCookieDomain","UnableToSetCookie","UnexpectedAlertOpen","NoAlertOpenError","ScriptTimeout","InvalidElementCoordinates","IMENotAvailable","IMEEngineActivationFailed","InvalidSelector","SessionNotCreatedException","ElementNotScrollable","SelectorTimeoutError","NoSessionIdError","GridApiError","ElementClickIntercepted","ElementNotInteractable","InsecureCertificate","InvalidArgument","InvalidSessionId","MoveTargetOutOfBounds","NoSuchCookie","UnableToCaptureScreen","UnknownMethod","UnsupportedOperation","ERROR_CODES","DEFAULTS","protocol","type","default","match","hostname","port","path","queryParams","capabilities","required","logLevel","logOutput","param","Writable","Error","connectionRetryTimeout","connectionRetryCount","user","key"],"mappings":"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","file":"constants.js","sourcesContent":["import { Writable } from 'stream'\n\n/**\n * Webdriver Errors\n */\nconst Unknown = {id: 'Unknown', status: -1, message: 'Remote end send an unknown status code.'}\nconst Success = {id: 'Success', status: 0, message: 'The command executed successfully.'}\nconst NoSuchDriver = {id: 'NoSuchDriver', status: 6, message: 'A session is either terminated or not started'}\nconst NoSuchElement = {id: 'NoSuchElement', status: 404, message: 'An element could not be located on the page using the given search parameters.'}\nconst NoSuchFrame = {id: 'NoSuchFrame', status: 400, message: 'A request to switch to a frame could not be satisfied because the frame could not be found.'}\nconst UnknownCommand = {id: 'UnknownCommand', status: 404, message: 'The requested resource could not be found, or a request was received using an HTTP method that is not supported by the mapped resource.'}\nconst StaleElementReference = {id: 'StaleElementReference', status: 400, message: 'An element command failed because the referenced element is no longer attached to the DOM.'}\nconst ElementNotVisible = {id: 'ElementNotVisible', status: 11, message: 'An element command could not be completed because the element is not visible on the page.'}\nconst InvalidElementState = {id: 'InvalidElementState', status: 400, message: 'An element command could not be completed because the element is in an invalid state (e.g. attempting to click a disabled element).'}\nconst UnknownError = {id: 'UnknownError', status: 500, message: 'An unknown server-side error occurred while processing the command.'}\nconst ElementIsNotSelectable = {id: 'ElementIsNotSelectable', status: 400, message: 'An attempt was made to select an element that cannot be selected.'}\nconst JavaScriptError = {id: 'JavaScriptError', status: 500, message: 'An error occurred while executing user supplied JavaScript.'}\nconst XPathLookupError = {id: 'XPathLookupError', status: 19, message: 'An error occurred while searching for an element by XPath.'}\nconst Timeout = {id: 'Timeout', status: 408, message: 'An operation did not complete before its timeout expired.'}\nconst NoSuchWindow = {id: 'NoSuchWindow', status: 400, message: 'A request to switch to a different window could not be satisfied because the window could not be found.'}\nconst InvalidCookieDomain = {id: 'InvalidCookieDomain', status: 400, message: 'An illegal attempt was made to set a cookie under a different domain than the current page.'}\nconst UnableToSetCookie = {id: 'UnableToSetCookie', status: 500, message: 'A request to set a cookie\\'s value could not be satisfied.'}\nconst UnexpectedAlertOpen = {id: 'UnexpectedAlertOpen', status: 500, message: 'A modal dialog was open, blocking this operation'}\nconst NoAlertOpenError = {id: 'NoAlertOpenError', status: 400, message: 'An attempt was made to operate on a modal dialog when one was not open.'}\nconst ScriptTimeout = {id: 'ScriptTimeout', status: 408, message: 'A script did not complete before its timeout expired.'}\nconst InvalidElementCoordinates = {id: 'InvalidElementCoordinates', status: 400, message: 'The coordinates provided to an interactions operation are invalid.'}\nconst IMENotAvailable = {id: 'IMENotAvailable', status: 30, message: 'IME was not available.'}\nconst IMEEngineActivationFailed = {id: 'IMEEngineActivationFailed', status: 31, message: 'An IME engine could not be started.'}\nconst InvalidSelector = {id: 'InvalidSelector', status: 400, message: 'Argument was an invalid selector (e.g. XPath/CSS).'}\nconst SessionNotCreatedException = {id: 'SessionNotCreatedException', status: 500, message: 'A new session could not be created.'}\nconst ElementNotScrollable = {id: 'ElementNotScrollable', status: 34, message: 'Element cannot be scrolled into view.'}\n\nconst SelectorTimeoutError = {id: 'SelectorTimeoutError', status: 100, message: 'Request timed out after the element was still found on the page.'}\nconst NoSessionIdError = {id: 'NoSessionIdError', status: 101, message: 'A session id is required for this command but wasn\\'t found in the response payload'}\nconst GridApiError = {id: 'GridApiError', status: 102, message: 'A call to the Selenium Grid API failed'}\n\nconst ElementClickIntercepted = {id: 'ElementClickIntercepted', status: 400, message: 'The Element Click command could not be completed because the element receiving the events is obscuring the element that was requested clicked.'}\nconst ElementNotInteractable = {id: 'ElementNotInteractable', status: 400, message: 'A command could not be completed because the element is not pointer- or keyboard interactable.'}\nconst InsecureCertificate = {id: 'InsecureCertificate', status: 400, message: 'Navigation caused the user agent to hit a certificate warning, which is usually the result of an expired or invalid TLS certificate.'}\nconst InvalidArgument = {id: 'InvalidArgument', status: 400, message: 'The arguments passed to a command are either invalid or malformed.'}\nconst InvalidSessionId = {id: 'InvalidSessionId', status: 404, message: 'Occurs if the given session id is not in the list of active sessions, meaning the session either does not exist or that it’s not active.'}\nconst MoveTargetOutOfBounds = {id: 'MoveTargetOutOfBounds', status: 500, message: 'The target for mouse interaction is not in the browser’s viewport and cannot be brought into that viewport.'}\nconst NoSuchCookie = {id: 'NoSuchCookie', status: 404, message: 'No cookie matching the given path name was found amongst the associated cookies of the current browsing context’s active document.'}\nconst UnableToCaptureScreen = {id: 'UnableToCaptureScreen', status: 500, message: 'A screen capture was made impossible.'}\nconst UnknownMethod = {id: 'UnknownMethod', status: 405, message: 'The requested command matched a known URL but did not match an method for that URL.'}\nconst UnsupportedOperation = {id: 'UnsupportedOperation', status: 500, message: 'Indicates that a command that should have executed properly cannot be supported for some reason.'}\n\n/**\n * selenium error codes\n * https://w3c.github.io/webdriver/webdriver-spec.html#dfn-error-code\n */\nconst ERROR_CODES = {\n    '-1': Unknown,\n    '0': Success,\n    '6': NoSuchDriver,\n    '7': NoSuchElement,\n    '8': NoSuchFrame,\n    '9': UnknownCommand,\n    '10': StaleElementReference,\n    '11': ElementNotVisible,\n    '12': InvalidElementState,\n    '13': UnknownError,\n    '15': ElementIsNotSelectable,\n    '17': JavaScriptError,\n    '19': XPathLookupError,\n    '21': Timeout,\n    '23': NoSuchWindow,\n    '24': InvalidCookieDomain,\n    '25': UnableToSetCookie,\n    '26': UnexpectedAlertOpen,\n    '27': NoAlertOpenError,\n    '28': ScriptTimeout,\n    '29': InvalidElementCoordinates,\n    '30': IMENotAvailable,\n    '31': IMEEngineActivationFailed,\n    '32': InvalidSelector,\n    '33': SessionNotCreatedException,\n    '34': ElementNotScrollable,\n\n    // WebdriverIO specific error codes\n    '100': SelectorTimeoutError,\n    '101': NoSessionIdError,\n    '102': GridApiError,\n\n    // W3C Webdriver errors\n    'element click intercepted': ElementClickIntercepted,\n    'element not selectable': ElementIsNotSelectable,\n    'element not interactable': ElementNotInteractable,\n    'insecure certificate': InsecureCertificate,\n    'invalid argument': InvalidArgument,\n    'invalid cookie domain': InvalidCookieDomain,\n    'invalid coordinates': InvalidElementCoordinates,\n    'invalid element state': InvalidElementState,\n    'invalid selector': InvalidSelector,\n    'invalid session id': InvalidSessionId,\n    'javascript error': JavaScriptError,\n    'move target out of bounds': MoveTargetOutOfBounds,\n    'no such alert': NoAlertOpenError,\n    'no such cookie': NoSuchCookie,\n    'no such element': NoSuchElement,\n    'no such frame': NoSuchFrame,\n    'no such window': NoSuchWindow,\n    'script timeout': ScriptTimeout,\n    'session not created': SessionNotCreatedException,\n    'stale element reference': StaleElementReference,\n    'timeout': Timeout,\n    'unable to set cookie': UnableToSetCookie,\n    'unable to capture screen': UnableToCaptureScreen,\n    'unexpected alert open': UnexpectedAlertOpen,\n    'unknown command': UnknownCommand,\n    'unknown error': UnknownError,\n    'unknown method': UnknownMethod,\n    'unsupported operation': UnsupportedOperation\n}\n\nconst DEFAULTS = {\n    /**\n     * protocol of automation driver\n     */\n    protocol: {\n        type: 'string',\n        default: 'http',\n        match: /(http|https)/\n    },\n    /**\n     * hostname of automation driver\n     */\n    hostname: {\n        type: 'string',\n        default: '0.0.0.0'\n    },\n    /**\n     * port of automation driver\n     */\n    port: {\n        type: 'number',\n        default: 4444\n    },\n    /**\n     * path to WebDriver endpoints\n     */\n    path: {\n        type: 'string',\n        default: '/wd/hub'\n    },\n    /**\n     * A key-value store of query parameters to be added to every selenium request\n     */\n    queryParams: {\n        type: 'object'\n    },\n    /**\n     * capability of WebDriver session\n     */\n    capabilities: {\n        type: 'object',\n        required: true\n    },\n    /**\n     * Level of logging verbosity\n     */\n    logLevel: {\n        type: 'string',\n        default: 'silent',\n        match: /(trace|debug|info|warn|error)/\n    },\n    /**\n     * logOutput as file path or writeable stream\n     */\n    logOutput: {\n        type: (param) => {\n            if (typeof param === 'string' || param instanceof Writable) {\n                return\n            }\n\n            throw new Error(`logOutput needs to be a string or a writeable stream`)\n        }\n    },\n    /**\n     * Timeout for any request to the Selenium server\n     */\n    connectionRetryTimeout: {\n        type: 'number',\n        default: 90000\n    },\n    /**\n     * Count of request retries to the Selenium server\n     */\n    connectionRetryCount: {\n        type: 'number',\n        default: 2\n    },\n    /**\n     * cloud user if applicable\n     */\n    user: {\n        type: 'string'\n    },\n    /**\n     * access key to user\n     */\n    key: {\n        type: 'string'\n    }\n}\n\nexport { ERROR_CODES, DEFAULTS }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25zdGFudHMuanMiXSwibmFtZXMiOlsiREVGQVVMVFMiLCJwcm90b2NvbCIsInR5cGUiLCJkZWZhdWx0IiwibWF0Y2giLCJob3N0bmFtZSIsInBvcnQiLCJwYXRoIiwicXVlcnlQYXJhbXMiLCJjYXBhYmlsaXRpZXMiLCJyZXF1aXJlZCIsImxvZ0xldmVsIiwibG9nT3V0cHV0IiwicGFyYW0iLCJXcml0YWJsZSIsIkVycm9yIiwiY29ubmVjdGlvblJldHJ5VGltZW91dCIsImNvbm5lY3Rpb25SZXRyeUNvdW50IiwidXNlciIsImtleSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7Ozs7O0FBRUEsTUFBTUEsV0FBVztBQUNiOzs7QUFHQUMsY0FBVTtBQUNOQyxjQUFNLFFBREE7QUFFTkMsaUJBQVMsTUFGSDtBQUdOQyxlQUFPO0FBSEQsS0FKRztBQVNiOzs7QUFHQUMsY0FBVTtBQUNOSCxjQUFNLFFBREE7QUFFTkMsaUJBQVM7QUFGSCxLQVpHO0FBZ0JiOzs7QUFHQUcsVUFBTTtBQUNGSixjQUFNLFFBREo7QUFFRkMsaUJBQVM7QUFGUCxLQW5CTztBQXVCYjs7O0FBR0FJLFVBQU07QUFDRkwsY0FBTSxRQURKO0FBRUZDLGlCQUFTO0FBRlAsS0ExQk87QUE4QmI7OztBQUdBSyxpQkFBYTtBQUNUTixjQUFNO0FBREcsS0FqQ0E7QUFvQ2I7OztBQUdBTyxrQkFBYztBQUNWUCxjQUFNLFFBREk7QUFFVlEsa0JBQVU7QUFGQSxLQXZDRDtBQTJDYjs7O0FBR0FDLGNBQVU7QUFDTlQsY0FBTSxRQURBO0FBRU5DLGlCQUFTLFFBRkg7QUFHTkMsZUFBTztBQUhELEtBOUNHO0FBbURiOzs7QUFHQVEsZUFBVztBQUNQVixjQUFPVyxLQUFELElBQVc7QUFDYixnQkFBSSxPQUFPQSxLQUFQLEtBQWlCLFFBQWpCLElBQTZCQSxpQkFBaUJDLGdCQUFsRCxFQUE0RDtBQUN4RDtBQUNIOztBQUVELGtCQUFNLElBQUlDLEtBQUosQ0FBVyxzREFBWCxDQUFOO0FBQ0g7QUFQTSxLQXRERTtBQStEYjs7O0FBR0FDLDRCQUF3QjtBQUNwQmQsY0FBTSxRQURjO0FBRXBCQyxpQkFBUztBQUZXLEtBbEVYO0FBc0ViOzs7QUFHQWMsMEJBQXNCO0FBQ2xCZixjQUFNLFFBRFk7QUFFbEJDLGlCQUFTO0FBRlMsS0F6RVQ7QUE2RWI7OztBQUdBZSxVQUFNO0FBQ0ZoQixjQUFNO0FBREosS0FoRk87QUFtRmI7OztBQUdBaUIsU0FBSztBQUNEakIsY0FBTTtBQURMO0FBdEZRLENBQWpCOztRQTJGU0YsUSxHQUFBQSxRIiwiZmlsZSI6ImNvbnN0YW50cy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFdyaXRhYmxlIH0gZnJvbSAnc3RyZWFtJ1xuXG5jb25zdCBERUZBVUxUUyA9IHtcbiAgICAvKipcbiAgICAgKiBwcm90b2NvbCBvZiBhdXRvbWF0aW9uIGRyaXZlclxuICAgICAqL1xuICAgIHByb3RvY29sOiB7XG4gICAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgICBkZWZhdWx0OiAnaHR0cCcsXG4gICAgICAgIG1hdGNoOiAvKGh0dHB8aHR0cHMpL1xuICAgIH0sXG4gICAgLyoqXG4gICAgICogaG9zdG5hbWUgb2YgYXV0b21hdGlvbiBkcml2ZXJcbiAgICAgKi9cbiAgICBob3N0bmFtZToge1xuICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgICAgZGVmYXVsdDogJzAuMC4wLjAnXG4gICAgfSxcbiAgICAvKipcbiAgICAgKiBwb3J0IG9mIGF1dG9tYXRpb24gZHJpdmVyXG4gICAgICovXG4gICAgcG9ydDoge1xuICAgICAgICB0eXBlOiAnbnVtYmVyJyxcbiAgICAgICAgZGVmYXVsdDogNDQ0NFxuICAgIH0sXG4gICAgLyoqXG4gICAgICogcGF0aCB0byBXZWJEcml2ZXIgZW5kcG9pbnRzXG4gICAgICovXG4gICAgcGF0aDoge1xuICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgICAgZGVmYXVsdDogJy93ZC9odWInXG4gICAgfSxcbiAgICAvKipcbiAgICAgKiBBIGtleS12YWx1ZSBzdG9yZSBvZiBxdWVyeSBwYXJhbWV0ZXJzIHRvIGJlIGFkZGVkIHRvIGV2ZXJ5IHNlbGVuaXVtIHJlcXVlc3RcbiAgICAgKi9cbiAgICBxdWVyeVBhcmFtczoge1xuICAgICAgICB0eXBlOiAnb2JqZWN0J1xuICAgIH0sXG4gICAgLyoqXG4gICAgICogY2FwYWJpbGl0eSBvZiBXZWJEcml2ZXIgc2Vzc2lvblxuICAgICAqL1xuICAgIGNhcGFiaWxpdGllczoge1xuICAgICAgICB0eXBlOiAnb2JqZWN0JyxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIExldmVsIG9mIGxvZ2dpbmcgdmVyYm9zaXR5XG4gICAgICovXG4gICAgbG9nTGV2ZWw6IHtcbiAgICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICAgIGRlZmF1bHQ6ICdzaWxlbnQnLFxuICAgICAgICBtYXRjaDogLyh0cmFjZXxkZWJ1Z3xpbmZvfHdhcm58ZXJyb3IpL1xuICAgIH0sXG4gICAgLyoqXG4gICAgICogbG9nT3V0cHV0IGFzIGZpbGUgcGF0aCBvciB3cml0ZWFibGUgc3RyZWFtXG4gICAgICovXG4gICAgbG9nT3V0cHV0OiB7XG4gICAgICAgIHR5cGU6IChwYXJhbSkgPT4ge1xuICAgICAgICAgICAgaWYgKHR5cGVvZiBwYXJhbSA9PT0gJ3N0cmluZycgfHwgcGFyYW0gaW5zdGFuY2VvZiBXcml0YWJsZSkge1xuICAgICAgICAgICAgICAgIHJldHVyblxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYGxvZ091dHB1dCBuZWVkcyB0byBiZSBhIHN0cmluZyBvciBhIHdyaXRlYWJsZSBzdHJlYW1gKVxuICAgICAgICB9XG4gICAgfSxcbiAgICAvKipcbiAgICAgKiBUaW1lb3V0IGZvciBhbnkgcmVxdWVzdCB0byB0aGUgU2VsZW5pdW0gc2VydmVyXG4gICAgICovXG4gICAgY29ubmVjdGlvblJldHJ5VGltZW91dDoge1xuICAgICAgICB0eXBlOiAnbnVtYmVyJyxcbiAgICAgICAgZGVmYXVsdDogOTAwMDBcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIENvdW50IG9mIHJlcXVlc3QgcmV0cmllcyB0byB0aGUgU2VsZW5pdW0gc2VydmVyXG4gICAgICovXG4gICAgY29ubmVjdGlvblJldHJ5Q291bnQ6IHtcbiAgICAgICAgdHlwZTogJ251bWJlcicsXG4gICAgICAgIGRlZmF1bHQ6IDJcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIGNsb3VkIHVzZXIgaWYgYXBwbGljYWJsZVxuICAgICAqL1xuICAgIHVzZXI6IHtcbiAgICAgICAgdHlwZTogJ3N0cmluZydcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIGFjY2VzcyBrZXkgdG8gdXNlclxuICAgICAqL1xuICAgIGtleToge1xuICAgICAgICB0eXBlOiAnc3RyaW5nJ1xuICAgIH1cbn1cblxuZXhwb3J0IHsgREVGQVVMVFMgfVxuIl19

@@ -19,2 +19,4 @@ 'use strict';

var _utils = require('./utils');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

@@ -118,3 +120,3 @@

const client = unit(this.sessionId);
log.info('COMMAND', `${name}(${args.join(', ')})`);
log.info('COMMAND', (0, _utils.commandCallStructure)(name, args));

@@ -127,3 +129,14 @@ /**

return func.apply(client, args);
const result = func.apply(client, args);
/**
* always transform result into promise as we don't know whether or not
* the user is running tests with wdio-sync or not
*/
Promise.resolve(result).then(res => {
log.info('RESULT', res);
this.emit('result', { name, result: res });
});
return result;
};

@@ -145,2 +158,2 @@ };

module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tb25hZC5qcyJdLCJuYW1lcyI6WyJXZWJEcml2ZXIiLCJTQ09QRV9UWVBFUyIsIkJyb3dzZXIiLCJFbGVtZW50Iiwib3B0aW9ucyIsIm1vZGlmaWVyIiwicHJvcGVydGllc09iamVjdCIsInNjb3BlVHlwZSIsInNjb3BlIiwicHJvdG90eXBlIiwiT2JqZWN0IiwiY3JlYXRlIiwiaXNXM0MiLCJ2YWx1ZSIsImxvZyIsImV2ZW50SGFuZGxlciIsIkV2ZW50RW1pdHRlciIsIkVWRU5USEFORExFUl9GVU5DVElPTlMiLCJnZXRQcm90b3R5cGVPZiIsInVuaXQiLCJzZXNzaW9uSWQiLCJjb21tYW5kV3JhcHBlciIsImNvbW1hbmRMaXN0Iiwia2V5cyIsImVudHJpZXMiLCJjb21tYW5kTmFtZSIsImNsaWVudCIsIm5hbWUiLCJjYXBhYmlsaXRpZXMiLCJhZGRDb21tYW5kIiwiZnVuYyIsImxpZnQiLCJuZXh0IiwiYXJncyIsImluZm8iLCJqb2luIiwiZGVmaW5lUHJvcGVydHkiLCJ3cml0YWJsZSIsImFwcGx5IiwiZXZlbnRDb21tYW5kIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O2tCQVF3QkEsUzs7QUFSeEI7O0FBQ0E7Ozs7Ozs7OztBQUVBLE1BQU1DLGNBQWM7QUFDaEIsZUFBVyxTQUFTQyxPQUFULEdBQW9CLENBQUUsQ0FEakI7QUFFaEIsZUFBVyxTQUFTQyxPQUFULEdBQW9CLENBQUU7QUFGakIsQ0FBcEI7O0FBS2UsU0FBU0gsU0FBVCxDQUFvQkksT0FBcEIsRUFBNkJDLFFBQTdCLEVBQXVDQyxtQkFBbUIsRUFBMUQsRUFBOEQ7QUFDekU7Ozs7O0FBS0EsVUFBTUMsWUFBWU4sWUFBWUssaUJBQWlCRSxLQUE3QixLQUF1Q1AsWUFBWSxTQUFaLENBQXpEO0FBQ0EsV0FBT0ssaUJBQWlCRSxLQUF4Qjs7QUFFQSxVQUFNQyxZQUFZQyxPQUFPQyxNQUFQLENBQWNKLFVBQVVFLFNBQXhCLEVBQW1DO0FBQ2pERyxlQUFPLEVBQUVDLE9BQU9ULFFBQVFR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dCB7IEV2ZW50RW1pdHRlciB9IGZyb20gJ2V2ZW50cydcbmltcG9ydCBsb2dnZXIgZnJvbSAnd2Rpby1sb2dnZXInXG5cbmNvbnN0IFNDT1BFX1RZUEVTID0ge1xuICAgICdicm93c2VyJzogZnVuY3Rpb24gQnJvd3NlciAoKSB7fSxcbiAgICAnZWxlbWVudCc6IGZ1bmN0aW9uIEVsZW1lbnQgKCkge31cbn1cblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gV2ViRHJpdmVyIChvcHRpb25zLCBtb2RpZmllciwgcHJvcGVydGllc09iamVjdCA9IHt9KSB7XG4gICAgLyoqXG4gICAgICogSW4gb3JkZXIgdG8gYWxsb3cgbmFtZWQgc2NvcGVzIGZvciBlbGVtZW50cyB3ZSBoYXZlIHRvIHByb3BhZ2F0ZSB0aGF0XG4gICAgICogaW5mbyB3aXRoaW4gdGhlIGBwcm9wZXJ0aWVzT2JqZWN0YCBvYmplY3QuIFRoaXMgZG9lc24ndCBoYXZlIGFueSBmdW5jdGlvbmFsXG4gICAgICogYWR2YW50YWdlcyBqdXN0IHByb3ZpZGVzIGJldHRlciBkZXNjcmlwdGlvbiBvZiBvYmplY3RzIHdoZW4gZGVidWdnaW5nIHRoZW1cbiAgICAgKi9cbiAgICBjb25zdCBzY29wZVR5cGUgPSBTQ09QRV9UWVBFU1twcm9wZXJ0aWVzT2JqZWN0LnNjb3BlXSB8fCBTQ09QRV9UWVBFU1snYnJvd3NlciddXG4gICAgZGVsZXRlIHByb3BlcnRpZXNPYmplY3Quc2NvcGVcblxuICAgIGNvbnN0IHByb3RvdHlwZSA9IE9iamVjdC5jcmVhdGUoc2NvcGVUeXBlLnByb3RvdHlwZSwge1xuICAgICAgICBpc1czQzogeyB2YWx1ZTogb3B0aW9ucy5pc1czQyB9XG4gICAgfSlcbiAgICBjb25zdCBsb2cgPSBsb2dnZXIoJ3dlYmRyaXZlcicpXG5cbiAgICBjb25zdCBldmVudEhhbmRsZXIgPSBuZXcgRXZlbnRFbWl0dGVyKClcbiAgICBjb25zdCBFVkVOVEhBTkRMRVJfRlVOQ1RJT05TID0gT2JqZWN0LmdldFByb3RvdHlwZU9mKGV2ZW50SGFuZGxlcilcblxuICAgIC8qKlxuICAgICAqIFdlYkRyaXZlciBtb25hZFxuICAgICAqL1xuICAgIGZ1bmN0aW9uIHVuaXQgKHNlc3Npb25JZCwgY29tbWFuZFdyYXBwZXIpIHtcbiAgICAgICAgcHJvcGVydGllc09iamVjdC5jb21tYW5kTGlzdCA9IHsgdmFsdWU6IE9iamVjdC5rZXlzKHByb3BlcnRpZXNPYmplY3QpIH1cbiAgICAgICAgcHJvcGVydGllc09iamVjdC5vcHRpb25zID0geyB2YWx1ZTogb3B0aW9ucyB9XG5cbiAgICAgICAgLyoqXG4gICAgICAgICAqIGFsbG93IHRvIHdyYXAgY29tbWFuZHMgaWYgbmVjZXNzYXJ5XG4gICAgICAgICAqIGUuZy4gaW4gd2Rpby1jbGkgdG8gbWFrZSB0aGVtIHN5bmNocm9ub3VzXG4gICAgICAgICAqL1xuICAgICAgICBpZiAodHlwZW9mIGNvbW1hbmRXcmFwcGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICBmb3IgKGNvbnN0IFtjb21tYW5kTmFtZSwgeyB2YWx1ZSB9XSBvZiBPYmplY3QuZW50cmllcyhwcm9wZXJ0aWVzT2JqZWN0KSkge1xuICAgICAgICAgICAgICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgICAgICAgICAgICAgY29udGludWVcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBwcm9wZXJ0aWVzT2JqZWN0W2NvbW1hbmROYW1lXS52YWx1ZSA9IGNvbW1hbmRXcmFwcGVyKGNvbW1hbmROYW1lLCB2YWx1ZSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBjbGllbnQgPSBPYmplY3QuY3JlYXRlKHByb3RvdHlwZSwgcHJvcGVydGllc09iamVjdClcbiAgICAgICAgY2xpZW50LnNlc3Npb25JZCA9IHNlc3Npb25JZFxuXG4gICAgICAgIC8qKlxuICAgICAgICAgKiByZWdpc3RlciBjYXBhYmlsaXRpZXMgb25seSB0byBicm93c2VyIHNjb3BlXG4gICAgICAgICAqL1xuICAgICAgICBpZiAoc2NvcGVUeXBlLm5hbWUgPT09ICdCcm93c2VyJykge1xuICAgICAgICAgICAgY2xpZW50LmNhcGFiaWxpdGllcyA9IG9wdGlvbnMuY2FwYWJpbGl0aWVzXG4gICAgICAgIH1cblxuICAgICAgICBpZiAodHlwZW9mIG1vZGlmaWVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICBjbGllbnQgPSBtb2RpZmllcihjbGllbnQsIG9wdGlvbnMpXG4gICAgICAgIH1cblxuICAgICAgICBjbGllbnQuYWRkQ29tbWFuZCA9IGZ1bmN0aW9uIChuYW1lLCBmdW5jKSB7XG4gICAgICAgICAgICB1bml0LmxpZnQobmFtZSwgY29tbWFuZFdyYXBwZXIobmFtZSwgZnVuYykpXG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY2xpZW50XG4gICAgfVxuXG4gICAgdW5pdC5saWZ0ID0gZnVuY3Rpb24gKG5hbWUsIGZ1bmMpIHtcbiAgICAgICAgcHJvdG90eXBlW25hbWVdID0gZnVuY3Rpb24gbmV4dCAoLi4uYXJncykge1xuICAgICAgICAgICAgY29uc3QgY2xpZW50ID0gdW5pdCh0aGlzLnNlc3Npb25JZClcbiAgICAgICAgICAgIGxvZy5pbmZvKCdDT01NQU5EJywgYCR7bmFtZX0oJHthcmdzLmpvaW4oJywgJyl9KWApXG5cbiAgICAgICAgICAgIC8qKlxuICAgICAgICAgICAgICogc2V0IG5hbWUgb2YgZnVuY3Rpb24gZm9yIGJldHRlciBlcnJvciBzdGFja1xuICAgICAgICAgICAgICovXG4gICAgICAgICAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkoZnVuYywgJ25hbWUnLCB7IHdyaXRhYmxlOiB0cnVlIH0pXG4gICAgICAgICAgICBmdW5jLm5hbWUgPSBuYW1lXG5cbiAgICAgICAgICAgIHJldHVybiBmdW5jLmFwcGx5KGNsaWVudCwgYXJncylcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIHJlZ2lzdGVyIGV2ZW50IGVtaXR0ZXJcbiAgICAgKi9cbiAgICBmb3IgKGxldCBldmVudENvbW1hbmQgaW4gRVZFTlRIQU5ETEVSX0ZVTkNUSU9OUykge1xuICAgICAgICBwcm90b3R5cGVbZXZlbnRDb21tYW5kXSA9IGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAgICAgICBldmVudEhhbmRsZXJbZXZlbnRDb21tYW5kXSguLi5hcmdzKVxuICAgICAgICAgICAgcmV0dXJuIHRoaXNcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB1bml0XG59XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/monad.js"],"names":["WebDriver","SCOPE_TYPES","Browser","Element","options","modifier","propertiesObject","scopeType","scope","prototype","Object","create","isW3C","value","log","eventHandler","EventEmitter","EVENTHANDLER_FUNCTIONS","getPrototypeOf","unit","sessionId","commandWrapper","commandList","keys","entries","commandName","client","name","capabilities","addCommand","func","lift","next","args","info","defineProperty","writable","result","apply","Promise","resolve","then","res","emit","eventCommand"],"mappings":"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","file":"monad.js","sourcesContent":["import { EventEmitter } from 'events'\nimport logger from 'wdio-logger'\n\nimport { commandCallStructure } from './utils'\n\nconst SCOPE_TYPES = {\n    'browser': function Browser () {},\n    'element': function Element () {}\n}\n\nexport default function WebDriver (options, modifier, propertiesObject = {}) {\n    /**\n     * In order to allow named scopes for elements we have to propagate that\n     * info within the `propertiesObject` object. This doesn't have any functional\n     * advantages just provides better description of objects when debugging them\n     */\n    const scopeType = SCOPE_TYPES[propertiesObject.scope] || SCOPE_TYPES['browser']\n    delete propertiesObject.scope\n\n    const prototype = Object.create(scopeType.prototype, {\n        isW3C: { value: options.isW3C }\n    })\n    const log = logger('webdriver')\n\n    const eventHandler = new EventEmitter()\n    const EVENTHANDLER_FUNCTIONS = Object.getPrototypeOf(eventHandler)\n\n    /**\n     * WebDriver monad\n     */\n    function unit (sessionId, commandWrapper) {\n        propertiesObject.commandList = { value: Object.keys(propertiesObject) }\n        propertiesObject.options = { value: options }\n\n        /**\n         * allow to wrap commands if necessary\n         * e.g. in wdio-cli to make them synchronous\n         */\n        if (typeof commandWrapper === 'function') {\n            for (const [commandName, { value }] of Object.entries(propertiesObject)) {\n                if (typeof value !== 'function') {\n                    continue\n                }\n\n                propertiesObject[commandName].value = commandWrapper(commandName, value)\n            }\n        }\n\n        let client = Object.create(prototype, propertiesObject)\n        client.sessionId = sessionId\n\n        /**\n         * register capabilities only to browser scope\n         */\n        if (scopeType.name === 'Browser') {\n            client.capabilities = options.capabilities\n        }\n\n        if (typeof modifier === 'function') {\n            client = modifier(client, options)\n        }\n\n        client.addCommand = function (name, func) {\n            unit.lift(name, commandWrapper(name, func))\n        }\n\n        return client\n    }\n\n    unit.lift = function (name, func) {\n        prototype[name] = function next (...args) {\n            const client = unit(this.sessionId)\n            log.info('COMMAND', commandCallStructure(name, args))\n\n            /**\n             * set name of function for better error stack\n             */\n            Object.defineProperty(func, 'name', { writable: true })\n            func.name = name\n\n            const result = func.apply(client, args)\n\n            /**\n             * always transform result into promise as we don't know whether or not\n             * the user is running tests with wdio-sync or not\n             */\n            Promise.resolve(result).then((res) => {\n                log.info('RESULT', res)\n                this.emit('result', { name, result: res })\n            })\n\n            return result\n        }\n    }\n\n    /**\n     * register event emitter\n     */\n    for (let eventCommand in EVENTHANDLER_FUNCTIONS) {\n        prototype[eventCommand] = function (...args) {\n            eventHandler[eventCommand](...args)\n            return this\n        }\n    }\n\n    return unit\n}\n"]}

@@ -14,2 +14,3 @@ 'use strict';

exports.getPrototype = getPrototype;
exports.commandCallStructure = commandCallStructure;

@@ -230,2 +231,26 @@ var _wdioLogger = require('wdio-logger');

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/utils.js"],"names":["isSuccessfulResponse","isValidParameter","getPrototype","log","body","statusCode","value","debug","status","message","startsWith","hasErrorResponse","error","stackTrace","stacktrace","arg","expectedType","shouldBeArray","slice","Array","isArray","argEntity","match","isW3C","prototype","ProtocolCommands","Object","assign","WebDriverProtocol","JsonWProtocol","MJsonWProtocol","AppiumProtocol","entries","endpoint","methods","method","commandData","command"],"mappings":"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","file":"utils.js","sourcesContent":["import logger from 'wdio-logger'\n\nimport command from './command'\nimport WebDriverProtocol from '../protocol/webdriver.json'\nimport MJsonWProtocol from '../protocol/mjsonwp.json'\nimport JsonWProtocol from '../protocol/jsonwp.json'\nimport AppiumProtocol from '../protocol/appium.json'\n\nconst log = logger('webdriver')\n\n/**\n * check if WebDriver requests was successful\n * @param  {Object}  body  body payload of response\n * @return {Boolean}       true if request was successful\n */\nexport function isSuccessfulResponse ({ body, statusCode } = {}) {\n    /**\n     * response contains a body\n     */\n    if (!body || typeof body.value === 'undefined') {\n        log.debug('request failed due to missing body')\n        return false\n    }\n\n    /**\n     * ignore failing element request to enable lazy loading capability\n     */\n    if (body.status && body.status === 7 && body.value.message && body.value.message.startsWith('no such element')) {\n        return true\n    }\n\n    /**\n     * if it has a status property, it should be 0\n     * (just here to stay backwards compatible to the jsonwire protocol)\n     */\n    if (body.status && body.status !== 0) {\n        log.debug(`request failed due to status ${body.status}`)\n        return false\n    }\n\n    const hasErrorResponse = body.value && (body.value.error || body.value.stackTrace || body.value.stacktrace)\n\n    /**\n     * check status code\n     */\n    if (statusCode === 200 && !hasErrorResponse) {\n        return true\n    }\n\n    /**\n     * if an element was not found we don't flag it as failed request because\n     * we lazy load it\n     */\n    if (statusCode === 404 && body.value && body.value.error === 'no such element') {\n        return true\n    }\n\n    /**\n     * that has no error property (Appium only)\n     */\n    if (hasErrorResponse) {\n        log.debug('request failed due to response error:', body.value.error)\n        return false\n    }\n\n    return true\n}\n\n/**\n * checks if command argument is valid according to specificiation\n *\n * @param  {*}       arg           command argument\n * @param  {Object}  expectedType  parameter type (e.g. `number`, `string[]` or `(number|string)`)\n * @return {Boolean}               true if argument is valid\n */\nexport function isValidParameter (arg, expectedType) {\n    let shouldBeArray = false\n\n    if (expectedType.slice(-2) === '[]') {\n        expectedType = expectedType.slice(0, -2)\n        shouldBeArray = true\n    }\n\n    /**\n     * check type of each individual array element\n     */\n    if (shouldBeArray) {\n        if (!Array.isArray(arg)) {\n            return false\n        }\n    } else {\n        /**\n         * transform to array to have a unified check\n         */\n        arg = [arg]\n    }\n\n    for (const argEntity of arg) {\n        if (!(typeof argEntity).match(expectedType)) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * creates the base prototype for the webdriver monad\n */\nexport function getPrototype (isW3C) {\n    const prototype = {}\n    const ProtocolCommands = Object.assign(\n        isW3C ? WebDriverProtocol : JsonWProtocol,\n        MJsonWProtocol,\n        AppiumProtocol\n    )\n\n    for (const [endpoint, methods] of Object.entries(ProtocolCommands)) {\n        for (const [method, commandData] of Object.entries(methods)) {\n            prototype[commandData.command] = { value: command(method, endpoint, commandData) }\n        }\n    }\n\n    return prototype\n}\n"]}
/**
* get command call structure
* (for logging purposes)
*/
function commandCallStructure(commandName, args) {
const callArgs = args.map(arg => {
if (typeof arg === 'string') {
arg = `"${arg}"`;
} else if (typeof arg === 'function') {
arg = '<fn>';
} else if (arg === null) {
arg = 'null';
} else if (typeof arg === 'object') {
arg = '<object>';
} else if (typeof arg === 'undefined') {
arg = typeof arg;
}
return arg;
}).join(', ');
return `${commandName}(${callArgs})`;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/utils.js"],"names":["isSuccessfulResponse","isValidParameter","getPrototype","commandCallStructure","log","body","statusCode","value","debug","status","message","startsWith","hasErrorResponse","error","stackTrace","stacktrace","arg","expectedType","shouldBeArray","slice","Array","isArray","argEntity","match","isW3C","prototype","ProtocolCommands","Object","assign","WebDriverProtocol","JsonWProtocol","MJsonWProtocol","AppiumProtocol","entries","endpoint","methods","method","commandData","command","commandName","args","callArgs","map","join"],"mappings":"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","file":"utils.js","sourcesContent":["import logger from 'wdio-logger'\n\nimport command from './command'\nimport WebDriverProtocol from '../protocol/webdriver.json'\nimport MJsonWProtocol from '../protocol/mjsonwp.json'\nimport JsonWProtocol from '../protocol/jsonwp.json'\nimport AppiumProtocol from '../protocol/appium.json'\n\nconst log = logger('webdriver')\n\n/**\n * check if WebDriver requests was successful\n * @param  {Object}  body  body payload of response\n * @return {Boolean}       true if request was successful\n */\nexport function isSuccessfulResponse ({ body, statusCode } = {}) {\n    /**\n     * response contains a body\n     */\n    if (!body || typeof body.value === 'undefined') {\n        log.debug('request failed due to missing body')\n        return false\n    }\n\n    /**\n     * ignore failing element request to enable lazy loading capability\n     */\n    if (body.status && body.status === 7 && body.value.message && body.value.message.startsWith('no such element')) {\n        return true\n    }\n\n    /**\n     * if it has a status property, it should be 0\n     * (just here to stay backwards compatible to the jsonwire protocol)\n     */\n    if (body.status && body.status !== 0) {\n        log.debug(`request failed due to status ${body.status}`)\n        return false\n    }\n\n    const hasErrorResponse = body.value && (body.value.error || body.value.stackTrace || body.value.stacktrace)\n\n    /**\n     * check status code\n     */\n    if (statusCode === 200 && !hasErrorResponse) {\n        return true\n    }\n\n    /**\n     * if an element was not found we don't flag it as failed request because\n     * we lazy load it\n     */\n    if (statusCode === 404 && body.value && body.value.error === 'no such element') {\n        return true\n    }\n\n    /**\n     * that has no error property (Appium only)\n     */\n    if (hasErrorResponse) {\n        log.debug('request failed due to response error:', body.value.error)\n        return false\n    }\n\n    return true\n}\n\n/**\n * checks if command argument is valid according to specificiation\n *\n * @param  {*}       arg           command argument\n * @param  {Object}  expectedType  parameter type (e.g. `number`, `string[]` or `(number|string)`)\n * @return {Boolean}               true if argument is valid\n */\nexport function isValidParameter (arg, expectedType) {\n    let shouldBeArray = false\n\n    if (expectedType.slice(-2) === '[]') {\n        expectedType = expectedType.slice(0, -2)\n        shouldBeArray = true\n    }\n\n    /**\n     * check type of each individual array element\n     */\n    if (shouldBeArray) {\n        if (!Array.isArray(arg)) {\n            return false\n        }\n    } else {\n        /**\n         * transform to array to have a unified check\n         */\n        arg = [arg]\n    }\n\n    for (const argEntity of arg) {\n        if (!(typeof argEntity).match(expectedType)) {\n            return false\n        }\n    }\n\n    return true\n}\n\n/**\n * creates the base prototype for the webdriver monad\n */\nexport function getPrototype (isW3C) {\n    const prototype = {}\n    const ProtocolCommands = Object.assign(\n        isW3C ? WebDriverProtocol : JsonWProtocol,\n        MJsonWProtocol,\n        AppiumProtocol\n    )\n\n    for (const [endpoint, methods] of Object.entries(ProtocolCommands)) {\n        for (const [method, commandData] of Object.entries(methods)) {\n            prototype[commandData.command] = { value: command(method, endpoint, commandData) }\n        }\n    }\n\n    return prototype\n}\n\n/**\n * get command call structure\n * (for logging purposes)\n */\nexport function commandCallStructure (commandName, args) {\n    const callArgs = args.map((arg) => {\n        if (typeof arg === 'string') {\n            arg = `\"${arg}\"`\n        } else if (typeof arg === 'function') {\n            arg = '<fn>'\n        } else if (arg === null) {\n            arg = 'null'\n        } else if (typeof arg === 'object') {\n            arg = '<object>'\n        } else if (typeof arg === 'undefined') {\n            arg = typeof arg\n        }\n\n        return arg\n    }).join(', ')\n\n    return `${commandName}(${callArgs})`\n}\n"]}
{
"name": "webdriver",
"version": "5.0.0-beta.1",
"version": "5.0.0-beta.2",
"description": "A Node.js bindings implementation for the W3C WebDriver and Mobile JSONWire Protocol",

@@ -34,5 +34,5 @@ "author": "Christian Bromann <christian@saucelabs.com>",

"request": "^2.83.0",
"wdio-config": "^5.0.0-beta.1",
"wdio-logger": "^5.0.0-beta.1"
"wdio-config": "^5.0.0-beta.2",
"wdio-logger": "^5.0.0-beta.2"
}
}

@@ -910,3 +910,8 @@ {

"ref": "https://github.com/SeleniumHQ/selenium/wiki/JsonWireProtocol#sessionsessionidtouchclick",
"parameters": []
"parameters": [{
"name": "element",
"type": "string",
"description": "ID of the element to single tap on.",
"required": true
}]
}

@@ -913,0 +918,0 @@ },

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc