@apica-io/asm-pm-runner
Version:
Run a postman collection in Apica ASM.
139 lines • 5.64 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
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());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const fs_1 = __importDefault(require("fs"));
const log4js = __importStar(require("log4js"));
const helpers = __importStar(require("../lib/helpers"));
const commander_1 = require("commander");
const newmanRunner_1 = require("../processor/newmanRunner");
function run(config) {
return __awaiter(this, void 0, void 0, function* () {
let exitCode = 0;
try {
let runner = new newmanRunner_1.NewmanRunner(config);
runner.init();
yield runner.run();
runner.saveResult();
}
catch (error) {
logger.error(error.message || error);
console.error(error.message || error);
exitCode = 1;
}
process.exit(exitCode);
});
}
function checkDirectory(dir, name) {
if (dir && (!fs_1.default.existsSync(dir) || !fs_1.default.lstatSync(dir).isDirectory())) {
console.error("The specified %s directory %s is not valid", name || "", dir);
process.exit(9);
}
}
const cliLogConfig = {
appenders: {
out: {
type: "stdout",
},
},
categories: {
default: { appenders: ["out"], level: "INFO" },
},
};
var pack = helpers.getPackageInfo();
let version = pack.version || "version unknown";
let program = new commander_1.Command();
program.storeOptionsAsProperties(true);
let config = {};
program
.option("-e, --environment <path>", "Environment JSON file")
.option("-dk, --decryptKey <decryptKey>", "Decrypt key")
.option('-ev, --envVars [envVars...]', 'Environment variables. Format name=value format')
.option("-v, --verbose", "Print collection information on stdout", false)
.option('-r, --resultDir <dir>', 'The result directory')
.option('-dd, --dataDir <dir>', 'The data directory for certificates and test data')
.option("-l, --logLevel <logLevel>", "Log level in log4js", "info")
.option('--sslClientCert <path>', 'Specify the path to a client certificate (PEM)')
.option('--sslClientKey <path>', 'Specify the path to a client certificate private key')
.option('--sslClientPassphrase <passphrase>', 'Specify the client certificate passphrase (for protected key)')
.arguments("<collection>");
program.version(version);
program.parse(process.argv);
let log_level = program.opts().logLevel || "info";
log_level = log_level.toUpperCase();
switch (log_level) {
case "DEBUG":
case "TRACE":
break;
case "ERROR":
case "FATAL":
break;
default:
log_level = "INFO";
break;
}
cliLogConfig.categories.default.level = log_level;
log4js.configure(cliLogConfig);
var logger = log4js.getLogger(pack.name);
config.collection = program.args[0];
config.decryptKey = program.opts().decryptKey;
config.resultDir = program.opts().resultDir;
config.dataDir = program.opts().dataDir;
config.environment = program.opts().environment;
config.envVars = program.opts().envVars;
config.verbose = program.opts().verbose;
// SSL Config
config.sslConfig = {};
config.sslConfig.cert = program.opts().sslClientCert;
config.sslConfig.key = program.opts().sslClientKey;
config.sslConfig.passPhrase = program.opts().sslClientPassphrase;
logger.info("%s (%s) started", pack.name, version);
logger.debug("collection=%s", config.collection);
checkDirectory(config.resultDir, "result");
checkDirectory(config.dataDir, "data");
if (!fs_1.default.existsSync(config.collection) || !fs_1.default.lstatSync(config.collection).isFile()) {
console.error("The specified collection file %s does not exist", config.collection);
process.exit(9);
}
try {
run(config);
}
catch (e) {
logger.error(e);
console.error(e);
}
//# sourceMappingURL=index.js.map