如何通过单个命令获取有关gerrit更改的最新refspec。 我需要输出为“refs / changes / 11/1234/4”。是否有相同的git命令
我知道ssh命令结合gerrit查询和一些脚本可以获得这个,但想知道是否有更好的方法来做同样的事情。以下是我将用于获取refspec的ssh命令。
ssh -p $ REVIEW_SERVER_PORT $ GERRIT_REVIEW_SERVER gerrit query --format = TEXT --current-patch-set $ CHANGE_SHA | grep ref。
同样,我也想获得gerrit改变的最新补丁
答案 0 :(得分:6)
您应该使用gerrit query。给定更改编号4665
:
ssh -p 29418 review.example.com gerrit query --current-patch-set --format=JSON change:4665
哪个输出:
{
"project":"xx",
"branch":"master",
"topic":"TOPIC",
"id":"I0b6fc492fd08749e409c359a73d74e7795f50cc9",
"number":"4665",
// ...
"currentPatchSet":{
"number":"5",
"revision":"ae3a5d2684991070041e1c34b5a16b1376dc3ce5",
"parents":[
"5b21793cadd3dc55008ef6c8dc658e127d80c097"
],
"ref":"refs/changes/65/4665/5",
// ...
}
}
您可以在其中找到currentPatchSet.ref
字段。
旧的,过于复杂的解决方案:
如果您想获得最新的变更补丁集2392
:
git ls-remote | grep /2392/ | awk '{print $2}' | sed 's/\// /g' | sort -n -k5 | tail -n 1 | sed 's/ /\//g'
为我的回购输出refs/changes/92/2392/12
。
或者,当您想要从Gerrit获得最后一次更改时:
git ls-remote | awk '{print $2}' | sed 's/\// /g' | sort -n -k4 | tail -n 1 | sed 's/ /\//g'
为我的回购输出refs/changes/54/2554/2
。
<强>解释强>
git ls-remote命令显示远程存储库中的所有引用,因此在Gerrit的情况下 - 也列出了每个补丁集。它输出的内容如下:
2ccddbfb34a98e8ba461964fae3766aa41be944d refs/changes/91/2291/7
d00c21c28d07626caea27594489442696ea39231 refs/changes/91/2291/8
8c05e6551a6a34c33a36669bf7e83c996569e24d refs/changes/91/2291/9
bc6762ac7b9ac5a74fc2e548df2541cb83977ec5 refs/changes/91/2391/1
3bd96c0d1ba2d561fa484ddfc264fabbf86aa536 refs/changes/91/2391/2
因此,为了从特定更改中选择所有补丁集,我们需要按/NUMBER/
grep结果,这解释了grep /2392/
。之后,通过选择awk的第二列,结果为:
refs/changes/92/2392/1
refs/changes/92/2392/10
refs/changes/92/2392/11
refs/changes/92/2392/12
refs/changes/92/2392/2
refs/changes/92/2392/3
refs/changes/92/2392/4
refs/changes/92/2392/5
refs/changes/92/2392/6
refs/changes/92/2392/7
refs/changes/92/2392/8
refs/changes/92/2392/9
现在我们要选择最后一个补丁集。我们需要分类。 sort命令可以使用-n
的数字进行排序,我们可以指定使用-kX
参数执行排序的列。但它需要用空格分隔列(AFAIK),因此我们需要用空格替换/
分隔符。我们使用sed。首次替换后,每个refs/changes/92/2392/X
变为refs changes 92 2392 X
。然后在第五列(补丁集编号)上执行排序。结果:
refs changes 92 2392 1
refs changes 92 2392 2
refs changes 92 2392 3
refs changes 92 2392 4
refs changes 92 2392 5
refs changes 92 2392 6
refs changes 92 2392 7
refs changes 92 2392 8
refs changes 92 2392 9
refs changes 92 2392 10
refs changes 92 2392 11
refs changes 92 2392 12
最后要做的是选择tail的最后一行并将空格替换为斜杠。瞧!
从Gerrit中选择最新的更改以相同的方式完成,但没有grep并按第四列排序(Change-Id)。
答案 1 :(得分:1)
这是一个可以通过HTTP工作的解决方案,因为SSH在某些CI环境中可能无效。
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
答案 2 :(得分:1)
这是一种避免列出远程服务器或使用Gerrit REST API的解决方案。
每次Gerrit更改都会有一个特殊的参考,称为meta
:
git fetch origin refs/changes/98/898/meta
一旦获取,它便指向一连串提交,这些提交代表此更改的更新历史。除其他事项外,提交消息具有预告片Patch-set
,其中将包含此更改适用的补丁集编号:
> git log FETCH_HEAD
Author: Gerrit User 1000026 <1000026@dc17d2f6-4abc-4304-ba32-8b7ca44eda6b>
Date: Wed Aug 19 06:36:23 2020 +0100
Update patch set 6
Change has been successfully cherry-picked as 68e4bc1612d61110ccfae4ac94bbd4458b2868a9 by Leonid Usov
Patch-set: 6
Subject: Add a new feature
Status: merged
Commit: 68e4bc1612d61110ccfae4ac94bbd4458b2868a9
Tag: autogenerated:gerrit:merged
Groups: bd9a33f7432c39308935056720de59168ff04003
Label: Code-Review=+2
Label: Verified=+1 Gerrit User 1000001 <1000001@dc17d2f6-4abc-4304-ba32-8b7ca44eda6b>
Label: SUBM=+1
Submission-id: 914
Submitted-with: OK
Submitted-with: OK: Code-Review: Gerrit User 1000026 <1000026@dc17d2f6-4abc-4304-ba32-8b7ca44eda6b>
Submitted-with: OK: Verified: Gerrit User 1000001 <1000001@dc17d2f6-4abc-4304-ba32-8b7ca44eda6b>
自然,该分支的尖端将指向最新更新,因此将包含最新补丁集的编号。这是我如何知道更改的最新补丁集编号:
» git fetch origin refs/changes/14/914/meta \
&& git cat-file -p FETCH_HEAD \
| git interpret-trailers --parse \
| sed -E "/^Patch-set:/s/([[:alpha:]-]+):[[:space:]]*(.*)/\2/;q"
From ssh://gerrit/repo
* branch refs/changes/14/914/meta -> FETCH_HEAD
6
请随意在标准输出上使用6
;)