npmci/ts/npmci.bash.ts

48 lines
1.6 KiB
TypeScript
Raw Normal View History

2016-05-30 01:40:07 +00:00
import "typings-global";
import * as plugins from "./npmci.plugins";
2016-06-07 01:57:43 +00:00
let nvmSourceString:string = "";
export let nvmAvailable:boolean = false;
let checkNvm = () => {
let nvmExecCode = plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`).code;
if(nvmExecCode === 0){
nvmSourceString = `source /usr/local/nvm/nvm.sh && `
nvmAvailable = true;
}
};
checkNvm();
2016-06-07 01:57:43 +00:00
export let bash = (commandArg:string,retryArg = 2,bareArg = false) => {
let exitCode:number;
let stdOut:string;
let execResult;
if(!process.env.NPMTS_TEST){ // NPMTS_TEST is used during testing
for (let i = 0; i <= retryArg; i++){
2016-06-07 01:57:43 +00:00
if(!bareArg){
execResult = plugins.shelljs.exec(
`bash -c "${nvmSourceString} ${commandArg}"`
2016-06-07 02:55:08 +00:00
);
2016-06-07 01:57:43 +00:00
} else {
2016-06-07 03:36:37 +00:00
execResult = plugins.shelljs.exec(commandArg);
2016-06-07 01:57:43 +00:00
}
exitCode = execResult.code;
stdOut = execResult.stdout;
if(exitCode !== 0 && i == retryArg){
process.exit(1);
} else if(exitCode == 0){
2016-06-05 19:11:30 +00:00
i = retryArg + 1; // if everything works out ok retrials are not wanted
} else {
2016-06-06 21:57:23 +00:00
plugins.beautylog.warn("Something went wrong! Exit Code: " + exitCode.toString());
2016-06-06 21:53:14 +00:00
plugins.beautylog.info("Retry " + (i + 1).toString() + " of " + retryArg.toString());
}
2016-06-05 12:55:08 +00:00
}
} else {
plugins.beautylog.log("ShellExec would be: " + commandArg.blue)
2016-05-30 01:43:15 +00:00
}
2016-06-07 01:57:43 +00:00
return stdOut;
}
2016-06-05 19:11:30 +00:00
export let bashBare = (commandArg,retryArg = 2) => {
2016-06-07 01:57:43 +00:00
return bash(commandArg,retryArg,true);
2016-05-30 01:40:07 +00:00
}