本人在第一次使用Gerrit时提交代码一直报change-Id找不到,在git log的时候显示如下
查询其他文档发现是commit-msg文件不存在导致的,现给出解决方案
提示错误,错误信息如下:
remote: Resolving deltas: 100% (6/6)
remote: Counting objects: 42105, done
remote: Processing changes: refs: 1, done
remote: ERROR: [xxx] missing Change-Id in commit message footer
remote:
remote: Hint: To automatically insert Change-Id, install the hook:
remote: gitdir=$(git rev-parse --git-dir); scp -p -P xxx
remote: And then amend the commit:
remote: git commit --amend
remote:
To ssh:xxx
! [remote rejected] xxx -> refs/for/xxx ([xxxxx] missing Change-Id in commit message footer)
error: failed to push some refs to 'ssh://xxx'
1、输入上面提示命令
gitdir=$(git rev-parse --git-dir); scp -p -P xxx
2、如果上面命令报错如下,则执行第3步,否则执行第4步
subsystem request failed on channel 0
scp: Connection closed
3、在.git/hook目录下看有没有生成commit-msg文件,如果只有commit-msg.sample文件则代表命令失败需要将第1步中scp -p修改成scp -O(不是0)再执行一下会打印commit-msg
4、执行git commit --amend命令补全Change-Id,可以通过git log来查看是否生成了Change-Id
5、最后执行git push origin HEAD:refs/for/工作分支