在团队中使用Pull Request来管理代码

前言

在参加多人共同开发项目,且选用Git作为代码托管工具的时候,我们不免会遇到分支冲突、覆盖、合并等问题。显然,因为同一个仓库是属于大家的,所以每个人都有权限向仓库中push或者pull数据。但是这样难免会带来混乱,在人数较多的时候,更是容易出现问题。

目前,在很多团队项目中,都使用Pull Request(GitLab称为Merge Request)来进行Code Review。Pull Request是一种有效的管理源代码的方式,尤其是在许多人一起贡献源代码的时候,显得尤为重要。

Pull Request的优点:

  • Auto Merge功能。哪怕两份代码并非在最新的master分支情况下进行修改,Pull Request也会智能识别,将多份来自于不同分支的代码进行合并。
  • Code Review功能。开发者提交上去的代码可由管理者进行复审。复审过程中出现的任何问题,可以直接在commit中进行指出,也可以引用相关代码行来指出问题,交流方便。
  • 与Issue的绑定功能。Pull Request可以与Issue进行绑定,相当于指定了完成某个Issue所修改的代码,在回顾时可以较为清晰的看到代码变化。

下面,将介绍Pull Request模式的工作流程。

提出需求

所有的任务、需求、Bug修复都以Issue的形式呈现。管理员、开发者、测试员等都可以创建Issue。

Github的创建Issue界面如图所示,左侧主要填写需求的具体内容,支持Markdown。

右侧可以将需求直接指派给某位开发者。如果不指派,开发者也可以选择认领任务。

右下角有Linked Pull Request,可以将与该Issue相关的Pull Request与此Issue构建联系,若Pull Request通过,则代表该Issue被完成。

开发者操作

在该工作模式下,master分支是受保护的——任何开发者都无权直接修改master分支,哪怕是管理员也不应当对master分支进行直接修改,否则会造成混乱。

那么,如果开发者想要修改master分支中的内容怎么办呢?

  • 从master分支创建出去一个属于自己的分支,用作开发者自己进行调试的开发环境。

    开发分支的建议命名格式:操作者姓名--操作内容,如guojun--add-readme。千万不要命名为dev1,dev2这种毫无信息量的名字,否则修改记录将难以追溯!

    (master) git checkout -b guojun--add-readme
  • 修改开发分支中的内容,本地测试,push到开发分支。

    (guojun--add-readme) git add --all
    (guojun--add-readme) git commit -m "add README.md"
    (guojun--add-readme) git push -u origin guojun--add-readme
  • 最重要的一步,提交Pull Request到master分支

你可以输入一些关于这个PR的说明,以供其他人进行Review。

PR上传之后,等着组内专门的Reviewers来进行Review吧。

对于不同的仓库,例如前端、后端等,Reviewers可以是测试人员,也可以是PM。

代码复审

我们切换到Reviewers界面。

此时,Reviewers若对代码不满,可以在对应的代码出标出,让开发人员继续修改。若没有问题,且出现图中绿色的画面(和基础分支不冲突),则可以进行Merge。

恭喜!这样代码就Merge完成了。一般情况下,需要删掉PR所创建的开发分支。

另外,如果Merge过程中出现冲突,如多个PR修改了同一份文件,GitHub还提供网页版编辑器供Reviewer去选择应该保留哪些、不保留哪些。

以上就是开发者进行源代码修改的整个过程。

