将Jenkins构建参数传递给管道节点

我创建了一个新的Jenkins管道.管道(当前)使用名为VAR_A的单个布尔选项进行参数化.我的管道脚本是:

node ('windows') {
    echo "$VAR_A"
    bat 'env'
}

当我手动构建带有VAR_A的项目时,会按预期回显“true”.但是,环境变量列表不显示VAR_A = true.

如果我将调用包装在withEnv块中,我可以让env显示VAR_A:

node ('windows') {
    echo "$VAR_A"
    withEnv(["VAR_A=$VAR_A"]) {
        bat 'env'
    }
}

我将提供比这更多的参数,因此不需要单独指定每个参数.有没有办法将所有构建参数传输到节点的环境?

关键是在管道脚本中,作业参数不会像常规作业一样自动注入环境.每个参数都成为Pipeline脚本 binding的变量.因此,您可以直接按名称访问它们.

在您的示例中,回显“$VAR_A”变量替换由脚本上下文中的groovy执行(请参阅Groovy doc on strings interpolation).这就是为什么你没有在蝙蝠输出中看到它.

对于要注入的每个参数,您需要添加如下所示的行:
env.VAR_A = VAR_A在脚本的开头.它可以在节点块之外,因为env在整个脚本中是全局的.

或者,有一种方法可以添加所有脚本变量,包括参数甚至是Pipeline内置变量,即步骤到环境中.不幸的是,它需要在沙箱中运行一些白名单:

@NonCPS
def populateEnv(){ binding.variables.each{k,v -> env."$k" = "$v"} }
populateEnv()

例:
VAR_A是一个参数.
脚本体:

def AAAA = 1 // such a definition doesn't put variable in the binding
BBBB = 2     // creates a binding variable. Absolutely the same behavior as for a job parameter.

@NonCPS
def populateEnv(){ binding.variables.each{k,v -> env."$k" = "$v"} }
populateEnv() // at this point injection happens

CCCC = 3      // created after the injection hence it won't appear in env.
node ('windows') {
    bat 'env'
}

在蝙蝠输出中,你会发现VAR_A和BBBB.

IMO,除非您的工作定义了数十个参数env.VAR_A = VAR_A方法更为简单,直接且无需批准.

本站公众号
   欢迎关注本站公众号,获取更多程序园信息
开发小院