配置流水线执行条件表达式
在流水线阶段任务的执行条件中通过表达式引用流水线上下文,用以限制任务执行。表达式由流水线上下文、操作符、函数或常量组合而成,表达式以编程的方式访问流水线上下文,实现将流水线中运行的实例、变量、任务等信息在流水线之间互相传递。
- 新建流水线。
- 新建阶段任务或编辑已有阶段任务。
- 单击“任务配置”,在“执行条件”参数项选择“表达式”,即可配置流水线阶段任务执行条件的表达式。
如果是新建阶段任务,需添加插件后再单击“任务配置”。
图1 执行条件表达式
示例:
在执行条件中定义任务在指定代码源的运行分支为“master”时才运行,表达式语法如下:
${{ sources.my_repo.target_branch == 'master' }}
相关参考
- 操作符
表达式中可以使用如下操作符:
表1 操作符 操作符
说明
.
属性引用。如:${{ pipeline.trigger_type }},表示获取流水线的触发类型。
!
非。如:${{ !startsWith(sources.my_repo.target_branch, 'release') }},表示判断流水线代码源的分支是否不以release开头。
==
等于。如:${{ pipeline.trigger_type == 'Manual' }},表示判断流水线的触发方式是否为手动触发。
!=
不等于。如:${{ pipeline.trigger_type != 'Manual' }},表示判断流水线的触发方式是否不为手动触发。
&&
且。如:${{ pipeline.trigger_type == 'Manual' && sources.my_repo.target_branch == 'master' }},表示判断流水线的触发方式为手动触发并且流水线代码源的分支为master。
||
或。如:${{ pipeline.trigger_type == 'Manual' || sources.my_repo.target_branch == 'master' }},表示判断流水线的触发方式为手动触发或者流水线代码源的分支为master。
- 函数
表达式中可使用如下内置函数:
表2 内置函数 函数
说明
contains
startsWith
endsWith
对象筛选器
使用“*”语法应用筛选器并选择集合中的匹配项。
示例:如下是流水线某次运行的jobs上下文
{ "check_job": { "status": "COMPLETED", "metrics": { "critical": "0", "major": "0" } }, "demo_job": { "status": "FAILED" } }
- 示例1:“jobs.*.status”,表示所有任务的状态,所以返回“[ 'COMPLETED', 'FAILED' ]”。
- 示例2:结合contains函数一起使用,如:contains(jobs.*.status, 'FAILED'),“jobs.*.status”中包含“FAILED”,所以返回“true”。