检测到您已登录华为云国际站账号,为了您更好的体验,建议您访问国际站服务网站 https://www.huaweicloud.com/intl/zh-cn
不再显示此消息
工作流概述 Git工作流不仅可以进行版本控制,还可以管理项目流程和团队协同开发,有效提高项目管理水平和团队协同开发能力。在实际应用中,有必要根据团队的需求和工作流程,选择合适的Git工作流,实现持续集成、持续交付和快速迭代的目标。 下面介绍如下工作流的工作方式、优缺点,以及使用中的一些注意事项。
功能分支工作流 功能分支工作流允许团队在不影响主分支(通常是“master”或“main”)的情况下,独立开发新功能或修复bug。这种工作流的核心是使用分支来管理不同的开发阶段,从而提高团队的协作效率和代码质量。 功能分支工作流优点 并行开发。支持团队成员在不影响主分支的情况下独立开发新功能或修复问题。
子模块中代码更新、在线或本地Git客户端中推送代码更新均会触发该事件。 Tag推送事件 在代码托管仓库新建或删除Tag会触发该事件。 合并请求事件 在代码托管仓库新建合并请求会触发该事件。 在代码托管仓库更新合并请求会触发该事件。如更新代码内容/更新合并请求状态(关闭、重开)/更
更改代码组名称会影响仓库克隆地址,需检查和更新相关配置,否则影响使用,请谨慎操作。 如果代码组下仓库配置了相关流水线,修改代码组名称后,流水线将无法触发,需同步更新流水线相关配置(执行计划和流水线源),具体可参考的“配置流水线”章节。 更改代码组名称后,代码构建、代码检查、部署、CodeArts
解决方案 方案一:通过项目代码托管设置-成员同步 开启后,自动同步所选角色项目成员至代码组及仓库(项目成员有变动时触发),项目经理不依赖开关始终同步,可单击刷新按钮触发一次全量同步。 方案二:通过成员组进行成员管理。 操作步骤如下: 在项目里定义成员组。 通过代码组对仓库进行分层管理,代码组下建仓库。
禁止新增二进制文件(对特权用户无效)。 允许修改二进制文件(对特权用户无效)。 二进制文件白名单(可直接入库的文件,限制2000个字符)。 特权用户(特权用户上限为50人)。 说明: 如果特权用户已经不是仓库成员,单击保存会提示“特权用户校验失败”,需要将非仓库成员的特权用户移除才能保存成功。
集中式工作流 集中式工作流适合刚从SVN工具转型为Git的小型团队。集中式工作流的开发都在一个中心仓库进行,开发者从中心仓库克隆代码仓库,开发完成后,将代码推送到中心仓库。 集中式工作流优点 中央管理。所有的代码仓都存储在一个中心仓库,方便管理和维护代码。 高效协作。团队成员可以通过中央仓库进行代码的共享和协作。
merge_requests_events Boolean 是否触发merge_requests_events事件 note_events Boolean 是否触发note_events事件 pipeline_events Boolean 是否触发pipeline_events事件 project_id
门禁的开启/关闭 进入目标仓库,单击“设置 > 策略设置 > 合并请求”。 配置门禁。 勾选合入条件下的“评审问题全部解决才能合入”,单击“提交”保存设置,门禁开启。 取消勾选合入条件下的“评审问题全部解决才能合入”,单击“提交”保存设置,门禁关闭。 门禁触发的效果 该合并请求的检视人或审核人
禁止新增二进制文件(对特权用户无效)。 允许修改二进制文件(对特权用户无效)。 二进制文件白名单(可直接入库的文件,限制2000个字符)。 特权用户(特权用户上限为50人)。 说明: 如果特权用户已经不是仓库成员,单击保存会提示“特权用户校验失败”,需要将非仓库成员的特权用户移除才能保存成功。
Boolean 是否触发merge_requests_events事件 issues_events Boolean 是否触发issues_events事件 note_events Boolean 是否触发note_events事件 pipeline_events Boolean 是否触发pipeline_events事件
配置代码提交规则 配置代码仓库级的提交规则 CodeArts Repo支持为代码的提交建立校验、限制规则,以确保代码质量,您可以勾选“继承项目设置”,自动继承并使用项目下设置且不支持更改。 您也可以进入要配置的代码仓库首页,选择“设置” > “策略设置” > “提交规则”,单击“
配置代码仓库级的权限 仓库权限矩阵仅支持管理员修改,项目管理员及各层父级代码组和仓库所有者可作为管理员。在确认您是管理员的前提下,进入代码托管首页,单击要设置的代码仓名称,进入代码仓的详情页,单击导航栏的“成员”,可为代码仓添加成员。完成代码仓的成员配置,单击导航栏的“设置”,进入仓库设置页面,选择“安全管理”
仓库总容量规格 仓库容量(含LFS,超出容量限制会导致仓库部分功能无法使用,如代码无法上传) <=10GB <=50GB <=100GB <=500GB 仓库数量规格 仓库数量 不限制 不限制 不限制 不限制 浏览器 类型 目前适配的主流浏览器类型包括: Chrome(推荐) IE10以上
请求中。 分支策略优先级示例如下: 假设在仓库下有A策略与B策略,它们配置的分支相同,则系统默认使用最新创建的分支策略。 假设在仓库下有A策略与B策略,A策略配置的分支为a分支与b分支,B策略配置的分支为a分支,在发起目标分支为a分支的合并请求时,系统默认使用B策略。 在审核机制
配置项目级的Repo权限 登录CodeArts Repo首页,并在左侧导航栏,选择“设置” > “通用设置” > “权限管理”,进入设置权限的页面。 选择对应的“角色” > “代码托管”, 单击“编辑”,可设置角色的权限。 项目经理和其他具有管理权限的用户,可以在该页面修改不同角色在项目下的默认操作权限。
成员同步”,勾选需要同步的角色,打开“同步项目成员”后,将自动同步所选角色项目成员至代码组及仓库,项目经理不依赖开关始终同步,可单击刷新按钮触发一次全量同步。 打开“同步项目成员”开关,更新项目成员时才会触发自动同步。 手动添加项目成员到代码组或仓库 进入要设置的代码组或者代码仓库首页,选择“成员”,单击“添加成员”,弹出添加成员页面,两种方式:
https账号密码校验 判断用户使用 https 上传/下载代码时输入的用户名和密码是否合法。 WebHook 接口 说明 查询指定仓库的webhook 获取仓库webhook。 为指定仓库添加hook 提交代码自动触发编译构建,添加仓库钩子。 删除指定仓库的 hook 提交代码自动触发编译构建,删除仓库钩子。
提交统计:按不同维度(每周、每天、每小时)统计代码提交活跃度。 仓库成员可以触发代码贡献度统计与语言比例统计。 因资源限制,每个仓库一天可以统计10次。 每个用户一天可以统计1000次。 统计完成,将显示每一位用户在截止时间之前的全部新增、删除的代码行数量(“+”表示新增,“-”表示删除)。
到“执行计划”页签。 开启“合并请求时触发”,根据实际情况勾选以下的一种触发事件。 新建:合并请求创建时触发。 更新:合并请求内容或设置更新时触发。 合并:合并请求合入时触发,该事件会同时触发代码提交事件。 重新打开:合并请求重新打开时触发。 完成流水线任务其他信息配置,单击“保存”。