@testim/testim-cli
Version:
Command line interface for running Testing on you CI
118 lines (92 loc) • 12.3 kB
JavaScript
;
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":";;;;;;;;;;;;;;gCAA4B,sBAAsB;;IAE5C,YAAY;cAAZ,YAAY;;AACF,aADV,YAAY,CACD,IAAI,EAAE,GAAG,EAAE;8BADtB,YAAY;;AAEV,mCAFF,YAAY,6CAEH;AACP,aAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;;AAE/C,YAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;AACxB,gBAAI,CAAC,OAAO,GAAG,GAAG,CAAA;AAClB,gBAAI,CAAC,IAAI,GAAG,IAAI,CAAA;SACnB,MAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;;AAE3D,gBAAI,CAAC,8BAAY,IAAI,CAAC,EAAE;AACpB,oBAAI,GAAG,EAAE,CAAA;aACZ;;AAED,gBAAI,CAAC,IAAI,GAAG,8BAAY,IAAI,CAAC,CAAC,EAAE,CAAA;AAChC,gBAAI,CAAC,OAAO,GAAG,8BAAY,IAAI,CAAC,CAAC,OAAO,CAAA;SAC3C,MAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;AAC/B,gBAAI,CAAC,IAAI,GAAG,kBAAkB,CAAA;AAC9B,gBAAI,CAAC,OAAO,GAAG,IAAI,CAAA;SACtB;;AAED,YAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE;AAClC,gBAAI,aAAa,GAAG,IAAI,CAAC,OAAO,CAAA;;AAEhC,gBAAI,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,IAAI,IAAI,aAAa,CAAC,MAAM,EAAE;AACrE,oBAAI,aAAa,CAAC,gBAAgB,IAAI,aAAa,CAAC,gBAAgB,CAAC,KAAK,CAAC,gCAAgC,CAAC,EAAE;AAC1G,iCAAa,CAAC,IAAI,GAAG,eAAe,CAAA;AACpC,iCAAa,CAAC,MAAM,GAAG,CAAC,CAAA;AACxB,iCAAa,CAAC,OAAO,GAAG,8BAAY,GAAG,CAAC,CAAC,OAAO,CAAA;iBACnD;;AAED,oBAAI,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO,GAAG,IAAI,GAAG,aAAa,CAAC,IAAI,GAAG,GAAG,GAAG,aAAa,CAAC,MAAM,GAAG,GAAG,CAAA;aACtG;;AAED,gBAAI,aAAa,CAAC,gBAAgB,EAAE;AAChC,oBAAI,MAAM,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,YAAY,CAAC,CAAA;AACjE,oBAAI,OAAO,GAAG,EAAE,CAAA;;AAEhB,oBAAI,MAAM,GAAG,CAAC,EAAE;AACZ,2BAAO,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC,YAAY,CAAA;iBAC3F,MAAM;AACH,2BAAO,GAAG,aAAa,CAAC,gBAAgB,CAAA;iBAC3C;;AAED,oBAAI,OAAO,CAAC,OAAO,CAAC,+CAA+C,CAAC,GAAG,CAAC,CAAC,EAAE;AACvE,2BAAO,GAAG,6EAA6E,GAAG,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,GAAG,CAAA;iBACpH;;;AAGD,oBAAI,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,EAAE;AACxC,2BAAO,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;iBAC1F;;;AAGD,oBAAI,OAAO,CAAC,OAAO,CAAC,qCAAqC,CAAC,KAAK,CAAC,CAAC,EAAE;AAC/D,2BAAO,GAAG,0HAA0H,GAAG,OAAO,GAAG,GAAG,CAAA;iBACvJ;;AAED,oBAAI,CAAC,OAAO,GAAG,OAAO,CAAA;aACzB;SACJ;KACJ;;;;;;;iBA7DC,YAAY;;eAmEP,kBAAG;AACN,mBAAO;AACH,oBAAI,EAAE,IAAI,CAAC,IAAI;AACf,uBAAO,EAAE,IAAI,CAAC,OAAO;aACxB,CAAA;SACJ;;;WAxEC,YAAY;GAAS,KAAK;;AA2EhC,IAAI,YAAY,GAAG,SAAf,YAAY,CAAa,GAAG,EAAE;AAC9B,WAAO,IAAI,YAAY,CAAC,cAAc,EAAE,GAAG,CAAC,CAAA;CAC/C,CAAA;AACD,IAAI,aAAa,GAAG,SAAhB,aAAa,CAAa,GAAG,EAAE;AAC/B,WAAO,IAAI,YAAY,CAAC,eAAe,EAAE,GAAG,CAAC,CAAA;CAChD,CAAA;AACD,IAAI,YAAY,GAAG,SAAf,YAAY,CAAa,GAAG,EAAE;AAC9B,WAAO,IAAI,YAAY,CAAC,cAAc,EAAE,GAAG,CAAC,CAAA;CAC/C,CAAA;;QAGG,YAAY,GAAZ,YAAY;QACZ,YAAY,GAAZ,YAAY;QACZ,aAAa,GAAb,aAAa;QACb,YAAY,GAAZ,YAAY;qBAED,YAAY","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"]}