UNPKG

@testim/testim-cli

Version:

Command line interface for running Testing on you CI

118 lines (92 loc) 12.3 kB
'use strict'; var _get = require('babel-runtime/helpers/get')['default']; var _inherits = require('babel-runtime/helpers/inherits')['default']; var _createClass = require('babel-runtime/helpers/create-class')['default']; var _classCallCheck = require('babel-runtime/helpers/class-call-check')['default']; Object.defineProperty(exports, '__esModule', { value: true }); var _helpersConstants = require('../helpers/constants'); var ErrorHandler = (function (_Error) { _inherits(ErrorHandler, _Error); function ErrorHandler(type, msg) { _classCallCheck(this, ErrorHandler); _get(Object.getPrototypeOf(ErrorHandler.prototype), 'constructor', this).call(this); Error.captureStackTrace(this, this.constructor); if (arguments.length === 2) { this.message = msg; this.type = type; } else if (arguments.length === 1 && typeof type === 'number') { // if ID is not known error throw UnknownError if (!_helpersConstants.ERROR_CODES[type]) { type = 13; } this.type = _helpersConstants.ERROR_CODES[type].id; this.message = _helpersConstants.ERROR_CODES[type].message; } else if (arguments.length === 1) { this.type = 'WebdriverIOError'; this.message = type; } if (typeof this.message === 'object') { var seleniumStack = this.message; if (seleniumStack.message && seleniumStack.type && seleniumStack.status) { if (seleniumStack.orgStatusMessage && seleniumStack.orgStatusMessage.match(/"errorMessage":"NoSuchElement"/)) { seleniumStack.type = 'NoSuchElement'; seleniumStack.status = 7; seleniumStack.message = _helpersConstants.ERROR_CODES['7'].message; } this.message = seleniumStack.message + ' (' + seleniumStack.type + ':' + seleniumStack.status + ')'; } if (seleniumStack.orgStatusMessage) { var reqPos = seleniumStack.orgStatusMessage.indexOf(',"request"'); var problem = ''; if (reqPos > 0) { problem = JSON.parse(seleniumStack.orgStatusMessage.slice(0, reqPos) + '}').errorMessage; } else { problem = seleniumStack.orgStatusMessage; } if (problem.indexOf('No enum constant org.openqa.selenium.Platform') > -1) { problem = 'The Selenium backend you\'ve chosen doesn\'t support the desired platform (' + problem.slice(46) + ')'; } // truncate errorMessage if (problem.indexOf('(Session info:') > -1) { problem = problem.slice(0, problem.indexOf('(Session info:')).replace(/\n/g, '').trim(); } // make assumption based on experience on certain error messages if (problem.indexOf('unknown error: path is not absolute') !== -1) { problem = 'You are trying to set a value to an input field with type="file", use the `uploadFile` command instead (Selenium error: ' + problem + ')'; } this.message = problem; } } } /** * make stack loggable * @return {Object} error log */ _createClass(ErrorHandler, [{ key: 'toJSON', value: function toJSON() { return { name: this.type, message: this.message }; } }]); return ErrorHandler; })(Error); var CommandError = function CommandError(msg) { return new ErrorHandler('CommandError', msg); }; var ProtocolError = function ProtocolError(msg) { return new ErrorHandler('ProtocolError', msg); }; var RuntimeError = function RuntimeError(msg) { return new ErrorHandler('RuntimeError', msg); }; exports.ErrorHandler = ErrorHandler; exports.CommandError = CommandError; exports.ProtocolError = ProtocolError; exports.RuntimeError = RuntimeError; exports['default'] = ErrorHandler; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../lib/utils/ErrorHandler.js"],"names":[],"mappings":"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","file":"ErrorHandler.js","sourcesContent":["import { ERROR_CODES } from '../helpers/constants'\n\nclass ErrorHandler extends Error {\n    constructor (type, msg) {\n        super()\n        Error.captureStackTrace(this, this.constructor)\n\n        if (arguments.length === 2) {\n            this.message = msg\n            this.type = type\n        } else if (arguments.length === 1 && typeof type === 'number') {\n            // if ID is not known error throw UnknownError\n            if (!ERROR_CODES[type]) {\n                type = 13\n            }\n\n            this.type = ERROR_CODES[type].id\n            this.message = ERROR_CODES[type].message\n        } else if (arguments.length === 1) {\n            this.type = 'WebdriverIOError'\n            this.message = type\n        }\n\n        if (typeof this.message === 'object') {\n            let seleniumStack = this.message\n\n            if (seleniumStack.message && seleniumStack.type && seleniumStack.status) {\n                if (seleniumStack.orgStatusMessage && seleniumStack.orgStatusMessage.match(/\"errorMessage\":\"NoSuchElement\"/)) {\n                    seleniumStack.type = 'NoSuchElement'\n                    seleniumStack.status = 7\n                    seleniumStack.message = ERROR_CODES['7'].message\n                }\n\n                this.message = seleniumStack.message + ' (' + seleniumStack.type + ':' + seleniumStack.status + ')'\n            }\n\n            if (seleniumStack.orgStatusMessage) {\n                let reqPos = seleniumStack.orgStatusMessage.indexOf(',\"request\"')\n                let problem = ''\n\n                if (reqPos > 0) {\n                    problem = JSON.parse(seleniumStack.orgStatusMessage.slice(0, reqPos) + '}').errorMessage\n                } else {\n                    problem = seleniumStack.orgStatusMessage\n                }\n\n                if (problem.indexOf('No enum constant org.openqa.selenium.Platform') > -1) {\n                    problem = 'The Selenium backend you\\'ve chosen doesn\\'t support the desired platform (' + problem.slice(46) + ')'\n                }\n\n                // truncate errorMessage\n                if (problem.indexOf('(Session info:') > -1) {\n                    problem = problem.slice(0, problem.indexOf('(Session info:')).replace(/\\n/g, '').trim()\n                }\n\n                // make assumption based on experience on certain error messages\n                if (problem.indexOf('unknown error: path is not absolute') !== -1) {\n                    problem = 'You are trying to set a value to an input field with type=\"file\", use the `uploadFile` command instead (Selenium error: ' + problem + ')'\n                }\n\n                this.message = problem\n            }\n        }\n    }\n\n    /**\n     * make stack loggable\n     * @return {Object} error log\n     */\n    toJSON () {\n        return {\n            name: this.type,\n            message: this.message\n        }\n    }\n}\n\nlet CommandError = function (msg) {\n    return new ErrorHandler('CommandError', msg)\n}\nlet ProtocolError = function (msg) {\n    return new ErrorHandler('ProtocolError', msg)\n}\nlet RuntimeError = function (msg) {\n    return new ErrorHandler('RuntimeError', msg)\n}\n\nexport {\n    ErrorHandler,\n    CommandError,\n    ProtocolError,\n    RuntimeError\n}\nexport default ErrorHandler\n"]}