RETIRED, Gerrit as used by OpenStack
Go to file
Dave Borowitz 0761fd5ce4 MergeOp: Disallow multiple submit types on a single branch
Submit type rules allow different changes to the same branch to have
different submit types. A main use case for this functionality is
allowing branch-specific rather than project-specific submit types.

However, in theory this also allows a single batch of commits to mix
submit types. MergeOp currently handles this situation by splitting
up open changes on a branch by submit type and running submit types
on each subset in arbitrary order (based on HashMap iteration).

My thesis is that this behavior produces nondeterministic results
that, even if we can justify them as "sane", are likely to be
surprising and/or confusing to the user, and that we are better off
failing fast rather than trying to support this scenario.

In the past, there was a distinct reason for this behavior, which was
that there might be (through no fault of a user) changes in the
submitted state with various submit types. Spinning through the submit
type list and making progress, while perhaps confusing, was probably
better than not making progress at all. But now that the submitted
state is gone, the only way in which multiple changes can be submitted
at once is within a single batch (including parents or by topic), so
this reasoning does not really exist any more.

For one example of confusing behavior, say we have two changes A<-B
based on the branch tip 0, where A is Merge Always and B is Merge If
Necessary. If MergeOp chooses to run Merge Always first, the resulting
history will be:

 0----Ma--Mab
  \-A-/   /
     \-B-/

If, however, MergeOp chooses to run Merge If Necessary first, the
merge sorter will choose the fast-forward resolution for B, resulting
in:

 0--A--B

When Merge Always runs, it will find that A is already merged and do
nothing.

For another example, consider three changes A<-B<-C, where A and C
are Cherry-Pick and B is Merge If Necessary. If MergeOp chooses to
run Cherry-Pick first, it cherry-picks A' and C':

 0--A'--C'

Then merging B fails since it now depends on an out-of-date patch set
of A.

If MergeOp chooses Merge If Necessary first, then B gets chosen as a
fast-forward and C gets cherry-picked on top:

 0--A--B--C'

It is not at all obvious that any one of these solutions is what the
user expects to get, to say nothing of more complicated cases.

Note that I am only about 75% sure of what actually happens in these
scenarios; I might be completely wrong. That just goes to show how
weird this behavior is.

Enforce during validateChangeList that only a single submit type is
present on each branch. This also eliminates one level of looping in
the main integrateIntoHistory logic.

Another possible solution would be in the case of mixed submit types
to run the entire process one change at a time in topological order.
This at least might be easier to reason about, although it would still
not always succeed, for example if a Merge Always change follows a
Cherry-Pick change. But it would introduce considerably more
complexity to rework the loops in MergeOp, all for the questionable
benefit of making it easier for users to get into a confused
situation. Better to just not let them do it at all.

