appium
Version:
Automation for Apps.
322 lines (263 loc) • 25 kB
JavaScript
;
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":"../.."}