Par exemple:
var output=sh "echo foo";
echo "output=$output";
J'aurai:
output=0
Donc, apparemment, je reçois le code de sortie plutôt que la sortie standard. Est-il possible de capturer la sortie standard dans une variable de pipeline, de sorte que je puisse obtenir: output=foo
comme résultat?
Remarque: le problème lié à Jenkins a depuis été résolu.
Comme mentionné dans JENKINS-26133 , il n’a pas été possible d’obtenir la sortie du shell en tant que variable. En guise de solution de contournement, il a été suggéré d’utiliser le paramètre read-read du fichier temporaire. Ainsi, votre exemple aurait ressemblé à:
sh "echo foo > result";
def output=readFile('result').trim()
echo "output=$output";
Maintenant , l'étape sh
step prend en charge le renvoi de stdout en fournissant le paramètre returnStdout
.
// These should all be performed at the point where you've
// checked out your sources on the slave. A 'git' executable
// must be available.
// Most typical, if you're not cloning into a sub directory
gitCommit = sh(returnStdout: true, script: 'git rev-parse HEAD').trim()
// short SHA, possibly better for chat notifications, etc.
shortCommit = gitCommit.take(6)
Voir cet exemple .
Essaye ça:
def get_git_sha(git_dir='') {
dir(git_dir) {
return sh(returnStdout: true, script: 'git rev-parse HEAD').trim()
}
}
node(BUILD_NODE) {
...
repo_SHA = get_git_sha('src/FooBar.git')
echo repo_SHA
...
}
Testé sur:
Une version courte serait:
echo sh(script: 'ls -al', returnStdout: true).result
Vous pouvez également utiliser cette fonction pour capturer StdErr StdOut et renvoyer le code.
def runShell(String command){
def responseCode = sh returnStatus: true, script: "${command} &> tmp.txt"
def output = readFile(file: "tmp.txt")
if (responseCode != 0){
println "[ERROR] ${output}"
throw new Exception("${output}")
}else{
return "${output}"
}
}
Remarquer:
&>name means 1>name 2>name -- redirect stdout and stderr to the file name