npmci/ts/npmci.bash.ts

73 lines
2.6 KiB
TypeScript
Raw Permalink Normal View History

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