UNPKG

appium-doctor

Version:

Test environment for fitness to run Appium

279 lines (190 loc) 23.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.FixSkippedError = exports.DoctorCheck = exports.Doctor = void 0; require("source-map-support/register"); require("@colors/colors"); var _lodash = _interopRequireDefault(require("lodash")); var _logger = _interopRequireDefault(require("./logger")); var _package = require("../../package.json"); class FixSkippedError extends Error {} exports.FixSkippedError = FixSkippedError; class DoctorCheck { constructor(opts = {}) { this.autofix = !!opts.autofix; } diagnose() { throw new Error('Not Implemented!'); } fix() { throw new Error('Not Implemented!'); } } exports.DoctorCheck = DoctorCheck; class Doctor { constructor() { this.checks = []; this.checkOptionals = []; this.toFix = []; this.toFixOptionals = []; } register(checks) { checks = Array.isArray(checks) ? checks : [checks]; this.checks = this.checks.concat(checks); } async diagnose() { _logger.default.info(`### Diagnostic for ${'necessary'.green} dependencies starting ###`); this.toFix = []; for (const check of this.checks) { const res = await check.diagnose(); if (res.optional) { this.checkOptionals.push(check); continue; } await this.diagnosticResultMessage(res, this.toFix, check); } _logger.default.info(`### Diagnostic for necessary dependencies completed, ${await this.fixMessage(this.toFix.length)}. ###`); _logger.default.info(''); _logger.default.info(`### Diagnostic for ${'optional'.yellow} dependencies starting ###`); this.toFixOptionals = []; for (const checkOptional of this.checkOptionals) { await this.diagnosticResultMessage(await checkOptional.diagnose(), this.toFixOptionals, checkOptional); } _logger.default.info(`### Diagnostic for optional dependencies completed, ${await this.fixMessage(this.toFixOptionals.length, true)}. ###`); _logger.default.info(''); } async reportManualFixes(fix, fixOptioal) { const manualFixes = _lodash.default.filter(fix, f => { var _f$check; return !(f !== null && f !== void 0 && (_f$check = f.check) !== null && _f$check !== void 0 && _f$check.autofix); }); const manualFixesOptional = _lodash.default.filter(fixOptioal, f => { var _f$check2; return !(f !== null && f !== void 0 && (_f$check2 = f.check) !== null && _f$check2 !== void 0 && _f$check2.autofix); }); if (manualFixes.length > 0) { _logger.default.info('### Manual Fixes Needed ###'); _logger.default.info('The configuration cannot be automatically fixed, please do the following first:'); const fixMessages = []; for (const f of manualFixes) { fixMessages.push(await f.check.fix()); } for (const m of _lodash.default.uniq(fixMessages)) { _logger.default.warn(` \u279C ${m}`); } _logger.default.info(''); } if (manualFixesOptional.length > 0) { _logger.default.info('### Optional Manual Fixes ###'); _logger.default.info('The configuration can install optionally. Please do the following manually:'); const fixMessages = []; for (const f of manualFixesOptional) { fixMessages.push(await f.check.fix()); } for (const m of _lodash.default.uniq(fixMessages)) { _logger.default.warn(` \u279C ${m}`); } _logger.default.info(''); } if (manualFixes.length > 0 || manualFixesOptional.length > 0) { _logger.default.info('###'); _logger.default.info(''); _logger.default.info('Bye! Run appium-doctor again when all manual fixes have been applied!'); _logger.default.info(''); return true; } return false; } async runAutoFix(f) { _logger.default.info(`### Fixing: ${f.error} ###`); try { await f.check.fix(); } catch (err) { if (err instanceof FixSkippedError) { _logger.default.info(`### Skipped fix ###`); return; } else { _logger.default.warn(`${err}`.replace(/\n$/g, '')); _logger.default.info(`### Fix did not succeed ###`); return; } } _logger.default.info('Checking if this was fixed:'); let res = await f.check.diagnose(); if (res.ok) { f.fixed = true; _logger.default.info(` ${'\u2714'.green} ${res.message}`); _logger.default.info(`### Fix was successfully applied ###`); } else { _logger.default.info(` ${'\u2716'.red} ${res.message}`); _logger.default.info(`### Fix was applied but issue remains ###`); } } async runAutoFixes() { let autoFixes = _lodash.default.filter(this.toFix, f => { var _f$check3; return f === null || f === void 0 ? void 0 : (_f$check3 = f.check) === null || _f$check3 === void 0 ? void 0 : _f$check3.autofix; }); for (let f of autoFixes) { await this.runAutoFix(f); _logger.default.info(''); } if (_lodash.default.find(autoFixes, f => !f.fixed)) { _logger.default.info('Bye! A few issues remain, fix manually and/or rerun appium-doctor!'); } else { _logger.default.info('Bye! All issues have been fixed!'); } _logger.default.info(''); } async run() { _logger.default.warn('[Deprecated] Please use appium-doctor installed with "npm install @appium/doctor --location=global"'); _logger.default.info(`Appium Doctor v.${_package.version}`); await this.diagnose(); if (await this.reportSuccess(this.toFix.length, this.toFixOptionals.length)) { return; } if (await this.reportManualFixes(this.toFix, this.toFixOptionals)) { return; } await this.runAutoFixes(); } async diagnosticResultMessage(result, toFixList, check) { if (result.ok) { _logger.default.info(` ${'\u2714'.green} ${result.message}`); } else { const errorMessage = result.optional ? ` ${'\u2716'.yellow} ${result.message}` : ` ${'\u2716'.red} ${result.message}`; _logger.default.warn(errorMessage); toFixList.push({ error: errorMessage, check }); } } async fixMessage(length, optional = false) { let message; switch (length) { case 0: message = 'no fix'; break; case 1: message = 'one fix'; break; default: message = `${length} fixes`; } return `${message} ${optional ? 'possible' : 'needed'}`; } async reportSuccess(length, lengthOptional) { if (length === 0 && lengthOptional === 0) { _logger.default.info('Everything looks good, bye!'); _logger.default.info(''); return true; } else { return false; } } } exports.Doctor = Doctor;require('source-map-support').install(); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/doctor.js","names":["FixSkippedError","Error","DoctorCheck","constructor","opts","autofix","diagnose","fix","Doctor","checks","checkOptionals","toFix","toFixOptionals","register","Array","isArray","concat","log","info","green","check","res","optional","push","diagnosticResultMessage","fixMessage","length","yellow","checkOptional","reportManualFixes","fixOptioal","manualFixes","_","filter","f","manualFixesOptional","fixMessages","m","uniq","warn","runAutoFix","error","err","replace","ok","fixed","message","red","runAutoFixes","autoFixes","find","run","version","reportSuccess","result","toFixList","errorMessage","lengthOptional"],"sourceRoot":"../..","sources":["lib/doctor.js"],"sourcesContent":["import '@colors/colors';\nimport _ from 'lodash';\nimport log from './logger';\nimport { version } from '../../package.json'; // eslint-disable-line import/no-unresolved\n\n\nclass FixSkippedError extends Error {\n}\n\nclass DoctorCheck {\n  constructor (opts = {}) {\n    this.autofix = !!opts.autofix;\n  }\n\n  diagnose () { throw new Error('Not Implemented!'); }\n\n  fix () {\n    // return string for manual fixes.\n    throw new Error('Not Implemented!');\n  }\n}\n\nclass Doctor {\n  constructor () {\n    this.checks = [];\n    this.checkOptionals = [];\n    this.toFix = [];\n    this.toFixOptionals = [];\n  }\n\n  register (checks) {\n    checks = Array.isArray(checks) ? checks : [checks];\n    this.checks = this.checks.concat(checks);\n  }\n\n  async diagnose () {\n    log.info(`### Diagnostic for ${'necessary'.green} dependencies starting ###`);\n    this.toFix = [];\n    for (const check of this.checks) {\n      const res = await check.diagnose();\n      if (res.optional) {\n        this.checkOptionals.push(check);\n        continue;\n      }\n      await this.diagnosticResultMessage(res, this.toFix, check);\n    }\n    log.info(`### Diagnostic for necessary dependencies completed, ${await this.fixMessage(this.toFix.length)}. ###`);\n    log.info('');\n\n    log.info(`### Diagnostic for ${'optional'.yellow} dependencies starting ###`);\n    this.toFixOptionals = [];\n    for (const checkOptional of this.checkOptionals) {\n      await this.diagnosticResultMessage(await checkOptional.diagnose(), this.toFixOptionals, checkOptional);\n    }\n    log.info(`### Diagnostic for optional dependencies completed, ${await this.fixMessage(this.toFixOptionals.length, true)}. ###`);\n    log.info('');\n  }\n\n  async reportManualFixes (fix, fixOptioal) {\n    const manualFixes = _.filter(fix, (f) => !f?.check?.autofix);\n    const manualFixesOptional = _.filter(fixOptioal, (f) => !f?.check?.autofix);\n\n    if (manualFixes.length > 0) {\n      log.info('### Manual Fixes Needed ###');\n      log.info('The configuration cannot be automatically fixed, please do the following first:');\n      // for manual fixes, the fix method always return a string\n      const fixMessages = [];\n      for (const f of manualFixes) {\n        fixMessages.push(await f.check.fix());\n      }\n      for (const m of _.uniq(fixMessages)) {\n        log.warn(` \\u279C ${m}`);\n      }\n      log.info('');\n    }\n    if (manualFixesOptional.length > 0) {\n      log.info('### Optional Manual Fixes ###');\n      log.info('The configuration can install optionally. Please do the following manually:');\n      // for manual fixes, the fix method always return a string\n      const fixMessages = [];\n      for (const f of manualFixesOptional) {\n        fixMessages.push(await f.check.fix());\n      }\n      for (const m of _.uniq(fixMessages)) {\n        log.warn(` \\u279C ${m}`);\n      }\n      log.info('');\n    }\n\n    if (manualFixes.length > 0 || manualFixesOptional.length > 0) {\n      log.info('###');\n      log.info('');\n      log.info('Bye! Run appium-doctor again when all manual fixes have been applied!');\n      log.info('');\n      return true;\n    }\n    return false;\n  }\n\n  async runAutoFix (f) {\n    log.info(`### Fixing: ${f.error} ###`);\n    try {\n      await f.check.fix();\n    } catch (err) {\n      if (err instanceof FixSkippedError) {\n        log.info(`### Skipped fix ###`);\n        return;\n      } else {\n        log.warn(`${err}`.replace(/\\n$/g, ''));\n        log.info(`### Fix did not succeed ###`);\n        return;\n      }\n    }\n    log.info('Checking if this was fixed:');\n    let res = await f.check.diagnose();\n    if (res.ok) {\n      f.fixed = true;\n      log.info(` ${'\\u2714'.green} ${res.message}`);\n      log.info(`### Fix was successfully applied ###`);\n    } else {\n      log.info(` ${'\\u2716'.red} ${res.message}`);\n      log.info(`### Fix was applied but issue remains ###`);\n    }\n  }\n\n  async runAutoFixes () {\n    let autoFixes = _.filter(this.toFix, (f) => f?.check?.autofix);\n    for (let f of autoFixes) {\n      await this.runAutoFix(f);\n      log.info('');\n    }\n    if (_.find(autoFixes, (f) => !f.fixed)) {\n      // a few issues remain.\n      log.info('Bye! A few issues remain, fix manually and/or rerun appium-doctor!');\n    } else {\n      // nothing left to fix.\n      log.info('Bye! All issues have been fixed!');\n    }\n    log.info('');\n  }\n\n  async run () {\n    log.warn('[Deprecated] Please use appium-doctor installed with \"npm install @appium/doctor --location=global\"');\n    log.info(`Appium Doctor v.${version}`);\n    await this.diagnose();\n    if (await this.reportSuccess(this.toFix.length, this.toFixOptionals.length)) {\n      return;\n    }\n    if (await this.reportManualFixes(this.toFix, this.toFixOptionals)) {\n      return;\n    }\n    await this.runAutoFixes();\n  }\n\n  //// generating messages\n  async diagnosticResultMessage (result, toFixList, check) { // eslint-disable-line require-await\n    if (result.ok) {\n      log.info(` ${'\\u2714'.green} ${result.message}`);\n    } else {\n      const errorMessage = result.optional ? ` ${'\\u2716'.yellow} ${result.message}` : ` ${'\\u2716'.red} ${result.message}`;\n      log.warn(errorMessage);\n      toFixList.push({\n        error: errorMessage,\n        check\n      });\n    }\n  }\n\n  async fixMessage (length, optional = false) { // eslint-disable-line require-await\n    let message;\n    switch (length) {\n      case 0:\n        message = 'no fix';\n        break;\n      case 1:\n        message = 'one fix';\n        break;\n      default:\n        message = `${length} fixes`;\n    }\n    return `${message} ${optional ? 'possible' : 'needed'}`;\n  }\n\n  async reportSuccess (length, lengthOptional) { // eslint-disable-line require-await\n    if (length === 0 && lengthOptional === 0) {\n      log.info('Everything looks good, bye!');\n      log.info('');\n      return true;\n    } else {\n      return false;\n    }\n  }\n}\n\nexport { Doctor, DoctorCheck, FixSkippedError };\n"],"mappings":"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"}