UNPKG

appium

Version:
333 lines (253 loc) 20.4 kB
#!/usr/bin/env node require('source-map-support').install(); 'use strict'; 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":"../.."}