Git Gerrit Repo User Manual
Git Repo Gerrit User Manual
Revision History
|
Revision # |
Description |
Date |
Author |
|
0.1 |
Initial this document |
2014/09/05 |
Deman Lu |
|
0.2 |
Add First time push Code to Gerrit |
2014/09/09 |
Deman Lu |
|
0.21 |
Add FAQ |
2014/09/09 |
Deman Lu |
Contents
Preparation....................................................................................................................... 4
Install............................................................................................................................... 4
Git Setup:.................................................................................................................. 4
Git Config:................................................................................................................ 4
Set Commit Template:................................................................................................. 4
Set git ignore............................................................................................................. 4
Install Repo................................................................................................................ 5
Gerrit Config:............................................................................................................ 5
Get First Project................................................................................................................ 7
FAQ................................................................................................................................. 8
No Branch Ready For Upload Error.......................................................................... 8
CONFLICT Error..................................................................................................... 8
Upload Merges
Error................................................................................................ 9
Repo init Error......................................................................................................... 9
Repo syntax error near unexpected token `newline'................................................... 9
Repo init Connect Error:.......................................................................................... 9
Everything up-to-date:........................................................................................... 9
Preparation
OS: Linux or Ubuntu
Software: Git, SSH, Repo
Install
Git Setup:
$ sudo apt-get install git
$ sudo apt-get install git-core
$ git version // version >= 1.6
Git Config:
$ git config --global user.name "deman_lu"
将user name为你gerrit系统的账号(邮箱地址(全小写的前缀))
$ git config --global user.email "deman_lu@htc.com"
将user email设置成你htc的邮箱(邮箱地址全小写)
$ git config --global core.editor vim
$ git config --global merge.tool vimdiff
$ git config --global color.ui
"auto"
Set Commit Template:
$ vim ~/.git-template
Symptom:
Bug ID:
Root Cause:
Solution:
Note:
$ git config --global commit.template
~/.git-template
Set git ignore
$ vim ~/.gitignore
$ git config --global core.excludesfile
~/.gitignore
Install Repo
$ cd
$ mkdir bin
$ cd bin
$ PATH=~/bin:$PATH
$ curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo
> ~/bin/repo
If you can’t connect google, you can copy
repo from:
\\10.33.8.3\cht000\CHT200\CHT210\CHT211\Trainning\
COS_Android\Git&Repo\bin
$ chmod a+x ~/bin/repo
Gerrit Config:
Gerrit Web: http://10.33.137.230/project/
Add public Key:
$ ssh-keygen -t rsa
If you have
ssh key, you can use
it directly。
$ cat ~/.ssh/id_ras.pub
Select [Setting] ==> [SSH Public Key]
Press Add key, and paste your id_rsa.pub content into edit text then added.
Add Server host key to known_hosts:
$ vim ~/.ssh/known_hosts
Paste the host key from below image showing
to known_hosts.
$ vim ~/.ssh/config
host gerrit
user deman_lu
hostname 10.33.137.230
port 29418
identityfile ~/.ssh/id_rsa
$ ssh gerrit
**** Welcome to Gerrit Code
Review ****
Hi
Deman_Lu, you have successfully connected over SSH.
Unfortunately, interactive shells are disabled.
To
clone a hosted Git repository, use:
git
clone ssh://deman_lu@10.33.137.230:29418/REPOSITORY_NAME.git
Connection to 10.33.137.230 closed.
If you want to see more detail:
http://10.116.121.47/mediawiki/index.php/Git_Repo_Gerrit_User_Manual
Get First Project
Using following command to get repository.
$ repo init -u
ssh://deman_lu@10.33.137.230:29418/manifest.git -m
team1.xml
The highlight is the manifest.xml,please connect Administrator to get
your manifest.xml
If you just want to do some practices, you
can ignore it and it will download default project.
$ repo sync
$repo forall -c "git checkout -b
master origin/master"
This will create branch master and connect
origin branch origin/master.
Thus, you can push your code to
origin/master
$ repo upload
--re=bill_tan,deman_lu
FAQ
No Branch Ready For Upload Error
Check if it is in some branch
$ git branch
If no branch, change to master branch.
$ git checkout master
Modify some files and commit
$ repo upload --re=<User Name>
After doing below thing, you also meet
these error:
Clean the repo and delete ~/.repoconfig
Please according to “Git First Project” step
by step.
CONFLICT Error
hailong@hailong-Lenovo:~/test/localhost/gerrit/repo/test$
repo sync
remote: Counting objects: 5, done
remote: Finding sources: 100% (3/3)
remote: Total 3 (delta 2), reused 3 (delta
2)
Unpacking objects: 100% (3/3), done.
From ssh://localgerrit:29418/new/test
fdcfcac..5f7a5f9 master -> origin/master
project test/
First, rewinding head to replay your work
on top of it...
Applying: m_cm_6.2
Using index info to reconstruct a base
tree...
Falling back to patching base and 3-way
merge...
Auto-merging readme.txt
CONFLICT (content): Merge
conflict in readme.txt
Recorded preimage for 'readme.txt'
Failed to merge in the changes.
Patch failed at 0001 m_cm_6.2
You should manual merge file when repo
sync.
$ git add readme.txt
$ git rebase --continue
Upload
Merges Error
When repo upload: ![remote rejected] master ->
refs/for/master (you are not allowed to upload merges)
Reason: you have doing some merge but
gerrit not allow.
Solution: reset your merge and using git
rebase to commit.
$ git reset --hard <commit id>
$ git fetch
$ git rebase origin/master
$ repo upload --re=<User Name>
Repo init
Error
Repo int: fatal: Cannot get https://code.google.com/p/git-repo/clone.bundle
fatal: error [Errno 104] Connection reset
by peer
Solution: $ vim ~/bin/repo modify
REPO_URL='http://android.googlesource.com/tools/repo'
Repo syntax error near unexpected token `newline'
/root/bin/repo: line 1: syntax error near
unexpected token `newline'
/root/bin/repo: line 1: `<!DOCTYPE html>'This problem is that repo’s
version is too old, using a new one.
$ curl
http://git-repo.googlecode.com/files/repo-1.12> ~/bin/repo
Or copy repo file form other members.
Repo init Connect Error:
fatal: Cannot get
https://gerrit.googlesource.com/git-repo/clone.bundle
fatal: HTTP error 403
When repo init, repo will download code
from google, so, the reason is you known.
Please try more times or do it later.
Everything up-to-date:
$ git push showing :every thing up to date,
but you also have not push anthing!
$ git push origin master : this will be
denied by gerrit, you can’t push code to git repository directly.
We must push to review repository:
$git push origin HEAD:refs/for/master
Git Gerrit Repo User Manual的更多相关文章
- How to get started with GIT and work with GIT Remote Repo
https://www.ntu.edu.sg/home/ehchua/programming/howto/Git_HowTo.html#zz-7. 1. Introduction GIT is a ...
- Git和Repo管理使用简要介绍
在Linux平台下进行Android系统项目开发时,需要Git或repo管理. 一. Git和Repo的区别: 1. Git:Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的 ...
- Git和Repo管理使用
Git和Repo管理使用简要介绍 http://blog.csdn.net/stevenhu_223/article/details/8828130 多仓库代码管理器Repo的安装,使用以及服务器搭建 ...
- 常用的git和repo命令
首先下图是git的流程图 相关概念 svn与git命令的对比 git常用命令 git log // 查看当前库的git log信息 git status ./ // 查看当前库的状态 git diff ...
- Git与Repo入门(转载)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAykAAADuCAIAAACyDd+sAAAAA3NCSVQICAjb4U/gAAAgAElEQVR4Xu ...
- 【转】Android源码学习(2)使用Git和Repo进行版本管理
原文网址:http://blog.chinaunix.net/uid-26074270-id-2458828.html Android项目采用Git和Repo进行版本管理.在大多数情况下,Git都可以 ...
- 【转】Git与Repo入门----不错
原文网址:http://www.cnblogs.com/angeldevil/p/3238470.html Git与Repo入门 版本控制 版本控制是什么已不用在说了,就是记录我们对文件.目录或工 ...
- Git Gerrit使用
Git Gerrit 操作都用 git bash操作: 如果想用 cmd 或者 PowerShell,系统环境变量 Path 添加 Git 安装路径,如: C:\Program Files (x86) ...
- Git 和 Repo常用命令
这篇博客总结的也不错: git常用及进阶命令总结 Git与Repo入门 一.初始環境配置 git config --global user.name "John Doe"git c ...
随机推荐
- asp.net self host and urlacl(解决UnHandledException Message:拒绝访问的问题)
命令提示符(管理员权限)需要添加的代码: netsh http add urlacl url=http://*:9999/ user=Everyone listen=yes 其中: url:代码中的u ...
- oracle-11g-64位安装和plaql
1.oracle卸载 如果是新装,请跳过此步骤 卸载步骤: 1.停止所有服务 2.用自带删除软件,删除所有目录 3.打开注册表: -->运行regedit,删除HKEY_LOCAL_MACHIN ...
- MySQL优化Explain命令简介(二)
type列 MySQL手册上注明type列用于描述join type,不过我们认为把这一列视为对access type--即MySQL决定如何在表中寻找数据的方式的描述,更加合适一些,以下所示从最坏情 ...
- [2016北京集训测试赛5]azelso-[概率/期望dp]
Description Solution 感谢大佬的博客https://www.cnblogs.com/ywwyww/p/8511141.html 定义dp[i]为[p[i],p[i+1])的期望经过 ...
- HBase常用命令汇总——综述(一)
hbase(main):009:0> help HBase Shell, version 1.2.4, r67592f3d062743907f8c5ae00dbbe1ae4f69e5af, Tu ...
- RHCSA day5
4.调整逻辑卷容量 请按照以下要求调整本地逻辑卷lvm1的容量: 调整后的逻辑卷及文件系统大小为770MiB 调整后确保文件系统中已存在的内容不能被破坏 调整后的容量可能出现误差,只要在730MiB ...
- 【BZOJ4560】[NOI2016]优秀的拆分
[BZOJ4560][NOI2016]优秀的拆分 题面 bzoj 洛谷 题解 考虑一个形如\(AABB\)的串是由两个形如\(AA\)的串拼起来的 那么我们设 \(f[i]\):以位置\(i\)为结尾 ...
- GBDT为什么不能并行,XGBoost却可以
传统的GBDT是以CART作为基分类器,xgboost还支持线性分类器,这个时候XGBOOST相当于带L1和L2正则化的逻辑斯蒂回归(分类问题)或者线性回归(回归问题).传统的GBDT在优化的hih只 ...
- jquery.validate使用 - 5
一些常用的验证脚本 不会写js了,只能从网上找一些常用的验证脚本. // 手机号码验证jQuery.validator.addMethod("mobile", function(v ...
- 查询表的大小(mysql)
--所有表的大小 select concat(round(sum(DATA_LENGTH/1024/1024),2),'M') from information_schema.tables where ...