计算
弹性云服务器 ECS
Flexus云服务
裸金属服务器 BMS
弹性伸缩 AS
镜像服务 IMS
专属主机 DeH
函数工作流 FunctionGraph
云手机服务器 CPH
Huawei Cloud EulerOS
网络
虚拟私有云 VPC
弹性公网IP EIP
虚拟专用网络 VPN
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
VPC终端节点 VPCEP
云连接 CC
企业路由器 ER
企业交换机 ESW
全球加速 GA
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
边缘安全 EdgeSec
威胁检测服务 MTD
CDN与智能边缘
内容分发网络 CDN
CloudPond云服务
智能边缘云 IEC
迁移
主机迁移服务 SMS
对象存储迁移服务 OMS
云数据迁移 CDM
迁移中心 MGC
大数据
MapReduce服务 MRS
数据湖探索 DLI
表格存储服务 CloudTable
云搜索服务 CSS
数据接入服务 DIS
数据仓库服务 GaussDB(DWS)
数据治理中心 DataArts Studio
数据可视化 DLV
数据湖工厂 DLF
湖仓构建 LakeFormation
企业应用
云桌面 Workspace
应用与数据集成平台 ROMA Connect
云解析服务 DNS
专属云
专属计算集群 DCC
IoT物联网
IoT物联网
设备接入 IoTDA
智能边缘平台 IEF
用户服务
账号中心
费用中心
成本中心
资源中心
企业管理
工单管理
国际站常见问题
ICP备案
我的凭证
支持计划
客户运营能力
合作伙伴支持计划
专业服务
区块链
区块链服务 BCS
Web3节点引擎服务 NES
解决方案
SAP
高性能计算 HPC
视频
视频直播 Live
视频点播 VOD
媒体处理 MPC
实时音视频 SparkRTC
数字内容生产线 MetaStudio
存储
对象存储服务 OBS
云硬盘 EVS
云备份 CBR
存储容灾服务 SDRS
高性能弹性文件服务 SFS Turbo
弹性文件服务 SFS
云硬盘备份 VBS
云服务器备份 CSBS
数据快递服务 DES
专属分布式存储服务 DSS
容器
云容器引擎 CCE
容器镜像服务 SWR
应用服务网格 ASM
华为云UCS
云容器实例 CCI
管理与监管
云监控服务 CES
统一身份认证服务 IAM
资源编排服务 RFS
云审计服务 CTS
标签管理服务 TMS
云日志服务 LTS
配置审计 Config
资源访问管理 RAM
消息通知服务 SMN
应用运维管理 AOM
应用性能管理 APM
组织 Organizations
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
应用身份管理服务 OneAccess
数据库
云数据库 RDS
文档数据库服务 DDS
数据管理服务 DAS
数据复制服务 DRS
云数据库 GeminiDB
云数据库 GaussDB
分布式数据库中间件 DDM
数据库和应用迁移 UGO
云数据库 TaurusDB
人工智能
人脸识别服务 FRS
图引擎服务 GES
图像识别 Image
内容审核 Moderation
文字识别 OCR
AI开发平台ModelArts
图像搜索 ImageSearch
对话机器人服务 CBS
华为HiLens
视频智能分析服务 VIAS
语音交互服务 SIS
应用中间件
分布式缓存服务 DCS
API网关 APIG
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
多活高可用服务 MAS
事件网格 EG
企业协同
华为云会议 Meeting
云通信
消息&短信 MSGSMS
云生态
合作伙伴中心
云商店
开发者工具
SDK开发指南
API签名指南
Terraform
华为云命令行工具服务 KooCLI
其他
产品价格详情
系统权限
管理控制台
客户关联华为云合作伙伴须知
消息中心
公共问题
开发与运维
应用管理与运维平台 ServiceStage
软件开发生产线 CodeArts
需求管理 CodeArts Req
部署 CodeArts Deploy
性能测试 CodeArts PerfTest
编译构建 CodeArts Build
流水线 CodeArts Pipeline
制品仓库 CodeArts Artifact
测试计划 CodeArts TestPlan
代码检查 CodeArts Check
代码托管 CodeArts Repo
云应用引擎 CAE
开天aPaaS
云消息服务 KooMessage
云手机服务 KooPhone
云空间服务 KooDrive
本文导读

展开导读

设置代码仓库级的合并请求规则

更新时间:2024-11-19 GMT+08:00

合并请求配置是指代码合入条件、合入模式的配置,且项目级的合入请求规则可继承到代码仓库、代码组。

