|  | = squash commits first | 
|  |  | 
|  | With this error message Gerrit rejects to push a commit if it | 
|  | contains the same Change-ID as a predecessor commit. | 
|  |  | 
|  | The reason for rejecting such a commit is that it would introduce, for | 
|  | the corresponding change in Gerrit, a dependency upon itself. Gerrit | 
|  | prevents such dependencies between patch sets within the same change | 
|  | to keep the review process simple. Otherwise reviewers would not only | 
|  | have to review the latest patch set but also all the patch sets the | 
|  | latest one depends on. | 
|  |  | 
|  | This error is quite common, it appears when a user tries to address | 
|  | review comments and creates a new commit instead of amending the | 
|  | existing commit. Another possibility for this error, although less | 
|  | likely, is that the user tried to create a patch series with multiple | 
|  | changes to be reviewed and accidentally included the same Change-ID | 
|  | into the different commit messages. | 
|  |  | 
|  |  | 
|  | == Example | 
|  |  | 
|  | Here an example about how the push is failing. Please note that the | 
|  | two commits 'one commit' and 'another commit' both have the same | 
|  | Change-ID (of course in real life it can happen that there are more | 
|  | than two commits that have the same Change-ID). | 
|  |  | 
|  | ---- | 
|  | $ git log | 
|  | commit 13d381265ffff88088e1af88d0e2c2c1143743cd | 
|  | Author: John Doe <john.doe@example.com> | 
|  | Date:   Thu Dec 16 10:15:48 2010 +0100 | 
|  |  | 
|  | another commit | 
|  |  | 
|  | Change-Id: I93478acac09965af91f03c82e55346214811ac79 | 
|  |  | 
|  | commit ca45e125145b12fe9681864b123bc9daea501bf7 | 
|  | Author: John Doe <john.doe@example.com> | 
|  | Date:   Thu Dec 16 10:12:54 2010 +0100 | 
|  |  | 
|  | one commit | 
|  |  | 
|  | Change-Id: I93478acac09965af91f03c82e55346214811ac79 | 
|  |  | 
|  | $ git push ssh://JohnDoe@host:29418/myProject HEAD:refs/for/master | 
|  | Counting objects: 8, done. | 
|  | Delta compression using up to 2 threads. | 
|  | Compressing objects: 100% (2/2), done. | 
|  | Writing objects: 100% (6/6), 558 bytes, done. | 
|  | Total 6 (delta 0), reused 0 (delta 0) | 
|  | To ssh://JohnDoe@host:29418/myProject | 
|  | ! [remote rejected] HEAD -> refs/for/master (squash commits first) | 
|  | error: failed to push some refs to 'ssh://JohnDoe@host:29418/myProject' | 
|  | ---- | 
|  |  | 
|  | If it was the intention to rework on a change and to push a new patch | 
|  | set the problem can be fixed by squashing the commits that contain the | 
|  | same Change-ID. The squashed commit can then be pushed to Gerrit. | 
|  | To squash the commits use git rebase to do an interactive rebase. For | 
|  | the example above where the last two commits have the same Change-ID | 
|  | this means an interactive rebase for the last two commits should be | 
|  | done. For further details about the git rebase command please check | 
|  | the link:http://www.kernel.org/pub/software/scm/git/docs/git-rebase.html[Git documentation for rebase]. | 
|  |  | 
|  | ---- | 
|  | $ git rebase -i HEAD~2 | 
|  |  | 
|  | pick ca45e12 one commit | 
|  | squash 13d3812 another commit | 
|  |  | 
|  | [detached HEAD ab37207] squashed commit | 
|  | 1 files changed, 3 insertions(+), 0 deletions(-) | 
|  | Successfully rebased and updated refs/heads/master. | 
|  |  | 
|  | $ git log | 
|  | commit ab37207d33647685801dba36cb4fd51f3eb73507 | 
|  | Author: John Doe <john.doe@example.com> | 
|  | Date:   Thu Dec 16 10:12:54 2010 +0100 | 
|  |  | 
|  | squashed commit | 
|  |  | 
|  | Change-Id: I93478acac09965af91f03c82e55346214811ac79 | 
|  |  | 
|  | $ git push ssh://JohnDoe@host:29418/myProject HEAD:refs/for/master | 
|  | Counting objects: 5, done. | 
|  | Writing objects: 100% (3/3), 307 bytes, done. | 
|  | Total 3 (delta 0), reused 0 (delta 0) | 
|  | To ssh://JohnDoe@host:29418/myProject | 
|  | * [new branch]      HEAD -> refs/for/master | 
|  | ---- | 
|  |  | 
|  | If it was the intention to create a patch series with multiple | 
|  | changes to be reviewed, each commit message should contain the | 
|  | Change-ID of the corresponding change in Gerrit.  If a change in | 
|  | Gerrit does not exist yet, the Change-ID should be generated (either | 
|  | by using a link:cmd-hook-commit-msg.html[commit hook] or by using EGit) or the Change-ID could be | 
|  | removed (not recommended since then amending this commit to create | 
|  | subsequent patch sets is more error prone). To change the Change-ID | 
|  | of an existing commit do an interactive link:http://www.kernel.org/pub/software/scm/git/docs/git-rebase.html[git rebase] and fix the | 
|  | affected commit messages. | 
|  |  | 
|  |  | 
|  | GERRIT | 
|  | ------ | 
|  | Part of link:error-messages.html[Gerrit Error Messages] | 
|  |  | 
|  | SEARCHBOX | 
|  | --------- |