パイプラインのshDSLコマンドからstdoutをキャプチャすることは可能ですか?


92

例えば:

var output=sh "echo foo";
echo "output=$output";

私は手に入れます:

output=0

したがって、どうやら私はstdoutではなく終了コードを取得します。stdoutをパイプライン変数にキャプチャして、次のようにすることはできます output=foo か?結果として?

回答:


227

現在、このshステップでは、パラメーターを指定してstdoutを返すことがサポートされています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)

この例を参照してください。


10
.trim()この回答の一部に注意してください。そうしないと、行末に改行文字が表示される可能性があります
Will Munn 2016

2
追加--shortするとrev-parse、短いハッシュを直接取得できます
Leon

何が失敗の原因かはgitCommit = sh(returnStdout: true, script: 'git rev-parse HEAD').toString().trim()
わかり

こんにちは、「。take(6)」は何の略ですか?
Vano 2018年

1
Groovyメソッドtake()を参照する@Vano。この場合、最初の6文字を取得します。docs.groovy-lang.org/docs/groovy-2.3.2/html/api/org/codehaus/...
ahillman3

47

注:リンクされたJenkinsの問題はその後解決されました。

JENKINS-26133で述べたように、シェル出力を変数として取得することはできませんでした。回避策として、一時ファイルからの書き込み読み取りの使用を提案しました。したがって、あなたの例は次のようになります。

sh "echo foo > result";
def output=readFile('result').trim()
echo "output=$output";

21
新規参入者の場合は、以下の回答stackoverflow.com/a/38912813/345845を参照してください。これはreturnStdoutshステップに渡された新しいパラメーターによって簡単になりました。
Baptiste Mathus 2017年

2
「シェル出力を変数として取得することはできません」-正しくありません。これはハックです。正解はreturnStdoutです。
グラハム

4
あなたが必要な場合は、これは実際には良い答えである唯一の時間があり、両方stdoutexit statusシェルコマンドから。それ以外の場合は、returnStdoutパラメーターを使用します。
Simon Forsberg 2017

4

これを試して:

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
    ...
}

テスト済み:

  • ジェンキンスver。2.19.1
  • パイプライン2.4

3

この関数を使用して、StdErrStdOutをキャプチャしてコードを返すこともできます。

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}"
    }
}

通知:

&>name means 1>name 2>name -- redirect stdout and stderr to the file name

1

短いバージョンは次のようになります。

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


0

私は同じ問題を抱えていて、間違ったブロックで試していることがわかった後、ほとんどすべてを試しました。ステップブロックで試していましたが、環境ブロックにある必要があります。

        stage('Release') {
                    environment {
                            my_var = sh(script: "/bin/bash ${assign_version} || ls ", , returnStdout: true).trim()
                                }
                    steps {                                 
                            println my_var
                            }
                }
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.