Change-Id: I0cec2a7e3e3625fedbdd621b0c6eca6c4100f232
2015-12-17 13:25:02 -05:00
.settings Update Eclipse code formatter settings 2015-08-31 07:03:36 +00:00
bucklets Remove bucklets/local_jar.bucklet soft-link to removed lib/local.defs 2015-12-15 11:03:27 -05:00
contrib Correct issue with Bouncy Castle code signing 2015-11-10 13:00:26 -08:00
Documentation MergeOp: Disallow multiple submit types on a single branch 2015-12-17 13:25:02 -05:00
gerrit-acceptance-framework Make MetaDataUpdate auto-closeable 2015-12-17 20:06:27 +09:00
gerrit-acceptance-tests MergeOp: Disallow multiple submit types on a single branch 2015-12-17 13:25:02 -05:00
gerrit-antlr Remove unnecessary dependencies 2015-09-18 06:02:35 +00:00
gerrit-cache-h2 H2CacheImpl: Support get(K, Callable<? extends V>) 2015-08-07 17:04:18 -07:00
gerrit-common Merge doc and change searches. 2015-11-24 22:14:39 -08:00
gerrit-extension-api Add extension API and acceptance tests for submit type rules 2015-12-17 13:25:02 -05:00
gerrit-gpg Merge "Add project config boolean to require signed push on a project" 2015-10-26 18:20:22 +00:00
gerrit-gwtdebug Expose acceptance test framework as new plugin artifact 2015-09-25 14:46:10 -04:00
gerrit-gwtexpui Remove modifiers 'public' and 'abstract' from interface methods 2015-11-19 09:36:40 -08:00
gerrit-gwtui Merge "Add button for inline comments that allows quoting them" 2015-12-09 08:10:44 +00:00
gerrit-gwtui-common Add a dropdown to control email notifications on user preference page 2015-12-07 16:13:41 -05:00
gerrit-httpd Make MetaDataUpdate auto-closeable 2015-12-17 20:06:27 +09:00
gerrit-launcher Update Buck to newest version 2015-12-02 14:07:12 +00:00
gerrit-lucene Fix race in Lucene shutdown 2015-12-17 13:25:02 -05:00
gerrit-main Replace C-style array declarations with Java-style declarations 2015-03-19 12:15:43 +09:00
gerrit-oauth Import StandardCharsets.UTF_8 as static 2015-10-19 14:59:46 +09:00
gerrit-openid Merge branch 'stable-2.12' 2015-12-16 09:41:32 +01:00
gerrit-patch-commonsnet Consistently use character encoding constants 2015-10-16 08:39:12 +00:00
gerrit-patch-jgit Pass ChangeInfo object to extension panels 2015-08-04 14:05:24 +02:00
gerrit-pgm Fix race in Lucene shutdown 2015-12-17 13:25:02 -05:00
gerrit-plugin-api Export dropwizard in plugin API 2015-11-21 19:37:17 +01:00
gerrit-plugin-archetype Set version to 2.13-SNAPSHOT 2015-11-09 21:44:27 +00:00
gerrit-plugin-gwt-archetype Set version to 2.13-SNAPSHOT 2015-11-09 21:44:27 +00:00
gerrit-plugin-gwtui Remove modifiers 'public' and 'abstract' from interface methods 2015-11-19 09:36:40 -08:00
gerrit-plugin-js-archetype Set version to 2.13-SNAPSHOT 2015-11-09 21:44:27 +00:00
gerrit-prettify Remove modifiers 'public' and 'abstract' from interface methods 2015-11-19 09:36:40 -08:00
gerrit-reviewdb Add a dropdown to control email notifications on user preference page 2015-12-07 16:13:41 -05:00
gerrit-server MergeOp: Disallow multiple submit types on a single branch 2015-12-17 13:25:02 -05:00
gerrit-sshd Add extension API and acceptance tests for submit type rules 2015-12-17 13:25:02 -05:00
gerrit-util-cli Add missing braces around if- for- and while-statements 2015-03-19 12:15:42 +09:00
gerrit-util-http Add some tests for ResourceServlet 2015-12-03 10:33:28 -05:00
gerrit-util-ssl Turn on many more Eclipse warnings, and fix them 2014-10-29 15:00:17 -07:00
gerrit-war Fix race in Lucene shutdown 2015-12-17 13:25:02 -05:00
lib Draft comments initial implementation 2015-12-09 12:32:37 -05:00
plugins plugins: rename 'filter' method in BUCK file 2015-12-09 15:08:15 +09:00
polygerrit-ui Merge "Show tab indicators in the diff view" 2015-12-17 17:28:41 +00:00
ReleaseNotes MergeOp: Disallow multiple submit types on a single branch 2015-12-17 13:25:02 -05:00
tools download_bower: Remove cache entries with invalid SHA-1 2015-12-07 15:43:56 +00:00
website/releases Update out of date hyperlinks 2015-06-17 22:38:13 +00:00
.buckconfig Update Buck to newest version 2015-12-02 14:07:12 +00:00
.buckversion Revert "Update buck to ba9f239f69287a553ca93af76a27484d83693563" 2015-12-09 01:25:12 +00:00
.editorconfig Add basic EditorConfig 2015-03-03 07:12:16 +00:00
.gitignore Update Buck to newest version 2015-12-02 14:07:12 +00:00
.gitmodules Add singleusergroup plugin 2013-11-09 07:45:00 +01:00
.mailmap Update mailmap 2015-04-08 07:50:41 +00:00
.pydevproject Update PyDev project to use Python 2.7 2014-10-02 15:16:44 +09:00
.watchmanconfig Watchman: Add buck-out dir to ignored directories 2014-08-21 07:32:37 +02:00
BUCK Buck: Build gwtgerrit without touching PolyGerrit deps 2015-12-01 07:29:21 +00:00
COPYING Initial project setup of Gerrit 2 2008-11-14 16:59:34 -08:00
INSTALL Remove Gerrit 1.x to 2.x import tools 2009-03-27 20:20:10 -07:00
README.md Buck: Upgrade to the latest version 2015-11-03 06:36:13 +01:00
SUBMITTING_PATCHES Update push URL in SUBMITTING_PATCHES 2012-03-29 00:57:14 -04:00
VERSION Set version to 2.13-SNAPSHOT 2015-11-09 21:44:27 +00:00

Gerrit Code Review

Gerrit is a code review and project management tool for Git based projects.

Objective

Gerrit makes reviews easier by showing changes in a side-by-side display, and allowing inline comments to be added by any reviewer.

Gerrit simplifies Git based project maintainership by permitting any authorized user to submit changes to the master Git repository, rather than requiring all approved changes to be merged in by hand by the project maintainer.

Documentation

For information about how to install and use Gerrit, refer to the documentation.

Source

Our canonical Git repository is located on googlesource.com. There is a mirror of the repository on Github.

Reporting bugs

Please report bugs on the issue tracker.

Contribute

Gerrit is the work of hundreds of contributors. We appreciate your help!

Please read the contribution guidelines.

Note that we do not accept Pull Requests via the Github mirror.

Getting in contact

The IRC channel on freenode is #gerrit. An archive is available at: echelog.com.

The Developer Mailing list is repo-discuss on Google Groups.

License

Gerrit is provided under the Apache License 2.0.

Build

Install Buck and run the following:

    git clone --recursive https://gerrit.googlesource.com/gerrit
    cd gerrit && buck build release

Install binary packages (Deb/Rpm)

The instruction how to configure GerritForge/BinTray repositories is here

On Debian/Ubuntu run:

    apt-get update & apt-get install gerrit=<version>-<release>

NOTE: release is a counter that starts with 1 and indicates the number of packages that have been released with the same version of the software.

On CentOS/RedHat run:

    yum clean all && yum install gerrit-<version>[-<release>]

NOTE: release is optional. Last released package of the version is installed if the release number is omitted.

Events

  • November 7-8 2015: Gerrit User Conference, Mountain View. (Register).
  • November 9-13 2015: Gerrit Hackathon, Mountain View. (Invitation Only).
  • March 2016: Gerrit Hackathon, Berlin. (Details to be confirmed).