HEAD的git别名:refs / for / master

时间:2011-09-14 22:46:25

标签: git gerrit

我正在配置Gerrit,我想避免写:

git push gerrit HEAD:refs/for/master

我想写:

git push review

我确信可以修改.git/config,但我无法使其正常工作。

8 个答案:

答案 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。像这样的东西基于'上游'分支工作,虽然我想稍微清理一下这个:

〜/的.gitconfig

[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)

也许不完全是你想要的,但如果你:

  1. gerrit重命名为review(使用git remote rename gerrit review),
  2. git config push.default tracking
  3. git config branch.master.merge refs/for/master
  4. 然后你可以git push review,你的主人将被推到refs/for/master gerrit。

    顺便说一句,如果你git config branch.master.remote review,那么你可以git push并获得同样的东西。

答案 5 :(得分:1)

如果你想允许直接推送到refs / heads /中的分支你只需在gerrit web gui中添加一个权限:

  1. 打开项目属性,
  2. 选择访问权,
  3. 添加参考,
  4. refs / heads / *
  5. 选择“推送”
  6. 输入组名称,
  7. refs / heads / *
  8. 保存。
  9. 你完成了。

答案 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

然后选择您需要配置的不同组。