目前 gitlab 在使用 GUI 创建合并请求 + 分支时运行管道。
是否可以跳过此管道,因为它仅重复默认分支中的最后一个管道?
我们尝试过:
workflow:
rules:
- if: $CI_MERGE_REQUEST_IID
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
这可以跳过新的分支管道,但它不会为没有合并请求的分支上的新提交运行管道。
目前 gitlab 在使用 GUI 创建合并请求 + 分支时运行管道。
是否可以跳过此管道,因为它仅重复默认分支中的最后一个管道?
我们尝试过:
workflow:
rules:
- if: $CI_MERGE_REQUEST_IID
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
这可以跳过新的分支管道,但它不会为没有合并请求的分支上的新提交运行管道。
为了在创建新分支时停止管道执行,同时在分支上发生新提交时运行
尝试更改:
workflow:
rules:
- if: $CI_MERGE_REQUEST_IID
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
至
workflow:
rules:
- if: $CI_COMMIT_BEFORE_SHA == "0000000000000000000000000000000000000000"
when: never
- if: $CI_MERGE_REQUEST_IID
- if: $CI_PIPELINE_SOURCE == "push"
规则
- if: $CI_COMMIT_BEFORE_SHA == "0000000000000000000000000000000000000000"
when: never
创建新分支时将停止执行新管道
规则
- if: $CI_PIPELINE_SOURCE == "push"
添加此功能是为了在分支上发生提交时允许新的管道触发,因为如果事件不是合并请求,则管道将不会执行。