Puede utilizar el build job
paso de Jenkins Pipeline (requisito mínimo de Jenkins: 2.130).
Aquí está la API completa para el build
paso: https://jenkins.io/doc/pipeline/steps/pipeline-build-step/
Cómo utilizar build
:
job
: Nombre de un trabajo posterior para construir. Puede ser otro trabajo de Pipeline, pero más comúnmente un estilo libre u otro proyecto.
- Utilice un nombre simple si el trabajo está en la misma carpeta que este trabajo de canalización ascendente;
- En su lugar, puede usar rutas relativas como
../sister-folder/downstream
- O puedes usar rutas absolutas como
/top-level-folder/nested-folder/downstream
Activa otro trabajo usando una rama como parámetro
En mi empresa, muchas de nuestras sucursales incluyen "/". Debe reemplazar cualquier instancia de "/" con "% 2F" (como aparece en la URL del trabajo).
En este ejemplo estamos usando rutas relativas
stage('Trigger Branch Build') {
steps {
script {
echo "Triggering job for branch ${env.BRANCH_NAME}"
BRANCH_TO_TAG=env.BRANCH_NAME.replace("/","%2F")
build job: "../my-relative-job/${BRANCH_TO_TAG}", wait: false
}
}
}
Activa otro trabajo usando el número de compilación como parámetro
build job: 'your-job-name',
parameters: [
string(name: 'passed_build_number_param', value: String.valueOf(BUILD_NUMBER)),
string(name: 'complex_param', value: 'prefix-' + String.valueOf(BUILD_NUMBER))
]
Desencadenar muchos trabajos en paralelo
Fuente: https://jenkins.io/blog/2017/01/19/converting-conditional-to-pipeline/
Más información sobre Paralelo aquí: https://jenkins.io/doc/book/pipeline/syntax/#parallel
stage ('Trigger Builds In Parallel') {
steps {
// Freestyle build trigger calls a list of jobs
// Pipeline build() step only calls one job
// To run all three jobs in parallel, we use "parallel" step
// https://jenkins.io/doc/pipeline/examples/#jobs-in-parallel
parallel (
linux: {
build job: 'full-build-linux', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
mac: {
build job: 'full-build-mac', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
windows: {
build job: 'full-build-windows', parameters: [string(name: 'GIT_BRANCH_NAME', value: env.BRANCH_NAME)]
},
failFast: false)
}
}
O alternativamente:
stage('Build A and B') {
failFast true
parallel {
stage('Build A') {
steps {
build job: "/project/A/${env.BRANCH}", wait: true
}
}
stage('Build B') {
steps {
build job: "/project/B/${env.BRANCH}", wait: true
}
}
}
}