TL; DR:显然,在Jenkins管道作业中,您可以轻松地向下游传递参数。我想知道的是,是否可以将它们传递给 上游 。
我们有三份工作;job_one,job_two和job_three。它们通常仅需要一个阶段就可以单独运行,但是在越来越频繁的情况下,我们希望能够将所有三个阶段背靠背运行。
job_one
job_two
job_three
第一个和第二个依赖于您可以提前定义的参数,但是第三个和第二个依赖于从第二个作业生成的参数(该文件名的结构在job_two运行之前是未知的)。
我建立了umbrella,每个工作都需要类似以下内容的东西。在这种情况下,PARAM1将填充,因为伞以“带参数的构建”形式运行。
umbrella
PARAM1
build job: 'job_one', parameters: [[$class: 'StringParameterValue', name: 'PARAM1', value: "$PARAM1"]]
一切都很好,然后我就可以使用PARAM1了job_one。
因为job_three我需要参数filename。这是在内部生成的job_two,因此据我所知无法访问,因为job_three不知道job_two在做什么。
filename
在理想的世界中,我只需要将job_two传递filename给伞作业,然后将其反馈给job_three。因此, 如何将生成的filename备份传递到伞式工作?
我正在描绘一个最终的脚本,像这样;
node('on-demand-t2small'){ stage ('Build 1') { build job: 'job_one', parameters: [[$class: 'StringParameterValue', name: 'PARAM1', value: "$PARMA1"]] } stage ('Build 2') { build job: 'job_two', parameters: [[$class: 'StringParameterValue', name: 'PARAM2', value: "$PARMA2"]] //somehow get the filename parameter out of job_two here so that I can move it to job three... } stage ('Build 3') { build job: 'job_three', parameters: [[$class: 'StringParameterValue', name: 'filename', value: "$filename"]] } }
我认识到第一个问题是“为什么没有job_two触发job_three?我不能以这种方式设置系统,原因有两个:
我曾考虑过将参数设置为环境变量,但我认为这是特定于节点的,因此我不能保证两个作业都将在同一节点上运行,因此这似乎不是解决方案。
伞是一种用groovy编写的管道作业,如果重要的话,其他三个可能是管道作业或自由式作业。
在可能的情况下,我希望您能获得详细的答案,但对于Groovy,Jenkins和一般的编码人员,我仍然是新手。
它应该像这样简单:
stage ('Build 3') { res = build job: 'job_three', parameters: [[$class: 'StringParameterValue', name: 'filename', value: "$filename"]] echo "$res.buildVariables.filename" }
假设您在job_three中做
env.filename = "col new file name"