如何在 Jenkins 管道中使用动态数据构建并行和顺序阶段的组合
How to build a combination of parallel and sequential stages in Jenkins pipeline with dynamic data
我正在尝试构建一个 Jenkins 管道,它结合了并行阶段和顺序阶段。我能够使用静态数据完成相同的操作,但在使用动态数据时无法使其正常工作,即使用参数化构建并从构建参数读取数据时。
下面的代码片段工作正常
pipeline {
agent any
stages {
stage('Parallel Tests') {
parallel {
stage('Ordered Tests Set') {
stages {
stage('Building seq test 1') {
steps {
echo "build seq test 1"
}
}
stage('Building seq test 2') {
steps {
echo "build seq test 2"
}
}
}
}
stage('Building Parallel test 1') {
steps {
echo "Building Parallel test 1"
}
}
stage('Building Parallel test 2') {
steps {
echo "Building Parallel test 2"
}
}
}
}
}
}
给我下面的执行结果
现在我想从我的构建参数中读取值并循环各个阶段。这是我尝试过但无法正常工作的方法。这段代码摘自我几个月前在 SO 中找到的另一个答案,但现在无法追踪,否则会添加 link -
def parallelStagesMap = params['Parallel Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedStagesMap = params['Ordered Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedMap (){
def orderedStagesMapList= [:]
orderedStagesMapList['Ordered Tests Set']= {
stage('Ordered Tests Set') {
stages{
orderedStagesMap
}
}
}
return orderedStagesMapList;
}
def generateStage(job) {
return {
stage("stage: ${job}") {
echo "This is ${job}."
}
}
}
pipeline {
agent none
stages {
stage ("Parallel Stage to trigger Tests"){
steps {
script {
parallel orderedMap()+parallelStagesMap
}
}
}
}
}
声明式和脚本式流水线语法不会在流水线中混用,请参阅 Pipeline Syntax。由于您正在根据参数动态创建管道定义,因此您很可能应该完全使用脚本语法,除非您的 use-case 匹配 matrix
.
从您的管道定义中删除声明性语法会产生如下内容。请注意,我没有在实时 Jenkins 实例上对其进行测试。
def parallelStagesMap = params['Parallel Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedStagesMap = params['Ordered Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedMap (){
def orderedStagesMapList= [:]
orderedStagesMapList['Ordered Tests Set']= {
stage('Ordered Tests Set') {
orderedStagesMap.each { key, value ->
value.call()
}
}
}
return orderedStagesMapList;
}
def generateStage(job) {
return {
stage("stage: ${job}") {
echo "This is ${job}."
}
}
}
stage("Parallel Stage to trigger Tests") {
parallel orderedMap()+parallelStagesMap
}
我正在尝试构建一个 Jenkins 管道,它结合了并行阶段和顺序阶段。我能够使用静态数据完成相同的操作,但在使用动态数据时无法使其正常工作,即使用参数化构建并从构建参数读取数据时。
下面的代码片段工作正常
pipeline {
agent any
stages {
stage('Parallel Tests') {
parallel {
stage('Ordered Tests Set') {
stages {
stage('Building seq test 1') {
steps {
echo "build seq test 1"
}
}
stage('Building seq test 2') {
steps {
echo "build seq test 2"
}
}
}
}
stage('Building Parallel test 1') {
steps {
echo "Building Parallel test 1"
}
}
stage('Building Parallel test 2') {
steps {
echo "Building Parallel test 2"
}
}
}
}
}
}
给我下面的执行结果
现在我想从我的构建参数中读取值并循环各个阶段。这是我尝试过但无法正常工作的方法。这段代码摘自我几个月前在 SO 中找到的另一个答案,但现在无法追踪,否则会添加 link -
def parallelStagesMap = params['Parallel Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedStagesMap = params['Ordered Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedMap (){
def orderedStagesMapList= [:]
orderedStagesMapList['Ordered Tests Set']= {
stage('Ordered Tests Set') {
stages{
orderedStagesMap
}
}
}
return orderedStagesMapList;
}
def generateStage(job) {
return {
stage("stage: ${job}") {
echo "This is ${job}."
}
}
}
pipeline {
agent none
stages {
stage ("Parallel Stage to trigger Tests"){
steps {
script {
parallel orderedMap()+parallelStagesMap
}
}
}
}
}
声明式和脚本式流水线语法不会在流水线中混用,请参阅 Pipeline Syntax。由于您正在根据参数动态创建管道定义,因此您很可能应该完全使用脚本语法,除非您的 use-case 匹配 matrix
.
从您的管道定义中删除声明性语法会产生如下内容。请注意,我没有在实时 Jenkins 实例上对其进行测试。
def parallelStagesMap = params['Parallel Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedStagesMap = params['Ordered Job Set'].split(',').collectEntries {
["${it}" : generateStage(it)]
}
def orderedMap (){
def orderedStagesMapList= [:]
orderedStagesMapList['Ordered Tests Set']= {
stage('Ordered Tests Set') {
orderedStagesMap.each { key, value ->
value.call()
}
}
}
return orderedStagesMapList;
}
def generateStage(job) {
return {
stage("stage: ${job}") {
echo "This is ${job}."
}
}
}
stage("Parallel Stage to trigger Tests") {
parallel orderedMap()+parallelStagesMap
}