UNPKG

appium-doctor

Version:

Test environment for fitness to run Appium

157 lines (120 loc) 12.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.authorizeIos = void 0; exports.configureBinaryLog = configureBinaryLog; exports.getNpmPackageInfo = getNpmPackageInfo; exports.inquirer = void 0; exports.nok = nok; exports.nokOptional = nokOptional; exports.ok = ok; exports.okOptional = okOptional; exports.pkgRoot = void 0; exports.resolveExecutablePath = resolveExecutablePath; require("source-map-support/register"); var _bluebird = _interopRequireDefault(require("bluebird")); var _path = _interopRequireDefault(require("path")); var _inquirer2 = _interopRequireDefault(require("inquirer")); var _logger = _interopRequireDefault(require("../lib/logger")); var _authorizeIos = _interopRequireDefault(require("authorize-ios")); var _appiumSupport = require("appium-support"); var _teen_process = require("teen_process"); var _lodash = require("lodash"); const authorizeIos = _authorizeIos.default; exports.authorizeIos = authorizeIos; const pkgRoot = process.env.NO_PRECOMPILE ? _path.default.resolve(__dirname, '..') : _path.default.resolve(__dirname, '..', '..'); exports.pkgRoot = pkgRoot; function ok(message) { return { ok: true, optional: false, message }; } function nok(message) { return { ok: false, optional: false, message }; } function okOptional(message) { return { ok: true, optional: true, message }; } function nokOptional(message) { return { ok: false, optional: true, message }; } const inquirer = { prompt: _bluebird.default.promisify(function (question, cb) { _inquirer2.default.prompt(question, function (resp) { cb(null, resp); }); }) }; exports.inquirer = inquirer; function configureBinaryLog(opts) { let actualLog = _logger.default.unwrap().log; _logger.default.unwrap().log = function (level, prefix, msg) { let l = this.levels[level]; if (l < this.levels[this.level]) return; actualLog(level, prefix, msg); if ((0, _lodash.isFunction)(opts.onLogMessage)) { opts.onLogMessage(level, prefix, msg); } }; _logger.default.level = opts.debug ? 'debug' : 'info'; } async function resolveExecutablePath(cmd) { let executablePath; try { executablePath = await _appiumSupport.fs.which(cmd); if (executablePath && (await _appiumSupport.fs.exists(executablePath))) { return executablePath; } } catch (err) { if (/not found/gi.test(err.message)) { _logger.default.debug(err); } else { _logger.default.warn(err); } } _logger.default.debug(`No executable path of '${cmd}'.`); if (executablePath) { _logger.default.debug(`Does '${executablePath}' exist?`); } return null; } async function getNpmPackageInfo(packageName) { const npmPath = await resolveExecutablePath(`npm${_appiumSupport.system.isWindows() ? `.cmd` : ''}`); if (!npmPath) { return nokOptional(`'npm' binary not found in PATH: ${process.env.PATH}`); } let pJson = {}; try { const { stdout } = await (0, _teen_process.exec)(npmPath, ['list', '-g', '-l', '-j', packageName]); pJson = JSON.parse(stdout); } catch (err) { _logger.default.debug(err); return null; } if (pJson.dependencies && pJson.dependencies[packageName]) { return { version: pJson.dependencies[packageName].version, path: pJson.path }; } return null; }require('source-map-support').install(); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/utils.js","names":["authorizeIos","authorize","pkgRoot","process","env","NO_PRECOMPILE","path","resolve","__dirname","ok","message","optional","nok","okOptional","nokOptional","inquirer","prompt","B","promisify","question","cb","_inquirer","resp","configureBinaryLog","opts","actualLog","log","unwrap","level","prefix","msg","l","levels","isFunction","onLogMessage","debug","resolveExecutablePath","cmd","executablePath","fs","which","exists","err","test","warn","getNpmPackageInfo","packageName","npmPath","system","isWindows","PATH","pJson","stdout","exec","JSON","parse","dependencies","version"],"sourceRoot":"../..","sources":["lib/utils.js"],"sourcesContent":["import B from 'bluebird';\nimport path from 'path';\nimport _inquirer from 'inquirer';\nimport log from '../lib/logger';\nimport authorize from 'authorize-ios';\nimport { fs, system } from 'appium-support';\nimport { exec } from 'teen_process';\nimport { isFunction } from 'lodash';\n\n// rename to make more sense\nconst authorizeIos = authorize;\n\nconst pkgRoot = process.env.NO_PRECOMPILE ?\n  path.resolve(__dirname, '..') : path.resolve(__dirname, '..', '..');\n\nfunction ok (message) {\n  return {ok: true, optional: false, message};\n}\nfunction nok (message) {\n  return {ok: false, optional: false, message};\n}\nfunction okOptional (message) {\n  return {ok: true, optional: true, message};\n}\nfunction nokOptional (message) {\n  return {ok: false, optional: true, message};\n}\n\nconst inquirer = {\n  prompt: B.promisify(function (question, cb) { // eslint-disable-line promise/prefer-await-to-callbacks\n    _inquirer.prompt(question, function (resp) { cb(null, resp); }); // eslint-disable-line promise/prefer-await-to-callbacks\n  })\n};\n\nfunction configureBinaryLog (opts) {\n  let actualLog = log.unwrap().log;\n  log.unwrap().log = function (level, prefix, msg) {\n    let l = this.levels[level];\n    if (l < this.levels[this.level]) return; // eslint-disable-line curly\n    actualLog(level, prefix, msg);\n\n    if (isFunction(opts.onLogMessage)) {\n      opts.onLogMessage(level, prefix, msg);\n    }\n  };\n  log.level = opts.debug ? 'debug' : 'info';\n}\n\n/**\n * Return an executable path of cmd\n *\n * @param {string} cmd Standard output by command\n * @return {?string} The full path of cmd. `null` if the cmd is not found.\n */\nasync function resolveExecutablePath (cmd) {\n  let executablePath;\n  try {\n    executablePath = await fs.which(cmd);\n    if (executablePath && await fs.exists(executablePath)) {\n      return executablePath;\n    }\n  } catch (err) {\n    if ((/not found/gi).test(err.message)) {\n      log.debug(err);\n    } else {\n      log.warn(err);\n    }\n  }\n  log.debug(`No executable path of '${cmd}'.`);\n  if (executablePath) {\n    log.debug(`Does '${executablePath}' exist?`);\n  }\n  return null;\n}\n\n/**\n * @typedef {Object} NpmPackageInfo\n * @property {string} version - version\n * @property {string} path - A path to npm root\n */\n/**\n * Returns the path and version of given package name\n * @param {string} packageName A package name to get path and version data\n * @return {?NpmPackageInfo}\n */\nasync function getNpmPackageInfo (packageName) {\n  const npmPath = await resolveExecutablePath(`npm${system.isWindows() ? `.cmd` : ''}`);\n  if (!npmPath) {\n    return nokOptional(`'npm' binary not found in PATH: ${process.env.PATH}`);\n  }\n\n  let pJson = {};\n  try {\n    const {stdout} = await exec(npmPath, ['list', '-g', '-l', '-j', packageName]);\n    pJson = JSON.parse(stdout);\n  } catch (err) {\n    log.debug(err);\n    return null;\n  }\n\n  if (pJson.dependencies && pJson.dependencies[packageName]) {\n    return {version: pJson.dependencies[packageName].version, path: pJson.path};\n  }\n\n  return null;\n}\n\nexport { pkgRoot, ok, nok, okOptional, nokOptional, inquirer, configureBinaryLog,\n  authorizeIos, resolveExecutablePath, getNpmPackageInfo};\n"],"mappings":"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"}