UNPKG

appcenter-cli

Version:

Command line tool for Visual Studio App Center

145 lines (144 loc) 8.13 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const commandline_1 = require("../../../util/commandline"); const interaction_1 = require("../../../util/interaction"); const util_1 = require("util"); const date_helper_1 = require("./lib/date-helper"); const misc_1 = require("../../../util/misc"); const chalk = require("chalk"); const debug = require("debug")("appcenter-cli:commands:codepush:deployments:history"); let CodePushDeploymentHistoryCommand = class CodePushDeploymentHistoryCommand extends commandline_1.AppCommand { constructor(args) { super(args); } run(client) { return __awaiter(this, void 0, void 0, function* () { const app = this.app; let releases; let metrics; try { releases = yield interaction_1.out.progress("Getting CodePush releases...", client.codePushDeploymentReleases.get(this.deploymentName, app.ownerName, app.appName)); metrics = yield interaction_1.out.progress("Getting CodePush releases metrics...", client.codePushDeploymentMetrics.get(this.deploymentName, app.ownerName, app.appName)); const releasesTotalActive = metrics.reduce((sum, releaseMetrics) => (sum += releaseMetrics.active), 0); let tableTitles = ["Label", "Release Time", "App Version", "Mandatory", "Description", "Install Metrics"]; tableTitles = tableTitles.map((title) => chalk.cyan(title)); interaction_1.out.table(interaction_1.out.getCommandOutputTableOptions(tableTitles), releases.map((release) => { let releaseRow = [ release.label, date_helper_1.formatDate(release.uploadTime) + this.generateReleaseAdditionalInfoString(release), release.targetBinaryRange, release.isMandatory ? "Yes" : "No", release.description, this.generateReleaseMetricsString(release, metrics, releasesTotalActive), ]; if (release.isDisabled) { releaseRow = releaseRow.map((element) => this.applyDimChalkSkippingLineBreaks(element)); } return releaseRow; })); return commandline_1.success(); } catch (error) { debug(`Failed to get list of CodePush deployments - ${util_1.inspect(error)}`); if (error.statusCode === 404 && error.response.bodyAsText === `Deployment "${this.deploymentName}" does not exist.`) { const deploymentNotExistErrorMsg = `The deployment ${chalk.bold(this.deploymentName)} does not exist.`; return commandline_1.failure(commandline_1.ErrorCodes.Exception, deploymentNotExistErrorMsg); } else if (error.statusCode === 404) { const appNotFoundErrorMsg = `The app ${this.identifier} does not exist. Please double check the name, and provide it in the form owner/appname. \nRun the command ${chalk.bold(`${misc_1.scriptName} apps list`)} to see what apps you have access to.`; return commandline_1.failure(commandline_1.ErrorCodes.NotFound, appNotFoundErrorMsg); } else { return commandline_1.failure(commandline_1.ErrorCodes.Exception, error.response.bodyAsText); } } }); } generateReleaseAdditionalInfoString(release) { let additionalInfo = ""; if (release.releaseMethod === "Promote") { additionalInfo = `(Promoted ${release.originalLabel} from ${release.originalDeployment})`; } else if (release.releaseMethod === "Rollback") { const labelNumber = parseInt(release.label.substring(1), 10); const previousReleaseLabel = "v" + (labelNumber - 1); additionalInfo = `(Rolled back ${previousReleaseLabel} to ${release.originalLabel})`; } return additionalInfo ? "\n" + chalk.magenta(additionalInfo) : ""; } generateReleaseMetricsString(release, metrics, releasesTotalActive) { let metricsString = ""; const releaseMetrics = metrics.find((metric) => metric.label === release.label); if (releaseMetrics) { const activePercent = releasesTotalActive ? (releaseMetrics.active / releasesTotalActive) * 100 : 0.0; let percentString; if (activePercent === 100.0) { percentString = "100%"; } else if (activePercent === 0.0) { percentString = "0%"; } else { percentString = activePercent.toPrecision(2) + "%"; } metricsString += chalk.green("Active: ") + percentString + ` (${releaseMetrics.active} of ${releasesTotalActive})`; if (releaseMetrics.installed != null) { metricsString += "\n" + chalk.green("Installed: ") + releaseMetrics.installed; const pending = releaseMetrics.downloaded - releaseMetrics.installed - releaseMetrics.failed; if (pending > 0) { metricsString += ` (${pending} pending)`; } } if (releaseMetrics.failed > 0) { metricsString += "\n" + chalk.green("Rollbacks: ") + chalk.red(releaseMetrics.failed.toString()); } } else { metricsString = chalk.magenta("No installs recorded"); } if (release.rollout != null && release.rollout !== 100) { metricsString += "\n" + chalk.green("Rollout: ") + release.rollout + "%"; } if (release.isDisabled) { metricsString += "\n" + chalk.green("Disabled: ") + "Yes"; } return metricsString; } applyDimChalkSkippingLineBreaks(applyString) { // Used to prevent "chalk" from applying styles to linebreaks which // causes table border chars to have the style applied as well. let chalkedString = ""; if (applyString) { chalkedString = applyString .split("\n") .map((line) => chalk.dim(line)) .join("\n"); } return chalkedString; } }; __decorate([ commandline_1.help("Specifies CodePush deployment name to view history"), commandline_1.required, commandline_1.name("deployment-name"), commandline_1.position(0) ], CodePushDeploymentHistoryCommand.prototype, "deploymentName", void 0); CodePushDeploymentHistoryCommand = __decorate([ commandline_1.help("Display the release history for a CodePush deployment") ], CodePushDeploymentHistoryCommand); exports.default = CodePushDeploymentHistoryCommand;