如何总是从gerrit中挑选最新版本的评论?

时间:2016-10-31 14:41:20

标签: git gerrit cherry-pick

是否有一种可编写脚本的方式来挑选最新版本的gerrit补丁评论?

在Gerrit界面上,您可以轻松复制樱桃选择的代码,但是此代码指定了特定版本,我对一些选择最新版本而不是特定版本的bash代码感兴趣。

git fetch https://review.gerrithub.io/org-name/project-name refs/changes/02/12345/5 && git cherry-pick FETCH_HEAD

如您所见,这将选择第5版。

更新

git review -s
git review -x 123456

我在本地尝试了审核-x方法但它运行但是从Jenkins运行的那些方法失败了:

Could not connect to gerrit.
Enter your gerrit username: <traceback object at 0x285ecf8>
We don't know where your gerrit is. Please manually create a remote
named "gerrit" and try again.

2 个答案:

答案 0 :(得分:2)

git-review工具让这很容易。它使用gerrit API查找给定评论的最新变更集。

例如,您可以运行...

git review -x 12345

...樱桃挑选最新版本的命名更改到您当地的分支机构。还有一个-d选项,它将更改公开为新分支,这对于在本地查看内容非常有用。

它也是提交更改的有用工具。

如果您不想使用git-review,您显然可以自己使用Gerrit API来查找最新变更集的相应参考。例如:

ssh -p <gerrit_port> <gerrit_user>@<gerrit_host> gerrit query --current-patch-set --format json <review_number>

这为您提供了一大块JSON来描述给定的更改,包括有关当前补丁集的信息。您可以通过将JSON管道化为:

来提取它
jq -r .currentPatchSet.ref

一个完整的示例,使用git-review项目本身:

$ ssh -p 29418 lars@review.openstack.org \
  gerrit  query --current-patch-set --format json 281504 \
  | head -1 | jq -r .currentPatchSet.ref
refs/changes/04/281504/8

<强>更新

使用git命令还有另一种方法可以做到这一点。您可以将git ls-remote命令用于远程引用列表,这可能类似于:

$ git ls-remote https://review.gerrithub.io/org-name/project-name
211fd8c368d27a0c64ad260b8556ab11211b071a        refs/changes/00/328300/1
f9a4f3206fa9746acc3aac044cd4ae8b31763186        refs/changes/00/328300/2
3c89f1432aed33514e57bf40764605675fc0e782        refs/changes/00/328300/3
cdf0b56f07009e0d87b605b98257fdb6352ff235        refs/changes/00/328300/4
6b8ef89aed4470be7a230412f0c73f7cce429eda        refs/changes/00/328300/5
640f49347b19bec17360b613014e7af67054e2c8        refs/changes/00/328300/6
a45f2e9b05459faecdda8979aef4a87983e2f8a3        refs/changes/00/331800/1
7fab4ee270c21cd110388c01670a7ff4d1cbf41b        refs/changes/00/334600/1
5944ffe73bc1cdaea26b0151b4c1e93ac1235584        refs/changes/00/334600/2
fc3789ac553484ce81c47dc0adb09128dfb43077        refs/changes/00/334600/3
8aa3592d48c686dd6313a4b8087addfd5a108491        refs/changes/00/334600/4
520b5c135d2889af90689d049aacf6138cca8c61        refs/changes/00/334600/5

如果我们想要查看328300最新补丁的参考资料,我们可以从上面提取,如下所示:

git ls-remote https://review.gerrithub.io/org-name/project-name |
  awk '{print $2}' |
  awk -F/ '$4 == "328300" {print $0, $5}' |
  sort -k4 -n | tail -1 | awk '{print $1}'

这给了我们:

refs/changes/00/328300/6

所以,将其推广到一个函数并使用它来挑选一个评论:

find_latest_change () {
  local remote=$1
  local review=$2

  git ls-remote $remote |
    awk '{print $2}' |
    awk -F/ -vreview=$review '$4 == review {print $0, $5}' |
    sort -k4 -n |
    tail -1 | 
    awk '{print $1}'
}

remote=https://review.gerrithub.io/org-name/project-name
latest=$(find_latest_change $remote 12345)
git fetch $remote $latest && 
  git cherry-pick FETCH_HEAD

答案 1 :(得分:0)

根据@larsks的回复,我能够编写一个真正适合我的版本。由于旧awk,他的原始版本在OS X上失败,并且由于缺少数字排序而未能选择最新版本(10> 2不在1和2之间)。

find_latest_change () {
  local remote=$1
  local review=$2
  git ls-remote $remote | grep -E "refs/changes/[[:digit:]]+/$2/" | sort -t / -k 5 -g | tail -n1 | awk '{print $2}'
}

remote=https://review.gerrithub.io/org-name/project-name
latest=$(find_latest_change $remote 12345)
git fetch $remote $latest && git cherry-pick FETCH_HEAD