UNPKG

appium

Version:
322 lines (263 loc) 25 kB
'use strict'; var _Object$keys = require('babel-runtime/core-js/object/keys')['default']; var _regeneratorRuntime = require('babel-runtime/regenerator')['default']; var _getIterator = require('babel-runtime/core-js/get-iterator')['default']; var _interopRequireDefault = require('babel-runtime/helpers/interop-require-default')['default']; Object.defineProperty(exports, '__esModule', { value: true }); var _npmlog = require('npmlog'); var _npmlog2 = _interopRequireDefault(_npmlog); var _winston = require('winston'); var _winston2 = _interopRequireDefault(_winston); var _appiumSupport = require('appium-support'); var _dateformat = require('dateformat'); var _dateformat2 = _interopRequireDefault(_dateformat); var _lodash = require('lodash'); var _lodash2 = _interopRequireDefault(_lodash); // set up distributed logging before everything else _appiumSupport.logger.patchLogger(_npmlog2['default']); global._global_npmlog = _npmlog2['default']; // npmlog is used only for emitting, we use winston for output _npmlog2['default'].level = "silent"; var levels = { debug: 4, info: 3, warn: 2, error: 1 }; var colors = { info: 'cyan', debug: 'grey', warn: 'yellow', error: 'red' }; var npmToWinstonLevels = { silly: 'debug', verbose: 'debug', debug: 'debug', info: 'info', http: 'info', warn: 'warn', error: 'error' }; var log = null; var timeZone = null; function timestamp() { var date = new Date(); if (!timeZone) { date = new Date(date.valueOf() + date.getTimezoneOffset() * 60000); } return (0, _dateformat2['default'])(date, "yyyy-mm-dd HH:MM:ss:l"); } // Strip the color marking within messages. // We need to patch the transports, because the stripColor functionality in // Winston is wrongly implemented at the logger level, and we want to avoid // having to create 2 loggers. function applyStripColorPatch(transport) { var _log = transport.log.bind(transport); transport.log = function (level, msg, meta, callback) { // eslint-disable-line promise/prefer-await-to-callbacks var code = /\u001b\[(\d+(;\d+)*)?m/g; msg = ('' + msg).replace(code, ''); _log(level, msg, meta, callback); }; } function _createConsoleTransport(args, logLvl) { var transport = new _winston2['default'].transports.Console({ name: "console", timestamp: args.logTimestamp ? timestamp : undefined, colorize: !args.logNoColors, handleExceptions: true, exitOnError: false, json: false, level: logLvl, formatter: function formatter(options) { var meta = options.meta && _Object$keys(options.meta).length ? '\n\t' + JSON.stringify(options.meta) : ''; var timestampPrefix = ''; if (options.timestamp) { timestampPrefix = options.timestamp() + ' - '; } return '' + timestampPrefix + (options.message || '') + meta; } }); if (args.logNoColors) { applyStripColorPatch(transport); } return transport; } function _createFileTransport(args, logLvl) { var transport = new _winston2['default'].transports.File({ name: "file", timestamp: timestamp, filename: args.log, maxFiles: 1, handleExceptions: true, exitOnError: false, json: false, level: logLvl }); applyStripColorPatch(transport); return transport; } function _createHttpTransport(args, logLvl) { var host = null, port = null; if (args.webhook.match(':')) { var hostAndPort = args.webhook.split(':'); host = hostAndPort[0]; port = parseInt(hostAndPort[1], 10); } var transport = new _winston2['default'].transports.Http({ name: "http", host: host || '127.0.0.1', port: port || 9003, path: '/', handleExceptions: true, exitOnError: false, json: false, level: logLvl }); applyStripColorPatch(transport); return transport; } function _createTransports(args) { var transports, consoleLogLevel, fileLogLevel, lvlPair; return _regeneratorRuntime.async(function _createTransports$(context$1$0) { while (1) switch (context$1$0.prev = context$1$0.next) { case 0: transports = []; consoleLogLevel = null; fileLogLevel = null; if (args.loglevel && args.loglevel.match(":")) { lvlPair = args.loglevel.split(':'); consoleLogLevel = lvlPair[0] || consoleLogLevel; fileLogLevel = lvlPair[1] || fileLogLevel; } else { consoleLogLevel = fileLogLevel = args.loglevel; } transports.push(_createConsoleTransport(args, consoleLogLevel)); if (!args.log) { context$1$0.next = 18; break; } context$1$0.prev = 6; context$1$0.next = 9; return _regeneratorRuntime.awrap(_appiumSupport.fs.exists(args.log)); case 9: if (!context$1$0.sent) { context$1$0.next = 12; break; } context$1$0.next = 12; return _regeneratorRuntime.awrap(_appiumSupport.fs.unlink(args.log)); case 12: transports.push(_createFileTransport(args, fileLogLevel)); context$1$0.next = 18; break; case 15: context$1$0.prev = 15; context$1$0.t0 = context$1$0['catch'](6); // eslint-disable-next-line no-console console.log('Tried to attach logging to file ' + args.log + ' but an error ' + ('occurred: ' + context$1$0.t0.message)); case 18: if (args.webhook) { try { transports.push(_createHttpTransport(args, fileLogLevel)); } catch (e) { // eslint-disable-next-line no-console console.log('Tried to attach logging to Http at ' + args.webhook + ' but ' + ('an error occurred: ' + e.message)); } } return context$1$0.abrupt('return', transports); case 20: case 'end': return context$1$0.stop(); } }, null, this, [[6, 15]]); } function init(args) { return _regeneratorRuntime.async(function init$(context$1$0) { while (1) switch (context$1$0.prev = context$1$0.next) { case 0: // set de facto param passed to timestamp function timeZone = args.localTimezone; // by not adding colors here and not setting 'colorize' in transports // when logNoColors === true, console output is fully stripped of color. if (!args.logNoColors) { _winston2['default'].addColors(colors); } // clean up in case we have initted before since npmlog is a global // object clear(); context$1$0.t0 = _winston2['default'].Logger; context$1$0.next = 6; return _regeneratorRuntime.awrap(_createTransports(args)); case 6: context$1$0.t1 = context$1$0.sent; context$1$0.t2 = { transports: context$1$0.t1 }; log = new context$1$0.t0(context$1$0.t2); // Capture logs emitted via npmlog and pass them through winston _npmlog2['default'].on('log', function (logObj) { var winstonLevel = npmToWinstonLevels[logObj.level] || 'info'; var msg = logObj.message; if (logObj.prefix) { var prefix = '[' + logObj.prefix + ']'; msg = prefix.magenta + ' ' + msg; } log[winstonLevel](msg); if (args.logHandler && typeof args.logHandler === "function") { args.logHandler(logObj.level, msg); } }); log.setLevels(levels); // 8/19/14 this is a hack to force Winston to print debug messages to stdout rather than stderr. // TODO: remove this if winston provides an API for directing streams. if (levels[log.transports.console.level] === levels.debug) { log.debug = function (msg) { log.info('[debug] ' + msg); }; } case 12: case 'end': return context$1$0.stop(); } }, null, this); } function clear() { if (log) { var _iteratorNormalCompletion = true; var _didIteratorError = false; var _iteratorError = undefined; try { for (var _iterator = _getIterator(_lodash2['default'].keys(log.transports)), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var transport = _step.value; log.remove(transport); } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator['return']) { _iterator['return'](); } } finally { if (_didIteratorError) { throw _iteratorError; } } } } _npmlog2['default'].removeAllListeners('log'); } exports.init = init; exports.clear = clear; exports['default'] = init; // --log-level arg can optionally provide diff logging levels for console and file, separated by a colon // if we don't delete the log file, winston will always append and it will grow infinitely large; // winston allows for limiting log file size, but as of 9.2.14 there's a serious bug when using // maxFiles and maxSize together. https://github.com/flatiron/winston/issues/397 //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/logsink.js"],"names":[],"mappings":"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","file":"lib/logsink.js","sourcesContent":["import npmlog from 'npmlog';\nimport winston  from 'winston';\nimport { fs, logger } from 'appium-support';\nimport dateformat from 'dateformat';\nimport _ from 'lodash';\n\n// set up distributed logging before everything else\nlogger.patchLogger(npmlog);\nglobal._global_npmlog = npmlog;\n\n// npmlog is used only for emitting, we use winston for output\nnpmlog.level = \"silent\";\nconst levels = {\n  debug: 4,\n  info: 3,\n  warn: 2,\n  error: 1,\n};\n\nconst colors = {\n  info: 'cyan',\n  debug: 'grey',\n  warn: 'yellow',\n  error: 'red',\n};\n\nconst npmToWinstonLevels = {\n  silly: 'debug',\n  verbose: 'debug',\n  debug: 'debug',\n  info: 'info',\n  http: 'info',\n  warn: 'warn',\n  error: 'error',\n};\n\nlet log = null;\nlet timeZone = null;\n\nfunction timestamp () {\n  let date = new Date();\n  if (!timeZone) {\n    date = new Date(date.valueOf() + date.getTimezoneOffset() * 60000);\n  }\n  return dateformat(date, \"yyyy-mm-dd HH:MM:ss:l\");\n}\n\n// Strip the color marking within messages.\n// We need to patch the transports, because the stripColor functionality in\n// Winston is wrongly implemented at the logger level, and we want to avoid\n// having to create 2 loggers.\nfunction applyStripColorPatch (transport) {\n  let _log = transport.log.bind(transport);\n  transport.log = function (level, msg, meta, callback) { // eslint-disable-line promise/prefer-await-to-callbacks\n    let code = /\\u001b\\[(\\d+(;\\d+)*)?m/g;\n    msg = ('' + msg).replace(code, '');\n    _log(level, msg, meta, callback);\n  };\n}\n\nfunction _createConsoleTransport (args, logLvl) {\n  let transport = new (winston.transports.Console)({\n    name: \"console\",\n    timestamp: args.logTimestamp ? timestamp : undefined,\n    colorize: !args.logNoColors,\n    handleExceptions: true,\n    exitOnError: false,\n    json: false,\n    level: logLvl,\n    formatter (options) {\n      let meta = options.meta && Object.keys(options.meta).length ? `\\n\\t${JSON.stringify(options.meta)}` : '';\n      let timestampPrefix = '';\n      if (options.timestamp) {\n        timestampPrefix = `${options.timestamp()} - `;\n      }\n      return `${timestampPrefix}${options.message || ''}${meta}`;\n    }\n  });\n  if (args.logNoColors) {\n    applyStripColorPatch(transport);\n  }\n\n  return transport;\n}\n\nfunction _createFileTransport (args, logLvl) {\n  let transport = new (winston.transports.File)({\n    name: \"file\",\n    timestamp,\n    filename: args.log,\n    maxFiles: 1,\n    handleExceptions: true,\n    exitOnError: false,\n    json: false,\n    level: logLvl,\n  });\n  applyStripColorPatch(transport);\n  return transport;\n}\n\nfunction _createHttpTransport (args, logLvl) {\n  let host = null,\n      port = null;\n\n  if (args.webhook.match(':')) {\n    let hostAndPort = args.webhook.split(':');\n    host = hostAndPort[0];\n    port = parseInt(hostAndPort[1], 10);\n  }\n\n  let transport = new (winston.transports.Http)({\n    name: \"http\",\n    host: host || '127.0.0.1',\n    port: port || 9003,\n    path: '/',\n    handleExceptions: true,\n    exitOnError: false,\n    json: false,\n    level: logLvl,\n  });\n  applyStripColorPatch(transport);\n  return transport;\n}\n\nasync function _createTransports (args) {\n  let transports = [];\n  let consoleLogLevel = null;\n  let fileLogLevel = null;\n\n  if (args.loglevel && args.loglevel.match(\":\")) {\n    // --log-level arg can optionally provide diff logging levels for console and file, separated by a colon\n    let lvlPair = args.loglevel.split(':');\n    consoleLogLevel =  lvlPair[0] || consoleLogLevel;\n    fileLogLevel = lvlPair[1] || fileLogLevel;\n  } else {\n    consoleLogLevel = fileLogLevel = args.loglevel;\n  }\n\n  transports.push(_createConsoleTransport(args, consoleLogLevel));\n\n  if (args.log) {\n    try {\n      // if we don't delete the log file, winston will always append and it will grow infinitely large;\n      // winston allows for limiting log file size, but as of 9.2.14 there's a serious bug when using\n      // maxFiles and maxSize together. https://github.com/flatiron/winston/issues/397\n      if (await fs.exists(args.log)) {\n        await fs.unlink(args.log);\n      }\n\n      transports.push(_createFileTransport(args, fileLogLevel));\n    } catch (e) {\n      // eslint-disable-next-line no-console\n      console.log(`Tried to attach logging to file ${args.log} but an error ` +\n                  `occurred: ${e.message}`);\n    }\n  }\n\n  if (args.webhook) {\n    try {\n      transports.push(_createHttpTransport(args, fileLogLevel));\n    } catch (e) {\n      // eslint-disable-next-line no-console\n      console.log(`Tried to attach logging to Http at ${args.webhook} but ` +\n                  `an error occurred: ${e.message}`);\n    }\n  }\n\n  return transports;\n}\n\nasync function init (args) {\n  // set de facto param passed to timestamp function\n  timeZone = args.localTimezone;\n\n  // by not adding colors here and not setting 'colorize' in transports\n  // when logNoColors === true, console output is fully stripped of color.\n  if (!args.logNoColors) {\n    winston.addColors(colors);\n  }\n\n  // clean up in case we have initted before since npmlog is a global\n  // object\n  clear();\n\n  log = new (winston.Logger)({\n    transports: await _createTransports(args)\n  });\n\n  // Capture logs emitted via npmlog and pass them through winston\n  npmlog.on('log', (logObj) => {\n    let winstonLevel = npmToWinstonLevels[logObj.level] || 'info';\n    let msg = logObj.message;\n    if (logObj.prefix) {\n      let prefix = `[${logObj.prefix}]`;\n      msg = `${prefix.magenta} ${msg}`;\n    }\n    log[winstonLevel](msg);\n    if (args.logHandler && typeof args.logHandler === \"function\") {\n      args.logHandler(logObj.level, msg);\n    }\n\n  });\n\n\n  log.setLevels(levels);\n\n  // 8/19/14 this is a hack to force Winston to print debug messages to stdout rather than stderr.\n  // TODO: remove this if winston provides an API for directing streams.\n  if (levels[log.transports.console.level] === levels.debug) {\n    log.debug = function (msg) {\n      log.info('[debug] ' + msg);\n    };\n  }\n}\n\nfunction clear () {\n  if (log) {\n    for (let transport of _.keys(log.transports)) {\n      log.remove(transport);\n    }\n  }\n  npmlog.removeAllListeners('log');\n}\n\n\nexport { init, clear };\nexport default init;\n"],"sourceRoot":"../.."}