[技术博客]在团队中使用Pull Request来管理代码
在团队中使用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来管理代码的更多相关文章
- 【技术博客】Django中文件下载的实现
开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. Django中文件下载的实现 1.背景 在VisualPy ...
- 40个国人iOS技术博客
40个国人iOS技术博客 博客地址 RSS地址 OneV's Den http://onevcat.com/atom.xml 破船之家 http://beyondvincent.com/atom.xm ...
- 转: BAT等研发团队的技术博客
BAT 技术团队博客 1. 美团技术团队博客: 地址: http://tech.meituan.com/ 2. 腾讯社交用户体验设计(ISUX) 地址:http://isux.tencent.c ...
- C++中实现对map按照value值进行排序 - 菜鸟变身记 - 51CTO技术博客
C++中实现对map按照value值进行排序 - 菜鸟变身记 - 51CTO技术博客 C++中实现对map按照value值进行排序 2012-03-15 15:32:36 标签:map 职场 休闲 排 ...
- 【技术博客】JWT的认证机制Django项目中应用
开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. JWT的认证机制Django项目中应用 这篇技术博客基于软 ...
- [技术博客] Django中文件的保存与访问
[技术博客] Django中文件的保存与访问 在TextMarking项目开发中,数据库需要保存用户上传的文本文档. 原型设计:用户点击上传文本->保存文本->文本发送到后端保存为文件. ...
- 【转】【技术博客】Spark性能优化指南——高级篇
http://mp.weixin.qq.com/s?__biz=MjM5NjQ5MTI5OA==&mid=2651745207&idx=1&sn=3d70d59cede236e ...
- 作业一:创建个人技术博客、自我介绍、简单的C程序
年9月14日中午12点: 一.主要内容 建个人技术博客(博客园 www.cnblogs.com) 本学期将通过写博客的方式提交作业,实际上,最终的目的是希望同学们能通过博客的形式记录我们整个学习过程 ...
- [转]有哪些值得关注的技术博客(Java篇)
有哪些值得关注的技术博客(Java篇) 大部分程序员在自学的道路上不知道走了多少坑,这个视频那个网站搞得自己晕头转向.对我个人来说我平常在学习的过程中喜欢看一些教程式的博客.这些博客的特点: 1. ...
随机推荐
- noip模拟21
开题发现这场考过,定睛一看,发现是省选前最后一场,没改过呀--但是还是讲武德的赛时没提交 A. Median 神奇之处在于 \(1e7\) 个质数居然能线性筛出来~ 那么 \(S2\) 可以直接筛出来 ...
- Hash值和位运算
一.Hash 1.md5是hash算法,不可逆,还原的是暴力穷举的方式解析的:加盐之后穷举也不能还原: 2.压缩映射会有重复,即哈希冲突: 二.ConcurrentHashMap 1.putIfAbs ...
- Typeora 图床设置
Typeora 文章中的图片 使用 Github 作为图床. 使用 PicGo 上传图片到 Github 并获取图片链接. 设置 Typeora 的上传服务. 一.Github 作为图床 创建 Rep ...
- MapReduce 示例:减少 Hadoop MapReduce 中的侧连接
摘要:在排序和reducer 阶段,reduce 侧连接过程会产生巨大的网络I/O 流量,在这个阶段,相同键的值被聚集在一起. 本文分享自华为云社区<MapReduce 示例:减少 Hadoop ...
- 洛谷P1309——迷宫(傻瓜DFS)
题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和 终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫 中移动有上下 ...
- 【PHP数据结构】链表的其它形式
在上篇文章中,我们已经说过了链表除了简单的那一种单向链表外,还有其它的几种形式.当然,这也是链表这种结构的一大特点,非常地灵活和方便.我们简单的想一想,如果让最后一个节点的 next 指回第一个节点, ...
- use关键字在PHP中的几种用法
在学习了和使用了这么多年的PHP之后,您知道use这个关键字在PHP中都有哪些用法吗?今天我们就来看一下它的三种常见用法. 1. 用于命名空间的别名引用 // 命名空间 include 'namesp ...
- prometheus、node_exporter设置开机自启动
方法一.写入rc.local 在/etc/rc.local文件中编辑需要执行的脚本或者命令,我个人习惯用这个,因人而异,有的项目可能需要热加载配置文件,用服务会更好 #普罗米修斯启动,需要后面接con ...
- python学习笔记(十四)python实现发邮件
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart u ...
- Appium自动化测试时为什么要自己封装find方法
官方的find_element方法不能很好地处理异常,所以自行封装,以智能化处理各种异常