Как использовать модуль Jenkins Copy Artifacts из конвейера (jenkinsfile)?

Я пытаюсь найти пример использования модуля Jenkins Copy Artifacts из конвейера Jenkins (рабочие процессы).

Может ли кто-нибудь указать на образец Groovy кода, который его использует?

Ответ 1

Если сборки не работают в одном конвейере, вы можете использовать прямой плагин CopyArtifact, вот пример: https://www.cloudbees.com/blog/copying-artifacts-between-builds-jenkins-workflow и пример кода:

node {
   // setup env..
   // copy the deployment unit from another Job...
   step ([$class: 'CopyArtifact',
          projectName: 'webapp_build',
          filter: 'target/orders.war']);
   // deploy 'target/orders.war' to an app host
}

Ответ 2

Если вы используете подчиненные устройства в своем главном устройстве и хотите скопировать артефакты между собой, вы можете использовать stash/nonash, например:

stage 'build'
node{
   git 'https://github.com/cloudbees/todo-api.git'
   stash includes: 'pom.xml', name: 'pom'
}

stage name: 'test', concurrency: 3
node {
   unstash 'pom'
   sh 'cat pom.xml' 
}

Вы можете увидеть этот пример в этой ссылке:

https://dzone.com/refcardz/continuous-delivery-with-jenkins-workflow

Ответ 3

С помощью декларативного файла Jenkins вы можете использовать следующий конвейер:

pipeline {
    agent any
    stages {
        stage ('push artifact') {
            steps {
                sh 'mkdir archive'
                sh 'echo test > archive/test.txt'
                zip zipFile: 'test.zip', archive: false, dir: 'archive'
                archiveArtifacts artifacts: 'test.zip', fingerprint: true
            }
        }

        stage('pull artifact') {
            steps {
                step([  $class: 'CopyArtifact',
                        filter: 'test.zip',
                        fingerprintArtifacts: true,
                        projectName: '${JOB_NAME}',
                        selector: [$class: 'SpecificBuildSelector', buildNumber: '${BUILD_NUMBER}']
                ])
                unzip zipFile: 'test.zip', dir: './archive_new'
                sh 'cat archive_new/test.txt'
            }
        }
    }
}

С CopyArtifact я использую '$ {JOB_NAME}' в качестве имени проекта, который является текущим запущенным проектом.

Селектор по умолчанию, используемый CopyArtifact, использует последний успешный номер сборки проекта, а не текущий (потому что он еще не успешен или нет). С помощью SpecificBuildSelector вы можете выбрать "$ {BUILD_NUMBER}", который содержит текущий номер сборки проекта.

Этот конвейер работает с параллельными этапами и может управлять огромными файлами (я использую файл 300 Мб, он не работает с stash/unstash)

Этот конвейер отлично работает с моим Jenkins 2.74, если у вас есть все необходимые плагины

Ответ 4

name = "/" + "${env.JOB_NAME}"
def archiveName = 'relNum'
try {
    step($class: 'hudson.plugins.copyartifact.CopyArtifact', projectName: name, filter: archiveName)
} catch (none) {
    echo 'No artifact to copy from ' + name + ' with name relNum'
    writeFile file: archiveName, text: '3'
}

def content = readFile(archiveName).trim()
echo 'value archived: ' + content

попробуйте использовать плагин copy artifact