您可以勾选“继承项目设置”,自动继承并使用项目下设置且不支持更改。您也可以进入要配置的代码仓库首页,选择“设置” > “策略设置” > “合并请求”。合并请求有两种机制,打分机制和审核机制,两种模式区别如下:

  • 打分机制,该模式仅包含代码检视,以打分为基础,只有分数达到门禁条件时,代码才可以合入。
  • 审核机制,该模式包含代码检视和合并审核两个步骤,以通过人数为基础,只有检视和审核通过的人数达到门禁条件时,代码才可以合入。

    当您选择合入机制后,参考下表填写其余参数,且该配置对整个代码仓库生效。

    表1 设置合入条件、合入模式的参数表

    参数名称

    参数解释

    合入条件

    此参数非必填,共2个选项:

    • 评审问题全部解决才能合入。勾选后,如果评审意见被勾选为“这是一个需要被解决的问题”,则合入条件会提示“存在未解决的评审意见”“合入”按钮置灰;如果只是一个普通的评审意见,则不存在“已解决”开关,也不会被合入条件拦截。
    • 必须与CodeArts Req关联。包含如下3个子选项:
      1. 只能关联一个单号。勾选后,一个MR只能关联一个单号。
      2. 所有E2E单号校验必须通过。勾选后,被关联的所有E2E单号校验必须通过。
      3. 选择分支配置合并请求策略。可添加多个分支配置合并请求策略,支持手动输入通配符匹配,按回车确认,如:*-stable或production/*。

    MR设置

    该参数非必填。包含如下选项:

    • 禁止合入自己创建的合并请求。勾选后,您在查看自己创建的MR时,“合入”按钮置灰,自己无法合入,需要找其他有合入权限的人合入。
    • 禁止审核自己创建的合并请求。
    • 禁止检视自己创建的合并请求。
    • 允许仓库管理员及项目经理强制合入。
    • 允许合并请求合并或关闭后继续做代码检视和评论。
    • 是否将自动合并的MR状态标记为关闭状态。如果A MR中的包含在A MR中所有Commits,那么当A合并后,则B MR会自动合并。默认B MR会标记为合并状态,可以通过该选项控制将B MR标记为关闭状态。
    • 不能重新打开一个已经关闭的合并请求。默认打开,您可以根据自己的需要打开或关闭。
    • 新建合并请求,默认开启合并后删除源分支。
    • 禁止Squash合并(合入MR时禁止Squash合并)。
    • 新建合并请求,默认开启Squash合并。

    合并模式

    此参数必填,共3个选项:

    • 通过Merge Commit合并。勾选后,每次合并操作都会产生一个merge commit点,只要没有检测到冲突就能够执行合并操作。即不管基线点是不是最新的点,无冲突就可以合并。
      • Squash合并不产生Merge节点:勾选后,squash合并不会产生merge节点。
      • 使用MR合入者生成Merge Commit :勾选后,可用于记录Commit信息。

        使用MR创建者生成Merge Commit: 勾选后,可用于记录Commit信息。

    • 通过Merge commit 合并(记录半线性历史)。勾选后,每次合并操作会记录一个merge commit提交,但是与“通过Merge commit合并”不同,必须基于目标分支最新的commit提交点进行提交,否则会提示开发者进行rebase操作。这种合并模式下可以非常确定一点,如果merge request能够正确构建,合并完成后目标分支也能够正确构建。
    • Fast-forward 合并。勾选后,每次合并操作不会记录一个merge commit提交,且必须基于目标分支最新的commit提交点进行提交,否则会提示开发者进行rebase操作。

设置分支策略

如果您在上述选择“合入机制”“审核机制”,并且想为某个分支配置合并策略,您可以进入要配置的代码仓库首页,选择“设置” > “策略设置” > “合并请求”,单击“新建分支策略”,参考下表填写参数。

单击“新建分支策略”按钮,可以为指定分支或该仓库下的全部分支设置合入策略。

表2 新建分支策略参数说明

参数

说明

分支

该参数必填。下拉框选择您想要设置的分支,支持选择全部分支。

最小检视人数

该参数必填。默认为0,表示无需检视人检视通过,也可通过检视门禁。

最小审核人数

该参数必填。默认为0,表示无需审核人审核通过,也可通过审核门禁。

重置审核门禁

该参数非必填。默认勾选,表示当重新推送代码到MR的源分支时,将MR审核门禁重置。

重置检视门禁

该参数非必填。默认勾选,表示当重新推送代码到MR的源分支时,将MR检视门禁重置。

仅能从以下审核人/检视人中追加审核人/检视人

该参数非必填。勾选后,可配置“追加审核人”名单与“追加检视人”名单,当您想在“审核人”“检视人”的必选名单外追加成员时,只允许从“追加审核人”名单与“追加检视人”名单中追加成员。

开启流水线门禁

该参数非必填。勾选后,合并前需要满足流水线门禁都通过的条件,将CI融入代码开发流程。

合并人

该参数非必填。可配置必选合并人名单,在新建合并请求时,该名单将自动同步至合并请求中。

审核人

该参数非必填。可配置必选审核人名单,在新建合并请求时,该名单将自动同步至合并请求中。

检视人

该参数非必填。可配置必选检视人名单,在新建合并请求时,该名单将自动同步至合并请求中。

说明:

分支策略优先级示例如下:

  • 假设在仓库下有A策略与B策略,它们配置的分支相同,则系统默认使用最新创建的分支策略。
  • 假设在仓库下有A策略与B策略,A策略配置的分支为a分支与b分支,B策略配置的分支为a分支,在发起目标分支为a分支的合并请求时,系统默认使用B策略。

在审核机制下未设置分支策略,则在发起合并请求时使用默认分支策略,该分支策略支持编辑、查看但不可删除,策略配置如下:

  • 分支:*,默认全部分支且不可修改。
  • 最小检视人数:默认为 0。
  • 最小审核人数:默认为 0。
  • 重置审核门禁:默认勾选。
  • 重置检视门禁:默认勾选。
  • 仅能从以下审核/检视人中追加审核人/检视人:默认不勾选。
  • 开启流水线门禁:默认不勾选。
  • 合并人:默认为空。
  • 审核人:默认为空。
  • 检视人:默认为空。
    必选名单举例:
    • 最小审核人数为2人,如果必选审核人名单为空,追加审核人名单2人均审核通过,审核门禁通过。
    • 最小审核人数为2人,如果必选审核人名单非空,则该名单内至少一人审核通过,审核门禁才可通过。

我们使用cookie来确保您的高速浏览体验。继续浏览本站,即表示您同意我们使用cookie。 详情

文档反馈

文档反馈

意见反馈

0/500

标记内容

同时提交标记内容