Чи можна захопити stdout з команди sh DSL у конвеєрі


92

Наприклад:

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

Я отримаю:

output=0

Отже, очевидно, я отримую код виходу, а не stdout. Чи можна захопити stdout у змінну конвеєра, таку, яку я міг отримати: output=foo як мій результат?

Відповіді:


227

Тепер , як shкрок підтримує повернення стандартного виведення шляхом подачі параметра 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

2
Append , --shortщоб rev-parseможна просто прямо одержати короткий хеш
Leon

не впевнений, що спричиняє збій, але мені довелося перетворити висновок у рядок також такgitCommit = sh(returnStdout: true, script: 'git rev-parse HEAD').toString().trim()
Балкрішна,

привіт, що означає '.take (6)'?
Вано,

1
@Vano, що посилається на метод Groovy take (), який у цьому випадку отримає перші 6 символів. docs.groovy-lang.org/docs/groovy-2.3.2/html/api/org/codehaus/…
ahillman3

47

Примітка: Зв’язана проблема Дженкінса з тих пір вирішена.

Як згадувалося в JENKINS-26133, неможливо було отримати вихід оболонки як змінну. Як обхідний шлях пропонується використовувати зчитування з тимчасового файлу. Отже, ваш приклад мав би виглядати так:

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

21
Для новачків див. Відповідь stackoverflow.com/a/38912813/345845 нижче, оскільки це стало простіше завдяки новому returnStdoutпараметру, переданому shкроку.
Baptiste Mathus

2
"неможливо отримати вихід оболонки як змінну" - не відповідає дійсності. Це хакерство, правильна відповідь returnStdout.
Грем

4
Єдиний випадок, коли це насправді є гарною відповіддю, - це якщо вам потрібна і команда, stdoutі команда exit statusз оболонки. В інших випадках використовуйте returnStdoutпараметр.
Саймон Форсберг

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

Перевірено на:

  • Дженкінс вір. 2.19.1
  • Трубопровід 2.4

3

Ви можете спробувати використовувати також ці функції для захоплення StdErr StdOut і повернення коду.

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



0

У мене була та сама проблема, і я спробував майже все, що знайшло, після того, як я дізнався, що намагався це зробити не в тому блоці. Я пробував це поетапно, тоді як він повинен бути в блоці середовища.

        stage('Release') {
                    environment {
                            my_var = sh(script: "/bin/bash ${assign_version} || ls ", , returnStdout: true).trim()
                                }
                    steps {                                 
                            println my_var
                            }
                }
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.