[技术博客]在团队中使用Pull Request来管理代码的更多相关文章

  1. 【技术博客】Django中文件下载的实现

    开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. Django中文件下载的实现 1.背景 在VisualPy ...

  2. 40个国人iOS技术博客

    40个国人iOS技术博客 博客地址 RSS地址 OneV's Den http://onevcat.com/atom.xml 破船之家 http://beyondvincent.com/atom.xm ...

  3. 转: BAT等研发团队的技术博客

    BAT 技术团队博客   1. 美团技术团队博客:  地址: http://tech.meituan.com/ 2. 腾讯社交用户体验设计(ISUX) 地址:http://isux.tencent.c ...

  4. C++中实现对map按照value值进行排序 - 菜鸟变身记 - 51CTO技术博客

    C++中实现对map按照value值进行排序 - 菜鸟变身记 - 51CTO技术博客 C++中实现对map按照value值进行排序 2012-03-15 15:32:36 标签:map 职场 休闲 排 ...

  5. 【技术博客】JWT的认证机制Django项目中应用

    开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. JWT的认证机制Django项目中应用 这篇技术博客基于软 ...

  6. [技术博客] Django中文件的保存与访问

    [技术博客] Django中文件的保存与访问 在TextMarking项目开发中,数据库需要保存用户上传的文本文档. 原型设计:用户点击上传文本->保存文本->文本发送到后端保存为文件. ...

  7. 【转】【技术博客】Spark性能优化指南——高级篇

    http://mp.weixin.qq.com/s?__biz=MjM5NjQ5MTI5OA==&mid=2651745207&idx=1&sn=3d70d59cede236e ...

  8. 作业一:创建个人技术博客、自我介绍、简单的C程序

    年9月14日中午12点: 一.主要内容  建个人技术博客(博客园 www.cnblogs.com) 本学期将通过写博客的方式提交作业,实际上,最终的目的是希望同学们能通过博客的形式记录我们整个学习过程 ...

  9. [转]有哪些值得关注的技术博客(Java篇)

    有哪些值得关注的技术博客(Java篇)   大部分程序员在自学的道路上不知道走了多少坑,这个视频那个网站搞得自己晕头转向.对我个人来说我平常在学习的过程中喜欢看一些教程式的博客.这些博客的特点: 1. ...

随机推荐

  1. 推荐一款编程字体:Iosevka

    最近发现一款很好用的编程字体:Iosevka.它是一款现代化的编程字体集合,除了等宽.oO0 iIl1明显区分等基本特性外,还有很多非常现代的特性,比如: 多种风格:有非常多的字形可供选择,衬线/非衬 ...

  2. 远程线程注入DLL突破session 0 隔离

    远程线程注入DLL突破session 0 隔离 0x00 前言 补充上篇的远程线程注入,突破系统SESSION 0 隔离,向系统服务进程中注入DLL. 0x01 介绍 通过CreateRemoteTh ...

  3. ☕【JVM技术指南】「JVM总结笔记」Java虚拟机垃圾回收认知和调优的"思南(司南)"【下部】

    承接上文 (完结撒花1-52系列)[JVM技术指南]「JVM总结笔记」Java虚拟机垃圾回收认知和调优的"思南(司南)"[上部] 并行收集器 并行收集器(也称为吞吐量收集器)是类似 ...

  4. ASP.NET Core Web API 教程 - Project Configuration

    ASP.NET Core Web API 教程 本系列文章主要参考了<Ultimate ASP.NET Core 3 Web API>一书,我对原文进行了翻译,同时适当删减.修改了一部分内 ...

  5. 安卓学习记录(四)——体温表APP

    1.新建project file->new->new project,选择Basic Activity 2.在content_main.xml中添加一个List View 1 <Li ...

  6. 学习PHP中好玩的Gmagick图像操作扩展的使用

    在 PHP 的图像处理领域,要说最出名的 GD 库为什么好,那就是因为它不需要额外安装的别的什么图像处理工具,而且是随 PHP 源码一起发布的,只需要在安装 PHP 的时候添加上编译参数就可以了. G ...

  7. 宝塔面板使用PM2命令提示Command Not Found解决方案

    1.查看node版本 进入/www/server/nvm/versions/node 查看node版本 2.复制以下代码 以node版本v12.18.1举例 PATH=$PATH:/www/serve ...

  8. webpack4 使用babel处理ES6语法的一些简单配置

    一,安装包 npm install --save-dev babel-loader @babel/corenpm install @babel/preset-env --save-devnpm ins ...

  9. Shell系列(3)- 命令别名

    前言 使用alias命令创建命令别名,是Bash的一个基本功能:别名有两种形式,一种暂时的,Linux重启后失效.另外一种永久的通过该配置文件实现 使用更改别名 临时 命令格式:alias 别名='原 ...

  10. Linux系列(38) - 源码包安装(2)

    安装前准备 安装C语言编译器"gcc" yum -y install gcc --c 源码包语言编译器 下载源码包 安装注意事项 源代码保存位置:/usr/local/src/ 软 ...