如何在Jenkins管道中使用动态数据构建并行和顺序阶段的组合

问题描述

我正在尝试构建一个包含并行阶段和顺序阶段的组合的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"
                }
            }   
        }

    }
}

}

给我以下执行结果

enter image description here

现在,我想从构建参数中读取值,然后循环执行各个阶段。这是我尝试过的但无法正常工作。这是我几个月前在SO中找到的另一个答案的片段,但现在无法跟踪,否则将添加链接-

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。由于您是根据参数动态创建管道定义的,因此除非您的用例与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
}