web-dev-qa-db-fra.com

Est-il possible de capturer le stdout à partir de la commande sh DSL dans le pipeline

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?

53
Jesse S

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";
35
Andrey Prokopiev

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 .

161
iloahz

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:

  • Jenkins ver. 2.19.1
  • Pipeline 2.4
4
METAJIJI

Une version courte serait:

echo sh(script: 'ls -al', returnStdout: true).result
3
A.Hab

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
0
GalloCedrone