appium
Version:
Automation for Apps.
333 lines (253 loc) • 20.4 kB
JavaScript
require('source-map-support').install();
;
var _slicedToArray = require('babel-runtime/helpers/sliced-to-array')['default'];
var _regeneratorRuntime = require('babel-runtime/regenerator')['default'];
var _getIterator = require('babel-runtime/core-js/get-iterator')['default'];
var _Object$assign = require('babel-runtime/core-js/object/assign')['default'];
var _interopRequireDefault = require('babel-runtime/helpers/interop-require-default')['default'];
Object.defineProperty(exports, '__esModule', {
value: true
});
var _logsink = require('./logsink');
var _logger = require('./logger');
var _logger2 = _interopRequireDefault(_logger);
// logger needs to remain first of imports
var _lodash = require('lodash');
var _lodash2 = _interopRequireDefault(_lodash);
var _appiumBaseDriver = require('appium-base-driver');
var _asyncbox = require('asyncbox');
var _parser = require('./parser');
var _parser2 = _interopRequireDefault(_parser);
var _config = require('./config');
var _appium = require('./appium');
var _appium2 = _interopRequireDefault(_appium);
var _gridRegister = require('./grid-register');
var _gridRegister2 = _interopRequireDefault(_gridRegister);
var _utils = require('./utils');
function preflightChecks(parser, args) {
var throwInsteadOfExit = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2];
return _regeneratorRuntime.async(function preflightChecks$(context$1$0) {
while (1) switch (context$1$0.prev = context$1$0.next) {
case 0:
context$1$0.prev = 0;
(0, _config.checkNodeOk)();
if (args.asyncTrace) {
require('longjohn').async_trace_limit = -1;
}
if (!args.showConfig) {
context$1$0.next = 7;
break;
}
context$1$0.next = 6;
return _regeneratorRuntime.awrap((0, _config.showConfig)());
case 6:
process.exit(0);
case 7:
(0, _config.warnNodeDeprecations)();
(0, _config.validateServerArgs)(parser, args);
if (!args.tmpDir) {
context$1$0.next = 12;
break;
}
context$1$0.next = 12;
return _regeneratorRuntime.awrap((0, _config.validateTmpDir)(args.tmpDir));
case 12:
context$1$0.next = 20;
break;
case 14:
context$1$0.prev = 14;
context$1$0.t0 = context$1$0['catch'](0);
_logger2['default'].error(context$1$0.t0.message.red);
if (!throwInsteadOfExit) {
context$1$0.next = 19;
break;
}
throw context$1$0.t0;
case 19:
process.exit(1);
case 20:
case 'end':
return context$1$0.stop();
}
}, null, this, [[0, 14]]);
}
function logDeprecationWarning(deprecatedArgs) {
_logger2['default'].warn('Deprecated server args:');
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = _getIterator(_lodash2['default'].toPairs(deprecatedArgs)), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var _step$value = _slicedToArray(_step.value, 2);
var arg = _step$value[0];
var realArg = _step$value[1];
_logger2['default'].warn(' ' + arg.red + ' => ' + realArg);
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator['return']) {
_iterator['return']();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
}
function logNonDefaultArgsWarning(args) {
_logger2['default'].info('Non-default server args:');
(0, _utils.inspectObject)(args);
}
function logDefaultCapabilitiesWarning(caps) {
_logger2['default'].info('Default capabilities, which will be added to each request ' + 'unless overridden by desired capabilities:');
(0, _utils.inspectObject)(caps);
}
function logStartupInfo(parser, args) {
var welcome, appiumRev, showArgs, deprecatedArgs;
return _regeneratorRuntime.async(function logStartupInfo$(context$1$0) {
while (1) switch (context$1$0.prev = context$1$0.next) {
case 0:
welcome = 'Welcome to Appium v' + _config.APPIUM_VER;
context$1$0.next = 3;
return _regeneratorRuntime.awrap((0, _config.getGitRev)());
case 3:
appiumRev = context$1$0.sent;
if (appiumRev) {
welcome += ' (REV ' + appiumRev + ')';
}
_logger2['default'].info(welcome);
showArgs = (0, _config.getNonDefaultArgs)(parser, args);
if (_lodash2['default'].size(showArgs)) {
logNonDefaultArgsWarning(showArgs);
}
deprecatedArgs = (0, _config.getDeprecatedArgs)(parser, args);
if (_lodash2['default'].size(deprecatedArgs)) {
logDeprecationWarning(deprecatedArgs);
}
if (!_lodash2['default'].isEmpty(args.defaultCapabilities)) {
logDefaultCapabilitiesWarning(args.defaultCapabilities);
}
// TODO: bring back loglevel reporting below once logger is flushed out
//logger.info('Console LogLevel: ' + logger.transports.console.level);
//if (logger.transports.file) {
//logger.info('File LogLevel: ' + logger.transports.file.level);
//}
case 11:
case 'end':
return context$1$0.stop();
}
}, null, this);
}
function logServerPort(address, port) {
var logMessage = 'Appium REST http interface listener started on ' + (address + ':' + port);
_logger2['default'].info(logMessage);
}
function initHeapdump(args) {
if (args.heapdumpEnabled) {
require('heapdump');
}
}
function main() {
var args = arguments.length <= 0 || arguments[0] === undefined ? null : arguments[0];
var parser, throwInsteadOfExit, router, server;
return _regeneratorRuntime.async(function main$(context$1$0) {
while (1) switch (context$1$0.prev = context$1$0.next) {
case 0:
parser = (0, _parser2['default'])();
throwInsteadOfExit = false;
if (args) {
// a containing package passed in their own args, let's fill them out
// with defaults
args = _Object$assign({}, (0, _parser.getDefaultArgs)(), args);
// if we have a containing package instead of running as a CLI process,
// that package might not appreciate us calling 'process.exit' willy-
// nilly, so give it the option to have us throw instead of exit
if (args.throwInsteadOfExit) {
throwInsteadOfExit = true;
// but remove it since it's not a real server arg per se
delete args.throwInsteadOfExit;
}
} else {
// otherwise parse from CLI
args = parser.parseArgs();
}
initHeapdump(args);
context$1$0.next = 6;
return _regeneratorRuntime.awrap((0, _logsink.init)(args));
case 6:
context$1$0.next = 8;
return _regeneratorRuntime.awrap(preflightChecks(parser, args, throwInsteadOfExit));
case 8:
context$1$0.next = 10;
return _regeneratorRuntime.awrap(logStartupInfo(parser, args));
case 10:
router = (0, _appium2['default'])(args);
context$1$0.next = 13;
return _regeneratorRuntime.awrap((0, _appiumBaseDriver.server)(router, args.port, args.address));
case 13:
server = context$1$0.sent;
context$1$0.prev = 14;
if (!(args.nodeconfig !== null)) {
context$1$0.next = 18;
break;
}
context$1$0.next = 18;
return _regeneratorRuntime.awrap((0, _gridRegister2['default'])(args.nodeconfig, args.address, args.port));
case 18:
context$1$0.next = 25;
break;
case 20:
context$1$0.prev = 20;
context$1$0.t0 = context$1$0['catch'](14);
context$1$0.next = 24;
return _regeneratorRuntime.awrap(server.close());
case 24:
throw context$1$0.t0;
case 25:
process.once('SIGINT', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
_logger2['default'].info('Received SIGINT - shutting down');
context$2$0.next = 3;
return _regeneratorRuntime.awrap(server.close());
case 3:
case 'end':
return context$2$0.stop();
}
}, null, this);
});
process.once('SIGTERM', function callee$1$0() {
return _regeneratorRuntime.async(function callee$1$0$(context$2$0) {
while (1) switch (context$2$0.prev = context$2$0.next) {
case 0:
_logger2['default'].info('Received SIGTERM - shutting down');
context$2$0.next = 3;
return _regeneratorRuntime.awrap(server.close());
case 3:
case 'end':
return context$2$0.stop();
}
}, null, this);
});
logServerPort(args.address, args.port);
return context$1$0.abrupt('return', server);
case 29:
case 'end':
return context$1$0.stop();
}
}, null, this, [[14, 20]]);
}
if (require.main === module) {
(0, _asyncbox.asyncify)(main);
}
exports.main = main;
// TODO prelaunch if args.launch is set
// TODO: startAlertSocket(server, appiumServer);
// configure as node on grid, if necessary
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/main.js"],"names":[],"mappings":"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","file":"lib/main.js","sourcesContent":["\n// transpile:main\n\nimport { init as logsinkInit } from './logsink';\nimport logger from './logger'; // logger needs to remain first of imports\nimport _ from 'lodash';\nimport { server as baseServer } from 'appium-base-driver';\nimport { asyncify } from 'asyncbox';\nimport { default as getParser, getDefaultArgs } from './parser';\nimport { showConfig, checkNodeOk, validateServerArgs,\n         warnNodeDeprecations, validateTmpDir, getNonDefaultArgs,\n         getDeprecatedArgs, getGitRev, APPIUM_VER } from './config';\nimport getAppiumRouter from './appium';\nimport registerNode from './grid-register';\nimport { inspectObject } from './utils';\n\n\nasync function preflightChecks (parser, args, throwInsteadOfExit = false) {\n  try {\n    checkNodeOk();\n    if (args.asyncTrace) {\n      require('longjohn').async_trace_limit = -1;\n    }\n    if (args.showConfig) {\n      await showConfig();\n      process.exit(0);\n    }\n    warnNodeDeprecations();\n    validateServerArgs(parser, args);\n    if (args.tmpDir) {\n      await validateTmpDir(args.tmpDir);\n    }\n  } catch (err) {\n    logger.error(err.message.red);\n    if (throwInsteadOfExit) {\n      throw err;\n    }\n\n    process.exit(1);\n  }\n}\n\nfunction logDeprecationWarning (deprecatedArgs) {\n  logger.warn('Deprecated server args:');\n  for (let [arg, realArg] of _.toPairs(deprecatedArgs)) {\n    logger.warn(`  ${arg.red} => ${realArg}`);\n  }\n}\n\nfunction logNonDefaultArgsWarning (args) {\n  logger.info('Non-default server args:');\n  inspectObject(args);\n}\n\nfunction logDefaultCapabilitiesWarning (caps) {\n  logger.info('Default capabilities, which will be added to each request ' +\n              'unless overridden by desired capabilities:');\n  inspectObject(caps);\n}\n\nasync function logStartupInfo (parser, args) {\n  let welcome = `Welcome to Appium v${APPIUM_VER}`;\n  let appiumRev = await getGitRev();\n  if (appiumRev) {\n    welcome += ` (REV ${appiumRev})`;\n  }\n  logger.info(welcome);\n\n  let showArgs = getNonDefaultArgs(parser, args);\n  if (_.size(showArgs)) {\n    logNonDefaultArgsWarning(showArgs);\n  }\n  let deprecatedArgs = getDeprecatedArgs(parser, args);\n  if (_.size(deprecatedArgs)) {\n    logDeprecationWarning(deprecatedArgs);\n  }\n  if (!_.isEmpty(args.defaultCapabilities)) {\n    logDefaultCapabilitiesWarning(args.defaultCapabilities);\n  }\n  // TODO: bring back loglevel reporting below once logger is flushed out\n  //logger.info('Console LogLevel: ' + logger.transports.console.level);\n  //if (logger.transports.file) {\n    //logger.info('File LogLevel: ' + logger.transports.file.level);\n  //}\n}\n\nfunction logServerPort (address, port) {\n  let logMessage = `Appium REST http interface listener started on ` +\n                   `${address}:${port}`;\n  logger.info(logMessage);\n}\n\nfunction initHeapdump (args) {\n  if (args.heapdumpEnabled) {\n    require('heapdump');\n  }\n}\n\nasync function main (args = null) {\n  let parser = getParser();\n  let throwInsteadOfExit = false;\n  if (args) {\n    // a containing package passed in their own args, let's fill them out\n    // with defaults\n    args = Object.assign({}, getDefaultArgs(), args);\n\n    // if we have a containing package instead of running as a CLI process,\n    // that package might not appreciate us calling 'process.exit' willy-\n    // nilly, so give it the option to have us throw instead of exit\n    if (args.throwInsteadOfExit) {\n      throwInsteadOfExit = true;\n      // but remove it since it's not a real server arg per se\n      delete args.throwInsteadOfExit;\n    }\n  } else {\n    // otherwise parse from CLI\n    args = parser.parseArgs();\n  }\n  initHeapdump(args);\n  await logsinkInit(args);\n  await preflightChecks(parser, args, throwInsteadOfExit);\n  await logStartupInfo(parser, args);\n  let router = getAppiumRouter(args);\n  let server = await baseServer(router, args.port, args.address);\n  try {\n    // TODO prelaunch if args.launch is set\n    // TODO: startAlertSocket(server, appiumServer);\n\n    // configure as node on grid, if necessary\n    if (args.nodeconfig !== null) {\n      await registerNode(args.nodeconfig, args.address, args.port);\n    }\n  } catch (err) {\n    await server.close();\n    throw err;\n  }\n\n  process.once('SIGINT', async function () {\n    logger.info(`Received SIGINT - shutting down`);\n    await server.close();\n  });\n\n  process.once('SIGTERM', async function () {\n    logger.info(`Received SIGTERM - shutting down`);\n    await server.close();\n  });\n\n  logServerPort(args.address, args.port);\n\n  return server;\n}\n\nif (require.main === module) {\n  asyncify(main);\n}\n\nexport { main };\n"],"sourceRoot":"../.."}