= Release notes for Gerrit 2.9 Gerrit 2.9 is now available: link:https://www.gerritcodereview.com/download/gerrit-2.9.war[ https://www.gerritcodereview.com/download/gerrit-2.9.war] *WARNING:* Support for Java 1.6 has been discontinued. As of Gerrit 2.9, Java 1.7 is required. Gerrit 2.9 includes the bug fixes done with link:ReleaseNotes-2.8.1.html[Gerrit 2.8.1], link:ReleaseNotes-2.8.2.html[Gerrit 2.8.2], link:ReleaseNotes-2.8.3.html[Gerrit 2.8.3], link:ReleaseNotes-2.8.4.html[Gerrit 2.8.4], link:ReleaseNotes-2.8.5.html[Gerrit 2.8.5], link:ReleaseNotes-2.8.6.html[Gerrit 2.8.6] and link:ReleaseNotes-2.8.6.1.html[Gerrit 2.8.6.1]. These bug fixes are *not* listed in these release notes. == Important Notes *WARNING:* This release contains schema changes. To upgrade: ---- java -jar gerrit.war init -d site_path java -jar gerrit.war reindex --recheck-mergeable -d site_path ---- *WARNING:* Upgrading to 2.9.x requires the server be first upgraded to 2.1.7 (or a later 2.1.x version), and then to 2.9.x. If you are upgrading from 2.2.x.x or later, you may ignore this warning and upgrade directly to 2.9.x. *WARNING:* When upgrading from version 2.8.4 or older with a site that uses Bouncy Castle Crypto, new versions of the libraries will be downloaded. The old libraries should be manually removed from site's `lib` folder to prevent the startup failure described in link:https://code.google.com/p/gerrit/issues/detail?id=3084[Issue 3084]. *WARNING:* Support for query via the SQL index is removed. The usage of a secondary index is now mandatory. *WARNING:* The `sortkey` and `sortkey_prev` options on the query changes REST endpoint are link:#sortkey-deprecation[deprecated]. *WARNING:* The new change screen only displays download commands if the `download-commands` core plugin or any other plugin providing download commands is installed. The `download-commands` plugin provides the standard download schemes and commands. It is packaged together with Gerrit and can be installed, or upgraded, during the link:https://gerrit-review.googlesource.com/Documentation/pgm-init.html[ site initialization]: .Installing the plugin for the first time - Batch init: + By default the batch init does *not* install any core plugin. To install the `download-commands` plugin during batch init, specify the '--install-plugin download-commands' option: + ---- $ java -jar gerrit-2.9.war init -d site --batch --install-plugin download-commands ---- - Interactive init: + There is a question whether the `download-commands` plugin should be installed. To install the plugin the question must be answered with `y`: + ---- Install plugin download-commands version v2.9 [y/N]? y ---- .Upgrading the plugin Pay attention that the `download-commands` plugin from Gerrit 2.8 is *not* compatible with Gerrit 2.9 and must be upgraded: - Batch init: + With the batch init it is *not* possible to upgrade core plugins. - Interactive init: + The interactive init asks whether the plugin should be upgraded: + ---- Install plugin download-commands version v2.9 [y/N]? y version v2.8.6.1 is already installed, overwrite it [y/N]? y ---- - Manual upgrade: + The plugin can be upgraded manually by copying the new plugin jar into the site's `plugins` folder. == Release Highlights * link:http://code.google.com/p/gerrit/issues/detail?id=2065[Issue 2065]: The new change screen is now the default change screen. + The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-review-ui.html[ documentation of the new review UI] describes the new screens in detail and highlights the important functionality with screenshots. + Users that are accessing the new change screen for the first time are informed about the new change screen by a welcome popup. The welcome popup links to the review UI documentation and allows users to go back to the old change screen. == New Features === Web UI ==== Global * Project links by default link to the project dashboard. ==== New Change Screen * The new change screen is now the default change screen. * The layout was changed so that the focus is now on the commit message, the change ID and the change status. * Draft comments are displayed in the reply box. + There are links to navigate to the inline comments which can be used if a comment needs to be edited. * New inline comments from other users, that were published after the current user last reviewed this change, are highlighted in bold. * New summary comments from other users, that were published after the current user last reviewed this change, are automatically expanded in the change history. + The support for the old comment visibility strategy is discontinued. * link:http://code.google.com/p/gerrit/issues/detail?id=93[Issue 93]: Inline comments are shown in the change history. * link:http://code.google.com/p/gerrit/issues/detail?id=592[Issue 592]: A reply icon is shown on each change message. * Quoting is possible when replying to a comment. * link:http://code.google.com/p/gerrit/issues/detail?id=2313[Issue 2313]: Show whether a related change is merged or old. * New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-review-ui.html#related-changes[ Related Changes] tabs: ** `Cherry-Picks` ** `Same Topic` ** `Conflicts With` * The title of the `Patch Sets` drop-down panel shows the number of the currently viewed patch set and the total number of patch sets, in the form: "current patch set/number of patch sets". * The currently viewed patch set is displayed in the `Patch Sets` title. * Keyboard shortcuts to navigate to next/previous patch set. * Support `[`, `/` and `]` keys to navigate between files in a cycle. * link:http://code.google.com/p/gerrit/issues/detail?id=2078[Issue 2078]: Show a tooltip on reviewers indicating on which labels they can vote. * The `Submit` button is enabled even if the change is not mergeable. + This allows to do the conflict resolution for a change series in a single merge commit and submit the changes in reverse order. * New `Open All` button in files header. * If a merge commit is viewed this is highlighted by an icon. In this case the parent commits are also shown. * link:http://code.google.com/p/gerrit/issues/detail?id=2191[Issue 2191]: New copy-to-clipboard button for commit ID. ==== New Side-by-Side Diff Screen * link:http://code.google.com/p/gerrit/issues/detail?id=348[Issue 348]: The lines of a patch file are linkable. + These links can be used to directly link to certain inline comments. * link:http://code.google.com/p/gerrit/issues/detail?id=2395[Issue 2395]: The line length preference is used to draw a margin line at that many columns of text. + This allows a user to configure their preferred width (e.g. 80 columns or 100 columns) and see the margin, making it easier to identify lines that run over that width. * link:http://code.google.com/p/gerrit/issues/detail?id=2530[Issue 2530]: All diff preferences are honored. * link:http://code.google.com/p/gerrit/issues/detail?id=148[Issue 148]: The full file path is shown. ==== Change List / Dashboards * The `Status` column shows `Merge Conflict` for changes that are not mergeable. * A new `Size` column shows the change size as a colored bar. ** The user preference `Show Change Sizes As Colored Bars In Changes Table` can be disabled to get the size information displayed as text. ** The number of changed lines by which a change is considered as a large change can be link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#change.largeChange[ configured]. * Support to drill down into dashboard section. + Clicking on the section title executes the query of this section without the `limit` operator. ==== Project Screens * The general project screen provides a copyable clone command that automatically installs the `commit-msg` hook. * link:http://code.google.com/p/gerrit/issues/detail?id=562[Issue 562]: Project owners can change `HEAD` from the project branches screen. * link:http://code.google.com/p/gerrit/issues/detail?id=1298[Issue 1298]: Administrators can change the parent project from the project access screen; other users can save changes to the parent project for review and get the change approved by an administrator. * The project list displays icons for projects that are read only or hidden. * The Git garbage collection can be triggered from the general project screen if the user has the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/access-control.html#capability_runGC[ Run Garbage Collection] global capability. ==== User Preferences * Users can choose the UK date format to render dates and timestamps in the UI. === Secondary Index * Support for query via the SQL index is removed. The usage of a secondary index is now mandatory. * New `--recheck-mergeable` option on the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/pgm-reindex.html[ reindex] program. === ssh * New `--notify` option on the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/cmd-review.html[ review] command allowing to control when email notifications should be sent. * link:http://code.google.com/p/gerrit/issues/detail?id=1752[Issue 1752]: New `--branch` option on the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/cmd-review.html[ review] command. * New `--all-reviewers` option on the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/cmd-query.html[ query] command allowing query results to include information about all reviewers added on the change. * New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/cmd-apropos.html[ apropos] command to search the Gerrit documentation. * link:http://code.google.com/p/gerrit/issues/detail?id=1156[Issue 1156]: New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/cmd-create-branch.html[ create-branch] command. === REST API ==== Changes [[sortkey-deprecation]] * Results returned by the link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/rest-api-changes.html#list-changes[ query changes] endpoint are now paginated using offsets instead of sortkeys. + The `sortkey` and `sortkey_prev` parameters on the endpoint are deprecated. The results are now paginated using the `--limit` (`-n`) option to limit the number of results, and the `-S` option to set the start point. + Queries with sortkeys are still supported against old index versions, to enable online reindexing while clients have an older JS version. ==== Projects * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/rest-api-projects.html#get-content[ Get content of a file from HEAD of a branch]. ==== Documentation * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/rest-api-documentation.html#search-documentation.html[ Search documentation]. === Access Rights * New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/access-control.html#capability_viewAllAccounts[ global capability for viewing all accounts]. * New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/access-control.html#capability_viewPlugins[ global capability for viewing the list of installed plugins]. * link:http://code.google.com/p/gerrit/issues/detail?id=1993[Issue 1993]: New `Change Owner` group that allows to assign label permissions to the change owner. * Support link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/access-control.html#category_submit_on_behalf_of[ on behalf of for submit]. * Allow service users to access REST API if `auth.gitBasicAuth = true`. + If link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#auth.gitBasicAuth[ auth.gitBasicAuth] is set to `true` in the `gerrit.config` file all HTTP traffic is authenticated using standard `BasicAuth` and the credentials are validated using the same auth method as configured for the Gerrit Web UI. E.g. for LDAP this means that users must use their LDAP password for Git over HTTP and for accessing the REST API. + Service users are technical users that were created by the `create-account` SSH command. These users only exist in Gerrit and hence they do not have any LDAP password. This is why service users were not able to make use of the REST API if `auth.gitBasicAuth` was set to `true`. + Now if `auth.gitBasicAuth` is set to `true` users that exist only in Gerrit but not in LDAP are authenticated with their HTTP password from the Gerrit database. === Search * New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#mergeable[ is:mergeable] search operator. + Finds changes that have no merge conflicts and can be merged into the destination branch. * link:http://code.google.com/p/gerrit/issues/detail?id=2163[Issue 2163]: New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#parentproject[ parentproject] search operator. + Finds changes in the specified project or in one of its child projects. * link:http://code.google.com/p/gerrit/issues/detail?id=2162[Issue 2162]: New link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#conflicts[ conflicts] search operator. + Finds changes that conflict with the specified change. * New operators for absolute last-updated-on search. ** link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#before_until[ before / until] ** link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#after_since[ after / since] * Support exact match on file parts in link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-search.html#file[ file] operator. * Query shortcuts ** `o` = `owner` ** `r` = `reviewer` ** `p` = `project` ** `f` = `file` === Daemon * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-inspector.html[ Gerrit Inspector]: interactive Jython shell. + New `-s` option is added to the Daemon to start an interactive Jython shell for inspection and troubleshooting of live data of the Gerrit instance. === Documentation * The documentation is now https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/rest-api-documentation.html#search-documentation.html[ searchable]: + On each documentation page there is search box in the right top corner that allows to search in the documentation. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/user-review-ui.html[ Documentation of the new review UI]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/intro-project-owner.html[ New Project Owner Guide]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/index.html[ Newly structured documentation index]. === Configuration * New init step for installing the `Verified` label. * link:http://code.google.com/p/gerrit/issues/detail?id=2257[Issue 2257]: link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#repository.name.defaultSubmitType[ Default submit type] for newly created projects can be configured. * `sshd_log` and `httpd_log` can use log4j configuration. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#change.allowDrafts[ Draft workflow can be disabled]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-project-config.html#receive.checkReceivedObjects[ Project configuration for checking of received objects]. * link:http://code.google.com/p/gerrit/issues/detail?id=2318[Issue 2318]: Allow the text of the "Report Bug" link to be configured. === Misc * The removal of reviewers and their votes is recorded as a change message. * link:http://code.google.com/p/gerrit/issues/detail?id=2229[Issue 2229]: The change URL is returned on push if the change is updated. * The topic is included into merge commit messages if all merged changes have the same topic. * Stable CSS class names. === Plugins * Plugin API to invoke the REST API. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#screen[ Plugins can add entire screens to Gerrit]. * Plugins can have a link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#settings-screen[ settings screen] which is linked from plugin list screen. * Support to edit link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#simple-project-specific-configuration[ project plugin configuration parameters] in the UI. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#plugins.allowRemoteAdmin[ Remote plugin administration is by default disabled]. ==== Extension Points * Extension point to provide a "Message Of The Day". * Validation for ** link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-validation.html#new-project-validation[ project creation]. ** link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-validation.html#new-group-validation[ group creation]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#init_step[ Init steps can do initialization after the site is created]. ** The `All-Projects` `project.config` can be read and edited * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#receive-pack[ Initialization of ReceivePack]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#post-receive-hook[ Registration of PostReceiveHooks]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#root-level-commands[ Registration of root level commands]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/dev-plugins.html#multiple-commands[ Multiple SSH commands can be bound to the same class]. * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/config-gerrit.html#database.dataSourceInterceptorClass[ DataSource Interception]. ==== JavaScript Plugins * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.9/js-api.html#self_on[ JavaScript Callbacks] ** Gerrit.on(\'history\', f) ** Gerrit.on(\'submitchange\', f) ** Gerrit.on(\'showchange\', f) * `change_plugins` element on the new change screen that allows to insert arbitrary HTML fragments from plugins. == Bug Fixes === Access Rights * Fix possibility to overcome BLOCK permissions. === Web UI * link:http://code.google.com/p/gerrit/issues/detail?id=2652[Issue 2652]: Copy label approvals when cherry-picking change to same branch. * link:http://code.google.com/p/gerrit/issues/detail?id=2662[Issue 2662]: Limit file list in new change screen to files that were touched in new patch set. * link:http://code.google.com/p/gerrit/issues/detail?id=2308[Issue 2308]: Show related changes in new change screen for merged changes if there are open descendants. * link:http://code.google.com/p/gerrit/issues/detail?id=2635[Issue 2635]: Fix copying of download commands by 'Cmd-C' in Safari. * link:http://code.google.com/p/gerrit/issues/detail?id=2178[Issue 2178]: Fix background of reply box on new change screen getting transparent. * link:http://code.google.com/p/gerrit/issues/detail?id=2362[Issue 2362]: Show quick approve button only for current patch set. * link:http://code.google.com/p/gerrit/issues/detail?id=2405[Issue 2405]: Update `Patch Sets` drop-down panel when draft patch set is deleted. * link:http://code.google.com/p/gerrit/issues/detail?id=2397[Issue 2397]: Fix linkifying of topics that are set to a URL. * link:http://code.google.com/p/gerrit/issues/detail?id=2151[Issue 2151]: Fix overflowing of long lines in commit message block. * link:http://code.google.com/p/gerrit/issues/detail?id=2401[Issue 2401]: Fix truncated long lines in new side-by-side diff screen. * link:http://code.google.com/p/gerrit/issues/detail?id=2225[Issue 2225]: Display larger icons for Prev / Next and Up to Change links on new side-by-side diff screen. * link:http://code.google.com/p/gerrit/issues/detail?id=2340[Issue 2340]: Fix selection in new side-by-side diff screen. * link:http://code.google.com/p/gerrit/issues/detail?id=2409[Issue 2409]: Show in new side-by-side diff screen updates of submodule links. * link:http://code.google.com/p/gerrit/issues/detail?id=2481[Issue 2481]: After showing a binary file in the unified diff screen switch back to the side-by-side diff screen when the user navigates to the next/previous file. * link:http://code.google.com/p/gerrit/issues/detail?id=2417[Issue 2417]: Respect base diff revision for files REST call. * link:http://code.google.com/p/gerrit/issues/detail?id=2654[Issue 2654]: Require the user to confirm setting the username. + Once the username has been set, it cannot be edited. This can cause problems for users who accidentally set the wrong username. A confirmation dialog now warns the user that setting the username is permanent and the username is only set when the user confirms. * link:https://code.google.com/p/gerrit/issues/detail?id=2635[Issue 2635]: Fix copying from copyable label in Safari. === Secondary Index * Fix Online Reindexing. * Fix for full-text search with Lucene. + The full-text search was using a fuzzy query which used the edit distance to find terms in the index close to the provided search term. This produced bizarre results for queries like "message:1234". + Instead, use Lucene's QueryBuilder with an analyzer to convert a full-text search word/phrase into a phrase query. * link:http://code.google.com/p/gerrit/issues/detail?id=2281[Issue 2281]: Reindex change after updating commit message. === REST * link:http://code.google.com/p/gerrit/issues/detail?id=2568[Issue 2568]: Update description file during `PUT /projects/{name}/config`. === SSH * link:http://code.google.com/p/gerrit/issues/detail?id=2516[Issue 2516]: Fix parsing of label name on `review` command. * link:http://code.google.com/p/gerrit/issues/detail?id=2440[Issue 2440]: Clarify for review command when `--verified` can be used. === Plugins * link:http://code.google.com/p/gerrit/issues/detail?id=2551[Issue 2551]: Handle absolute URLs in the top level menu. * link:http://code.google.com/p/gerrit/issues/detail?id=2391[Issue 2391]: Respect servlet context path in URL for top menu items. === Other * link:http://code.google.com/p/gerrit/issues/detail?id=2382[Issue 2382]: Clean left over data migration after removal of TrackingIds table. == Upgrades * Update JGit to 3.4.0.201405051725-m7 + This upgrade fixes the MissingObjectExceptions in Gerrit that are described in link:http://code.google.com/p/gerrit/issues/detail?id=2025[ issue 2025]. * Update gwtjsonrpc to 1.5 * Update gwtorm to 1.13 * Update guava to 16.0 * Update H2 to 1.3.174 + This version includes a fix for an LOB deadlock between reading and updating LOB columns. This could lead to a deadlock between web and SSH clients as described in link:http://code.google.com/p/gerrit/issues/detail?id=2365[issue 2365]. * Update Jetty to 9.1.0.v20131115 * Update Servlet API to 3.1 * Update Lucene to 4.6.0 * Update GWT to 2.6.0 == Plugins === Replication * Default push refSpec is changed to `refs/*:refs/*` (non-forced push). + The default push refSpec for the replication plugin has changed from `forced` to `non-forced` push (was `+refs/*:refs/*` and now is `refs/*:refs/*`). This change should not impact typical replication topologies where the slaves are read-only and can be pushed by their masters only. If you wanted explicitly to overwrite all changes on the slaves, you need to add a `push=+refs/*:refs/*` configuration entry for each replication target. * Support replication of HEAD updates. * Stream events for ref replication. * Replications failed due to "failed to lock" errors are retried. * Configuration changes can be detected and replication is automatically restarted. === Issue Tracker System plugins *WARNING:* The `hooks-*` plugins (`plugins/hooks-bugzilla`, `plugins/hooks-jira` and `plugins/hooks-rtc`) are deprecated with Gerrit 2.9. There are new plugins for the integration with Bugzilla, Jira and IBM Rational Team Concert: * link:https://gerrit-review.googlesource.com/#/admin/projects/plugins/its-bugzilla[plugins/its-bugzilla] * link:https://gerrit-review.googlesource.com/#/admin/projects/plugins/its-jira[plugins/its-jira] * link:https://gerrit-review.googlesource.com/#/admin/projects/plugins/its-rtc[plugins/its-rtc] The new issue tracker system plugins have a common base which is link:https://gerrit-review.googlesource.com/#/admin/projects/plugins/its-base[plugins/its-base]. The configuration of the new plugins is slightly different than the configuration of the old plugins because they use different section names in the Gerrit configuration. For easy migration the new plugins have an init step that allows to take over the configuration from the old plugins during the Gerrit initialization phase. New Features: * The issue tracker integration can be enabled/disabled per project. * Parent projects can enforce the issue tracker integration for their child projects. * It can be configured for which branches of a project the issue tracker integration is enabled. * Whether the issue tracker integration is enabled/disabled for a project can be changed from the ProjectInfoScreen in the Gerrit WebUI.