2014-05-19 76 views
4

我刚刚安装了Gerrit,我想对它进行推送,但是我收到了有关Change-Id的错误,但它似乎存在于它抱怨的提交中。将Change-Id添加到所有提交

$ git push gerrit HEAD:refs/publish/my-branch 
Counting objects: 28, done. 
Delta compression using up to 4 threads. 
Compressing objects: 100% (15/15), done. 
Writing objects: 100% (15/15), 4.46 KiB, done. 
Total 15 (delta 12), reused 0 (delta 0) 
remote: Resolving deltas: 100% (12/12) 
remote: Processing changes: refs: 1, done  
remote: ERROR: missing Change-Id in commit message footer 
remote: Suggestion for commit message: 
remote: Revert "Refactoring controllers" 
remote: 
remote: This reverts commit dd1c5c86b12461f61326fd102a11d9e3cb51142e. 
remote: 
remote: Change-Id: Iaacf80a9e4f56b58d0b648112c3eb2413988f00e 
remote: 
remote: Hint: To automatically insert Change-Id, install the hook: 
remote: gitdir=$(git rev-parse --git-dir); scp -p -P 29418 [email protected]:hooks/commit-msg ${gitdir}/hooks/ 
remote: 
remote: 
To ssh://[email protected]:29418/Project 
! [remote rejected] HEAD -> refs/publish/my-branch (missing Change-Id in commit message footer) 
error: failed to push some refs to 'ssh://[email protected]:29418/Project' 

我认为,这是因为以前的提交是没有Change-Id,因为他们之前有钩制成。我如何更新所有以前的提交以添加Change-Id

+1

导入存储库时,通常会推送给主服务器,而不是推送审阅。 – uncletall

回答

2

在Gerrit中 - 在项目设置页面中禁用需要临时提交change-Id的选项。然后将现有的提交推送到Gerrit。

+0

然后我可以安全地启用它吗? – stackular

+1

是 - 启动回购后 - 然后设置此选项 – HiB

+1

请注意,如果某人修改了这些提交并推回来,它们将作为新更改打开;为了防止这种情况,必须从Gerrit UI手动将change-id复制到提交消息。 – Smar

1

当你有钩,你可以做衍合分支到自己在交互模式

git checkout branchName 
git rebase -i branchName 

当你看到交互式菜单更改关键字pickedit附近的每一个承诺,你有没有变化ID。然后,git将在“重新绑定”每一个标记为edit的提交之前停止。每做一次你就做git commit --amend,保存更改(如果你已经提交了hook hrom gerrit,那么你需要手动添加更改ID),然后git rebase --continue。之后,您的分支中的每个提交都将具有change-id。
Rince并重复你需要的每一个分支。

相关问题