2016-11-24 22:21:40 +00:00
|
|
|
import * as plugins from './npmci.plugins'
|
2016-06-07 01:57:43 +00:00
|
|
|
|
2016-11-24 22:21:40 +00:00
|
|
|
let nvmSourceString: string = ''
|
|
|
|
export let nvmAvailable: boolean = false
|
2016-08-02 14:20:32 +00:00
|
|
|
let checkNvm = () => {
|
2016-11-24 22:21:40 +00:00
|
|
|
if (plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`,{silent: true}).code === 0) {
|
2016-08-02 14:20:32 +00:00
|
|
|
nvmSourceString = `source /usr/local/nvm/nvm.sh && `
|
2016-11-24 22:21:40 +00:00
|
|
|
nvmAvailable = true
|
|
|
|
} else if (plugins.shelljs.exec(`bash -c "source ~/.nvm/nvm.sh"`,{silent: true}).code === 0) {
|
2016-08-02 21:11:42 +00:00
|
|
|
nvmSourceString = `source ~/.nvm/nvm.sh && `
|
2016-11-24 22:21:40 +00:00
|
|
|
nvmAvailable = true
|
2016-08-02 21:11:42 +00:00
|
|
|
};
|
2016-11-24 22:21:40 +00:00
|
|
|
}
|
|
|
|
checkNvm()
|
2016-08-02 14:20:32 +00:00
|
|
|
|
2016-12-10 21:43:14 +00:00
|
|
|
/**
|
|
|
|
* bash() allows using bash with nvm in path
|
|
|
|
*/
|
|
|
|
export let bash = (commandArg: string, retryArg: number = 2, bareArg: boolean = false): string => {
|
2016-11-24 22:21:40 +00:00
|
|
|
let exitCode: number
|
|
|
|
let stdOut: string
|
|
|
|
let execResult
|
2016-08-02 21:11:42 +00:00
|
|
|
if (!process.env.NPMTS_TEST) { // NPMTS_TEST is used during testing
|
|
|
|
for (let i = 0; i <= retryArg; i++) {
|
|
|
|
if (!bareArg) {
|
2016-06-07 01:57:43 +00:00
|
|
|
execResult = plugins.shelljs.exec(
|
2016-08-02 14:20:32 +00:00
|
|
|
`bash -c "${nvmSourceString} ${commandArg}"`
|
2016-11-24 22:21:40 +00:00
|
|
|
)
|
2016-06-07 01:57:43 +00:00
|
|
|
} else {
|
2016-11-24 22:21:40 +00:00
|
|
|
execResult = plugins.shelljs.exec(commandArg)
|
2016-06-07 01:57:43 +00:00
|
|
|
}
|
2016-11-24 22:21:40 +00:00
|
|
|
exitCode = execResult.code
|
|
|
|
stdOut = execResult.stdout
|
2016-12-10 21:43:14 +00:00
|
|
|
|
|
|
|
// determine how bash reacts to error and success
|
|
|
|
if (exitCode !== 0 && i === retryArg) { // something went wrong and retries are exhausted
|
2016-11-24 22:21:40 +00:00
|
|
|
process.exit(1)
|
2016-12-10 21:43:14 +00:00
|
|
|
} else if (exitCode === 0 || retryArg === -1) { // everything went fine, or no error wanted
|
|
|
|
i = retryArg + 1 // retry +1 breaks for loop, if everything works out ok retrials are not wanted
|
2016-06-05 19:11:30 +00:00
|
|
|
} else {
|
2016-11-24 22:21:40 +00:00
|
|
|
plugins.beautylog.warn('Something went wrong! Exit Code: ' + exitCode.toString())
|
|
|
|
plugins.beautylog.info('Retry ' + (i + 1).toString() + ' of ' + retryArg.toString())
|
2016-06-05 18:51:13 +00:00
|
|
|
}
|
2016-06-05 12:55:08 +00:00
|
|
|
}
|
|
|
|
} else {
|
2016-11-24 22:21:40 +00:00
|
|
|
plugins.beautylog.log('ShellExec would be: ' + commandArg)
|
2016-05-30 01:43:15 +00:00
|
|
|
}
|
2016-11-24 22:21:40 +00:00
|
|
|
return stdOut
|
2016-06-05 12:33:59 +00:00
|
|
|
}
|
|
|
|
|
2016-12-10 21:43:14 +00:00
|
|
|
/**
|
|
|
|
* bashBare allows usage of bash without sourcing any files like nvm
|
|
|
|
*/
|
|
|
|
export let bashBare = (commandArg: string, retryArg: number = 2) => {
|
2016-11-24 22:21:40 +00:00
|
|
|
return bash(commandArg, retryArg, true)
|
|
|
|
}
|
2016-12-10 21:43:14 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* bashNoError allows executing stuff without throwing an error
|
|
|
|
*/
|
|
|
|
export let bashNoError = (commandArg: string) => {
|
|
|
|
return bash(commandArg,-1)
|
|
|
|
}
|