我正在配置Gerrit
,我想避免写:
git push gerrit HEAD:refs/for/master
我想写:
git push review
我确信可以修改.git/config
,但我无法使其正常工作。
答案 0 :(得分:24)
我设置了两种不同的推送类型,审核和noreview:
评论:
git config remote.review.pushurl ssh://<GERRIT_HOST>:29418/<PROJECT_PATH>.git
git config remote.review.push refs/heads/*:refs/for/*
git push review # this will push your current branch up for review
绕过审核:
git config remote.noreview.pushurl ssh://<GERRIT_HOST>:29418/<PROJECT_PATH>.git
git config remote.noreview.push refs/heads/*
git push noreview # this will push your current branch up, bypassing review
请注意,项目所有者/ Gerrit管理员需要进行一些Gerrit项目更改,以便绕过审核。我认为需要将“推送”权限添加到refs / *的项目中(除非您具体了解哪些分支允许绕过审核)。但是,对于评论,已经设置了发布所需的权限。换句话说,如果你的
git push gerrit HEAD:refs/for/master
正在运作,上面的“评论”部分也应该有效,而不会改变任何其他内容。
答案 1 :(得分:5)
为什么不创建bash别名?
alias review="git push gerrit HEAD:refs/for/master"
现在你可以输入:
review
如果你想要更多而不是一个gerrit分支,请检查我的bash助手:https://github.com/tomwys/gerrit-bash-commands
答案 2 :(得分:4)
你最好做的是别名中的Git scriptlet。像这样的东西基于'上游'分支工作,虽然我想稍微清理一下这个:
[alias]
pub = "!f() { git push -u ${1:-origin} HEAD:`git config branch.$(git name-rev --name-only HEAD).merge | sed -e 's@refs/heads/@refs/for/@'`; }; f"
这样,您只需输入:
即可git pub
就像你打字一样:
git push -u origin HEAD:refs/for/master
或
git push -u origin HEAD:refs/for/myremote-branch
唯一的要求是它只与Windows上的Git Bash shell兼容,或者与许多Linux shell中的一个兼容。
答案 3 :(得分:3)
您可能也对git-review感兴趣,它不仅仅通过提供以下内容来消除push
:
git review
...但也允许你做以下事情:
git review branchname
查看上面链接的“使用情况”部分了解更多信息。
答案 4 :(得分:1)
也许不完全是你想要的,但如果你:
gerrit
重命名为review
(使用git remote rename gerrit review
),git config push.default tracking
和git config branch.master.merge refs/for/master
,然后你可以git push review
,你的主人将被推到refs/for/master
gerrit。
顺便说一句,如果你git config branch.master.remote review
,那么你可以git push
并获得同样的东西。
答案 5 :(得分:1)
如果你想允许直接推送到refs / heads /中的分支你只需在gerrit web gui中添加一个权限:
你完成了。
答案 6 :(得分:0)
那些想要仅通过gerrit推送到主分支的人,请将以下内容添加到.git\config
[remote "review"]
push = HEAD:refs/for/master
pushurl = ssh://GERRIT_URL:29418/PROJECT_NAME
或在项目目录中执行
git config remote.review.push HEAD:refs/for/master
git config remote.review.pushurl ssh://GERRIT_URL:29418/PROJECT_NAME
然后你可以使用
git push review
推向Gerrit。使用此方法,您可以从任何本地分支推送,数据将始终转到主分支
答案 7 :(得分:0)
您只需创建一个简单的脚本来自动执行该过程:
#!/bin/bash
GROUP1_REVIEWER="group1 list of mail separated by space"
GROUP2_REVIEWER="group2 list of mail separated by space"
GROUP3_REVIEWER="group3 list of mail separated by space"
ORIGIN=$(git config --get remote.origin.url)
[ $? -ne 0 ] && echo "Git repo not found; EXIT" && exit 1
case $1 in
group1) REVIEWER_LIST=$GROUP1_REVIEWER ;;
group2) REVIEWER_LIST=$GROUP2_REVIEWER ;;
group3) REVIEWER_LIST=$GROUP3_REVIEWER ;;
*) echo "Please specify one existent group"; exit 1 ;;
esac
[ "$1" == "" ] && echo "Please specify one existent group" && exit 1
pushurl=${ORIGIN}
push="HEAD:refs/for/master"
receivepack="$(printf "git receive-pack "; for reviewer in $REVIEWER_LIST ; do printf -- "--reviewer $reviewer "; done)"
# check if review remote is already present
git config -l | grep remote.review 1>/dev/null 2>&1
[ $? -eq 0 ] && echo "Remote review already present; configure it manually; EXIT" && exit 1
# start config
echo "Adding new remote review config"
git config remote.review.pushurl $pushurl
git config remote.review.push $push
git config remote.review.receivepack "$receivepack"
您将使用:
git_review_add_config.sh group1
然后选择您需要配置的不同组。