2019-12-14 16:52:26 -05:00
|
|
|
import * as child_process from 'child_process';
|
2021-03-14 02:42:46 -05:00
|
|
|
import { SpawnOptions } from 'child_process';
|
2019-12-14 16:52:26 -05:00
|
|
|
|
|
|
|
export async function _exec(options, cmd, args) {
|
|
|
|
let stdout = '';
|
|
|
|
let stderr = '';
|
|
|
|
const flags = [];
|
|
|
|
const cwd = process.cwd();
|
|
|
|
const env = options.env;
|
2021-03-14 02:42:46 -05:00
|
|
|
console.log(`Running \`${cmd} ${args.map((x) => `"${x}"`).join(' ')}\`${flags}...`);
|
2019-12-14 16:52:26 -05:00
|
|
|
console.log(`CWD: ${cwd}`);
|
|
|
|
console.log(`ENV: ${JSON.stringify(env)}`);
|
|
|
|
const spawnOptions = {
|
|
|
|
cwd,
|
2020-08-13 16:36:23 -05:00
|
|
|
...(env ? { env } : {}),
|
2019-12-14 16:52:26 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
if (process.platform.startsWith('win')) {
|
|
|
|
args.unshift('/c', cmd);
|
|
|
|
cmd = 'cmd.exe';
|
|
|
|
spawnOptions['stdio'] = 'pipe';
|
|
|
|
}
|
|
|
|
|
|
|
|
const childProcess = child_process.spawn(cmd, args, spawnOptions);
|
|
|
|
childProcess.stdout.on('data', (data) => {
|
|
|
|
stdout += data.toString('utf-8');
|
|
|
|
if (options.silent) {
|
|
|
|
return;
|
|
|
|
}
|
2019-12-15 16:18:47 -05:00
|
|
|
|
2021-03-14 02:42:46 -05:00
|
|
|
data
|
|
|
|
.toString('utf-8')
|
2019-12-14 16:52:26 -05:00
|
|
|
.split(/[\n\r]+/)
|
2021-03-14 02:42:46 -05:00
|
|
|
.filter((line) => line !== '')
|
|
|
|
.forEach((line) => console.log(' ' + line));
|
2019-12-14 16:52:26 -05:00
|
|
|
});
|
2019-12-15 16:18:47 -05:00
|
|
|
|
2019-12-14 16:52:26 -05:00
|
|
|
childProcess.stderr.on('data', (data) => {
|
|
|
|
stderr += data.toString('utf-8');
|
|
|
|
if (options.silent) {
|
|
|
|
return;
|
|
|
|
}
|
2019-12-15 16:18:47 -05:00
|
|
|
|
2021-03-14 02:42:46 -05:00
|
|
|
data
|
|
|
|
.toString('utf-8')
|
2019-12-14 16:52:26 -05:00
|
|
|
.split(/[\n\r]+/)
|
2021-03-14 02:42:46 -05:00
|
|
|
.filter((line) => line !== '')
|
|
|
|
.forEach((line) => console.error(' ' + line));
|
2019-12-14 16:52:26 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
const err = new Error(`Running "${cmd} ${args.join(' ')}" returned error code `);
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
childProcess.on('exit', (error) => {
|
|
|
|
if (!error) {
|
|
|
|
resolve({ stdout, stderr });
|
|
|
|
} else {
|
|
|
|
err.message += `${error}...\n\nSTDOUT:\n${stdout}\n\nSTDERR:\n${stderr}\n`;
|
|
|
|
reject(err);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (options.waitForMatch) {
|
|
|
|
const match = options.waitForMatch;
|
|
|
|
childProcess.stdout.on('data', (data) => {
|
2019-12-15 16:18:47 -05:00
|
|
|
// console.log("-->data==>", data.toString(), data.toString().match(match));
|
2019-12-14 16:52:26 -05:00
|
|
|
if (data.toString().match(match)) {
|
2021-03-14 02:42:46 -05:00
|
|
|
resolve({ ok: true, stdout, stderr });
|
2019-12-14 16:52:26 -05:00
|
|
|
}
|
|
|
|
});
|
|
|
|
childProcess.stderr.on('data', (data) => {
|
|
|
|
if (data.toString().match(match)) {
|
|
|
|
resolve({ stdout, stderr });
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-09-16 23:48:16 -05:00
|
|
|
export function execAndWaitForOutputToMatch(
|
|
|
|
cmd: string,
|
|
|
|
args: string[],
|
|
|
|
match: RegExp,
|
|
|
|
spawnOptions: SpawnOptions = {}
|
|
|
|
): any {
|
2019-12-15 16:18:47 -05:00
|
|
|
return _exec({ waitForMatch: match, ...spawnOptions, silence: true }, cmd, args);
|
2019-12-14 16:52:26 -05:00
|
|
|
}
|
|
|
|
|
2019-12-15 11:06:28 -05:00
|
|
|
export function npm(...args) {
|
|
|
|
return _exec({}, 'npm', args);
|
2019-12-14 16:52:26 -05:00
|
|
|
}
|
|
|
|
|
2019-12-15 16:18:47 -05:00
|
|
|
export function runVerdaccio(cmd, installation, args, match: RegExp): any {
|
|
|
|
return _exec({ cwd: installation, silent: true, waitForMatch: match }, cmd, args);
|
|
|
|
}
|
|
|
|
|
2019-12-14 16:52:26 -05:00
|
|
|
export function silentNpm(...args) {
|
2021-03-14 02:42:46 -05:00
|
|
|
return _exec({ silent: true }, 'npm', args);
|
2019-12-14 16:52:26 -05:00
|
|
|
}
|