Gerrit实际上一个Git服务器,它为在其服务器上托管的Git仓库提供一系列权限控制,以及一个用来作Code Review是Web前台页面。固然,其主要功能就是用来作Code Review。android
Contact Informationgit
ssh-keygen -t rsa cat ~/.ssh/id_rsa.pub
Copy key的内容,在Gerrit帐户的设置页面“SSH Public Key”中加入便可。服务器
ssh-keyssh
登陆Gerrit后在Projects-->List, 选择相应工程your_project,进入该工程的General界面。
选中“clone with commit-msg hook”和“SSH”:工具
git clone ssh://your_account@review.xxxxx.com:29418/your_project && scp -p -P 29418 your_account@review.xxxxx.com:hooks/commit-msg cic-android/.git/hooks/
拷贝以上命令在本身本地Git命令行窗口执行便可拉取库代码。fetch
Gerrit相对Git提供了一个特有的命名空间“refs/for/”用来定义咱们的提交上传到哪一个branch,且能够用来区分咱们的commit是提交到Gerrit进行审核仍是直接提交到Git仓库,格式以下:google
refs/for/<target-branch>
Push一个Commit到Gerrit:spa
$ git commit $ git push origin HEAD:refs/for/master
直接Push一个commit到Git仓库:(咱们默认配置成不容许)插件
$ git commit $ git push origin HEAD:master
当咱们的commit Push到Gerrit等待review时,Gerrit会将此commit保存在一个名为“refs/changes/xx/yy/zz”的一个暂存branch中。
其中zz为这个commit的patch set号,yy是change号,xx是change号的后两位。命令行
例如咱们工程中的这个大明同窗的提交:
http://review.xxxxx.com:9090/#/c/545/
一共提交了9次patch,那么第9个patch就保存在一个名为“refs/changes/45/545/9”的branch中。
能够经过Gerrit页面中该commit右上角的Download按钮验证,好比说咱们选择“Cherry Pick”, 命令以下:
git fetch ssh://your_account@review.xxxxx.com:29418/your_project refs/changes/45/545/9 && git cherry-pick FETCH_HEAD
在此,有必要说下几个概念,以便理解:
Change
一个Change包含一个Change-Id,这个Id就是经过咱们拉取代码库的时候所拷贝的hooks(hooks/commit-msg)自动生成的。
包含一个或多个Patch Set,以及诸如Owner,Project,Target branch,Comments等信息。
Change-Id
Change-Id是一串SHA-1字符串。有hooks自动生成在咱们的commit message下面:
Feature:Music play. BugId:/ Description:Music play. Change-Id: I3d087f04d9d94bfaa93b8609b988b300af537497
在一个project的每一个branch中Change Id是惟一的。
我的Git工做原则一
** 永远是基于远程库的最新代码工做,尽可能每一步操做(特别是add/commit/push)都经过git pull --rebase获取一下当前最新版本。**
根据以上原则,建议在将本地commit push到Gerrit以后,立马reset掉,或者从新切换一个新的分支工做。
当咱们的commit被reviewer打回来时,咱们可能须要修改并从新提交。
若是咱们的代码在本地分支已经reset掉,能够经过Gerrit页面提供的Download方式获取:
// fetch and checkout the change // (checkout command copied from change screen) $ git fetch ssh://your_account@review.xxxxx.com:29418/your_project refs/changes/45/545/9 && git checkout FETCH_HEAD
若是以前是经过切换分支方式工做的,能够从新切换回包含此commit的分支而无需执行上述命令,而后能够在此代码基础上进行修改,从新add,amend commit:
// rework the change $ git add <path-of-reworked-file> ... // amend commit $ git commit --amend // push patch set $ git push origin HEAD:refs/for/master
在Change界面添加相关reviewers.能够考虑使用自动添加reviewers的插件
Change通常配置成只有在Code-Review +2 以及Verified +1 的状况下才能够Submit。
Submit时可能会有冲突,界面会提示“Cannot Merge”字样,此时能够先尝试Gerrit页面提供的Rebase功能作一次Rebase操做,若是提示冲突,则需在本地解决冲突后从新提交一个Patch Set到该Change上。
本地Rebase的一种流程:
// update the remote tracking branches $ git fetch // fetch and checkout the change // (checkout command copied from change screen) $ git fetch ssh://your_account@review.xxxxx.com:29418/your_project refs/changes/74/67374/2 && git checkout FETCH_HEAD // do the rebase $ git rebase origin/master // resolve conflicts if needed and stage the conflict resolution ... $ git add <path-of-file-with-conflicts-resolved> // continue the rebase $ git rebase --continue // push the commit with the conflict resolution as new patch set $ git push origin HEAD:refs/for/master
Code Review须要时间,开发人员能够在此期间开发其余feature,这就产生了多feature并行开发的状态。
为了保证减小冲突和依赖,每个feature都应该是在该feature本身的本地分支开发,且此分支是基于远程分支(target branch)的当前HEAD的。 也就是基于远程库的最新代码开发,而不该该依赖于code review中的某个、某些Change。
固然,若是必要,你也能够基于一个正在code review的Change开发新的feature,这样会产生依赖,能够在Gerrit中该Change的页面看到“Related Changes”。这就要求reviewer也须要关注这个依赖关系,调整review时序。
根据以往的使用经验,强烈建议不要产生这种依赖,尽可能使每个Change提交都是无依赖的,避免Change的连环失败致使各类解冲突的工做。
我的Git工做原则二
** 尽量保证每个Change的完整性以及独立性,且越小越好。**
Gerrit提供了直接在Web页面修改咱们的patch代码的功能,这对于咱们作一些小的问题修改(好比格式化问题,命名不对,多余的空格等)很是方便。
Edit
点击Edit后,该工具栏显示以下:
toolbar
能够在此对patch的文件进行修改,删除等。
若是想对文件中的某处进行编辑,点击进入该文件的review界面:
page_edit
点击编辑按钮,进入编辑模式,编辑完save:
save
会在Change页面看到,点击Publish Edit按钮,Gerrit会自动帮你生成一个包含刚刚修改的patch。
publish
patch
Gerrit能够做为一个本身的Change草稿箱,咱们能够将一些还未完成,或者还不想提交review的Change上传至此处。一来能够做为一个备份,另外在多人互相协助完成同一个功能,或是本身在多台电脑(家里、办公室)上处理未完成的工做。
不一样于提交一个正式Change的“refs/for/”协议,提交一个Change到草稿箱的协议方式为“refs/drafts/”,以下:
$ git commit $ git push origin HEAD:refs/drafts/luckyair
在Gerrit页面的Drafts栏:
draft
草稿箱中的Change也能够很方便的转换为正式的Change,而无需从新用“refs/for/”来提交,点击Publish按钮转换为正式Change,也能够在此删除此草稿。
publish draft
做者:anly_jun 连接:https://www.jianshu.com/p/b77fd16894b6 來源:简书 著做权归做者全部。商业转载请联系做者得到受权,非商业转载请注明出处。