| Release notes for Gerrit 2.8 |
| ============================ |
| |
| |
| Gerrit 2.8 is now available: |
| |
| link:https://gerrit-releases.storage.googleapis.com/gerrit-2.8.war[ |
| https://gerrit-releases.storage.googleapis.com/gerrit-2.8.war] |
| |
| |
| Schema Change |
| ------------- |
| |
| |
| *WARNING:* This release contains schema changes. To upgrade: |
| ---- |
| java -jar gerrit.war init -d site_path |
| ---- |
| |
| *WARNING:* Upgrading to 2.8.x requires the server be first upgraded to 2.1.7 (or |
| a later 2.1.x version), and then to 2.8.x. If you are upgrading from 2.2.x.x or |
| later, you may ignore this warning and upgrade directly to 2.8.x. |
| |
| *WARNING:* The replication plugin now automatically creates missing repositories |
| on the destination if during the replication of a ref the target repository is |
| found to be missing. This is a change in behavior of the replication plugin. To go |
| back to the old behavior, set the parameter `remote.NAME.createMissingRepositories` |
| in the `replication.config` file to `false`. |
| |
| *WARNING:* The deprecated `approve` alias for the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-review.html[ |
| review] SSH command has been removed. This is important for all users |
| of the Jenkins link:https://wiki.jenkins-ci.org/display/JENKINS/Gerrit+Trigger[ |
| Gerrit Trigger Plugin] since this plugin by default uses the `approve` |
| command to vote and comment on changes in Gerrit. If you use the Gerrit |
| Trigger Plugin, go to its global configuration in Jenkins and adapt the |
| Gerrit commands to use the `review` command instead of the `approve` |
| command. |
| |
| *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 during the |
| link:https://gerrit-review.googlesource.com/Documentation/pgm-init.html[ |
| site initialization]. |
| |
| |
| Release Highlights |
| ------------------ |
| |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/intro-change-screen.html[ |
| New change screen] with completely redesigned UI and fully using the REST API. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#__a_id_index_a_section_index[ |
| Secondary indexing with Lucene and Solr]. |
| |
| * Lots of new link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api.html[ |
| REST API endpoints]. |
| |
| * New |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#ui_extension[ |
| UI extension] and |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/js-api.html[ |
| JavaScript API] for plugins. |
| |
| * New build system using Facebook's link:http://facebook.github.io/buck/[Buck]. |
| |
| * New core plugin: Download Commands. |
| |
| |
| New Features |
| ------------ |
| |
| Build |
| ~~~~~ |
| |
| * Gerrit is now built with |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-buck.html[ |
| Buck]. |
| |
| * Documentation is now built with Buck and link:http://asciidoctor.org[Asciidoctor]. |
| |
| |
| Indexing and Search |
| ~~~~~~~~~~~~~~~~~~~ |
| |
| Gerrit can be configured to use a |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#__a_id_index_a_section_index[ |
| secondary index] with Lucene or Solr. |
| |
| Existing search operations use the secondary index, when enabled, to increase |
| performance and reduce resource usage. |
| |
| The following additional search operations are possible when secondary indexing |
| is enabled: |
| |
| * New |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/user-search.html#comment[ |
| `comment` search operator]. |
| |
| * The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/user-search.html#file[ |
| `file` operator] can be used to find changes on the specified file. |
| |
| * Regular expressions are allowed in `file` searches. |
| |
| |
| *WARNING:* After enabling the secondary index, the index must be built using the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/pgm-reindex.html[ |
| reindex program] before restarting the Gerrit server. |
| |
| |
| Configuration |
| ~~~~~~~~~~~~~ |
| |
| * Project owners can define `receive.maxObjectSizeLimit` in the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#receive.maxObjectSizeLimit[ |
| project configuration] to further reduce the global setting. |
| |
| * Site administrators can define a |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-mail.html#_footer_vm[ |
| footer template] that will be appended to the end of all outgoing emails after |
| the 'ChangeFooter' and 'CommentFooter'. |
| |
| * New `topic-changed` hook and stream event is fired when a change's topic is |
| edited from the Web UI or via a REST API. |
| |
| * New options `--list-plugins` and `--install-plugins` on the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/pgm-init.html[ |
| site initialization command]. |
| |
| * New `auth.httpDisplaynameHeader` and `auth.httpEmailHeader` in the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#__a_id_auth_a_section_auth[ |
| authentication configuration]. |
| + |
| When using HTTP-based authentication, the SSO can be delegated to check not only |
| the user credentials but also to fetch the full user-profile. |
| + |
| With the config properties `auth.httpDisplaynameHeader` and `auth.httpEmailHeader` |
| it is possible to configure the name of the headers used for propagating this extra |
| information and enforce them on the user profile during login and beyond. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#__a_id_httpd_a_section_httpd[ |
| Customizable registration page for HTTP authentication]. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#__a_id_httpd_a_section_httpd[ |
| Configurable external `robots.txt` file]. |
| |
| * Support for |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/database-setup.html#createdb_oracle[ |
| Oracle database]. |
| |
| * New bash completion script for autocompletion of parameters to the gerrit.sh wrapper. |
| |
| * The site can be |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-auto-site-initialization.html[ |
| auto-initialized on server startup]. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#httpd.filterClass[ |
| Configurable filtering of HTTP traffic through Gerrit's HTTP protocol]. |
| |
| * Labels can be |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-labels.html#httpd.label_copyAllScoresIfNoCodeChange[ |
| configured to copy scores forward to new patch sets if there is no code change]. |
| |
| * Labels can be |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-labels.html#httpd.label_copyAllScoresOnTrivialRebase[ |
| configured to copy scores forward to new patch sets for trivial rebases]. |
| |
| Web UI |
| ~~~~~~ |
| |
| |
| Global |
| ^^^^^^ |
| |
| * The change status is shown in a separate column on dashboards and search results. |
| |
| Change Screens |
| ^^^^^^^^^^^^^^ |
| |
| |
| * New change screen with completely redesigned UI, using the REST API. |
| + |
| Site administrators can |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#gerrit.changeScreen[ |
| configure which change screen is shown by default]. |
| + |
| Users can choose which one to use in their personal preferences, either using |
| the site default or explicitly choosing the old one or new one. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=141[Issue 141]: |
| In the new change screen, comments can be added on a range of lines. |
| |
| * New button to cherry-pick the change to another branch. |
| |
| * When issuing a rebase via the Web UI, the committer is now the logged in |
| user, rather than "Gerrit Code Review". |
| + |
| If the user has more than one email address, the preferred email address will |
| be used. |
| |
| * Default user's full name to git committer name if user has not configured a |
| full name in their profile. |
| |
| * Include comment author attributes in comment panels. |
| + |
| Comment author's email address and name are included as attributes in comment |
| panels. This makes it easier to filter out CI-based comments using user |
| scripts. |
| |
| * Copy reviewed flag to new patch sets for identical files. |
| + |
| If a user has already seen and reviewed a file, the 'reviewed' flag is forwarded |
| on to the next patch set when the content of the file in the next patch set is |
| identical to the reviewed file. |
| |
| * "Uploaded Patch Set 1" change message is added on changes when they |
| are uploaded. |
| |
| |
| REST API |
| ~~~~~~~~ |
| |
| * Several new link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api.html[ |
| REST API endpoints] are added. |
| |
| * REST views can determine how long their response should be cached. |
| |
| * REST views can handle 'HTTP 422 Unprocessable Entity' responses. |
| |
| Access Rights |
| ^^^^^^^^^^^^^ |
| |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-access.html#list-access[ |
| List access rights for project(s)] |
| |
| Accounts |
| ^^^^^^^^ |
| |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#create-account[ |
| Create account] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-account-name[ |
| Get account full name] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#set-account-name[ |
| Set account full name] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#delete-account-name[ |
| Delete account full name] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#list-account-emails[ |
| List account email addresses] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-account-email[ |
| Get account email address] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#set-preferred-email[ |
| Set account preferred email address] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#create-account-email[ |
| Create account email] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#delete-account-email[ |
| Delete account email] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-active[ |
| Get account state] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#set-active[ |
| Set account state to active] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#delete-active[ |
| Set account state to inactive] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-http-password[ |
| Get account HTTP password] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#set-http-password[ |
| Set or generate account HTTP password] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#delete-http-password[ |
| Delete account HTTP password] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#list-ssh-keys[ |
| List account SSH keys] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-ssh-key[ |
| Get account SSH key] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#add-ssh-key[ |
| Add account SSH key] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#delete-ssh-key[ |
| Delete account SSH key] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-username[ |
| Get account username] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#get-starred-changes[ |
| Get starred changes] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#star-change[ |
| Star change] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-accounts.html#unstar-change[ |
| Unstar change] |
| |
| Changes |
| ^^^^^^^ |
| |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#rebase-change[ |
| Rebase change] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#cherry-pick[ |
| Cherry-pick revision] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#get-content[ |
| Get content of a file in a revision] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#get-patch[ |
| Get revision as a formatted patch] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#get-diff[ |
| Get diff of a file in a revision] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#get-commit[ |
| Get parsed commit of a revision] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#publish-draft-change[ |
| Publish draft change] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#delete-draft-change[ |
| Delete draft change] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#suggest-reviewers[ |
| Suggest reviewers] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-changes.html#get-included-in[ |
| Get included in] |
| |
| |
| Config |
| ^^^^^^ |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-config.html#get-capabilities[ |
| Get capabilities] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-config.html#get-version[ |
| Get version] (of the Gerrit server) |
| |
| |
| Projects |
| ^^^^^^^^ |
| |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#list-branches[ |
| List branches] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#get-branch[ |
| Get branch] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#create-branch[ |
| Create branch] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#delete-branch[ |
| Delete branch] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#list-child-projects[ |
| List child projects] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#get-child-project[ |
| Get child project] |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/rest-api-projects.html#set-config[ |
| Set configuration] |
| |
| |
| Capabilities |
| ~~~~~~~~~~~~ |
| |
| |
| New global capabilities are added. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/access_control.html#capability_generateHttpPassword[ |
| Generate Http Password] allows non-administrator users to generate HTTP |
| passwords for users other than themselves. |
| + |
| This capability would typically be assigned to a non-interactive group |
| to be able to generate HTTP passwords for users from a tool or web service |
| that uses the Gerrit REST API. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/access_control.html#capability_runAs[ |
| Run As] allows users to impersonate other users by setting the `X-Gerrit-RunAs` |
| HTTP header on REST API calls. |
| + |
| Site administrators do not inherit this capability; it must be granted |
| explicitly. |
| |
| |
| Emails |
| ~~~~~~ |
| |
| * The `RebasedPatchSet` template is removed. Email notifications for rebased |
| changes are now sent with the `ReplacePatchSet` template. |
| |
| * Comment notification emails now include context of comments that are replied |
| to, and links to the file(s) in which comments are made. |
| |
| |
| Plugins |
| ~~~~~~~ |
| |
| |
| Global |
| ^^^^^^ |
| |
| |
| * Plugins may now contribute buttons to various parts of the UI using the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#ui_extension[ |
| UI extension] and |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/js-api.html[ |
| JavaScript API]. |
| |
| * Plugins may now provide an 'About' section on their documentation index page. |
| |
| * Plugins may now provide separate sections for REST API and servlet |
| documentation on their index page. |
| |
| * Plugins may now provide |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-validation.html#pre-merge-validation[ |
| pre-merge validation steps]. |
| |
| * Plugins may now provide |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#capabilities[ |
| Global capabilities]. |
| |
| * Plugins may now |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#plugin_name[ |
| define their own name] and get the name injected at runtime. |
| |
| * The "hello world" plugin is replaced with the "cookbook plugin" which has more |
| examples of the plugin API's usage. |
| |
| * Plugins may now trigger and listen to a "project deleted" |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#events[ |
| event]. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2101[Issue 2101]: |
| Plugins implementing LifecycleListener can use auto registration. |
| |
| * Plugins may bind REST endpoints with empty view names. |
| |
| * Plugins may now provide |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#top-menu-extensions[ |
| entries in Gerrit's top menu]. |
| |
| * Plugins may now |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#stream-events[ |
| send events to the events stream]. |
| |
| * Plugins may now bind multiple SSH commands to the same implementation class. |
| |
| * Plugins may now provide |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/dev-plugins.html#download-commands[ |
| download schemes and download commands]. |
| + |
| Commonly used download schemes and commands are moved out of core |
| Gerrit and are now implemented by a new core plugin, `download-commands`. |
| |
| |
| |
| Commit Message Length Checker |
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| |
| |
| * Commits whose subject or body length exceeds the limit can be rejected. |
| |
| Replication |
| ^^^^^^^^^^^ |
| |
| * Automatically create missing repositories on the destination. |
| + |
| If during the replication of a ref the target repository is found to be missing, |
| the repository is automatically created. |
| + |
| This is a change in behavior of the replication plugin. To go back to the old |
| behavior, set the parameter `remote.NAME.createMissingRepositories` in the |
| `replication.config` file to `false`. |
| |
| * Support for replication of project deletions. |
| + |
| The replication plugin can now be configured to listen to project deletion events |
| and to replicate the project deletions. By default project deletions are *not* |
| replicated. |
| |
| * The `{$name}` placeholder is optional when replicating a single project, |
| allowing a single project to be replicated under a different name. |
| |
| * Project names can be matched with wildcard or regex patterns in `replication.config`. |
| |
| * The `replication start` command does not exit until replication is finished |
| when the `--wait` option is used. |
| |
| * The `replication start` command displays a summary of the replication status. |
| |
| * Retry counts are added to replication task names, so they can be seen in the |
| output of the `show-queue` command. |
| |
| * The `remoteNameStyle` option can be set to `basenameOnly` to replicate projects |
| using only the basename on the target server. |
| |
| * The `startReplication` global capability is now provided by the plugin. |
| |
| * Pushes to each destination URI are serialized. |
| + |
| Scheduling a retry to avoid collision with an in-flight push is differentiated |
| from a retry due to a transport error. In the case of collision avoidance, the |
| job is rescheduled according to the replication delay, rather than the retry |
| delay. |
| |
| |
| ssh |
| ~~~ |
| |
| |
| * The `commit-msg` hook installation command is now |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-gerrit.html#gerrit.installCommitMsgHookCommand[ |
| configurable]. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-ls-members.html[ |
| New `ls-members` command]. |
| |
| * link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-set-members.html[ |
| New `set-members` command]. |
| + |
| New command to manipulate group membership. Members can be added or removed |
| and groups can be included or excluded in one specific group or number of groups. |
| |
| * The full commit message is now included in the data sent by the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-stream-events.html[ |
| `stream-events` command]. |
| |
| * The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-show-queue.html[ |
| `show-queue` command] now shows the time that a task was added to the queue. |
| |
| * The deprecated `approve` alias of the `review` command is removed. |
| |
| * The 'CHANGEID,PATCHSET' format for specifying a patch set in the `review` command |
| is no longer considered to be a 'legacy' feature that will be removed in future. |
| |
| Daemon |
| ~~~~~~ |
| |
| |
| * Add `--init` option to Daemon to initialize site on daemon start. |
| + |
| The `--init` option will also upgrade an already existing site and is processed in |
| non-interactive (batch) mode. |
| |
| |
| Bug Fixes |
| --------- |
| |
| |
| General |
| ~~~~~~~ |
| |
| |
| * Use the parent change on the same branch for rebases. |
| + |
| Since there can be multiple changes with the same commit on different branches, |
| use the parent change on the same branch during rebase. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=600[Issue 600]: |
| Fix change stuck in SUBMITTED state but actually merged. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1699[Issue 1699]: |
| Fix handling of projects with trailing ".git" suffix. |
| |
| * Limit retrying of submitted changes to 12 hours. |
| |
| * Don't allow project owners to delete branches if force push is blocked. |
| |
| * Allow usernames to begin with digit. |
| |
| * Verify access to source ref during add branch operation. |
| + |
| Previously Gerrit didn't check access to source ref during add branch |
| operation. Because of that users could create a branch from any known |
| commit SHA1, even when they didn't have access to that commit. |
| |
| * Fix Gerrit API sources JAR contents. |
| + |
| The gerrit-extension-api-X.Y-all-sources.jar did not actually contain any |
| sources. |
| |
| * Generate javadoc for Gerrit Extension and Plugin APIs. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2244[Issue 2244]: |
| Update patch status before skipping duplicate emails. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1640[Issue 1640]: |
| Catch missing LDAP accounts in group membership. |
| |
| * Use `rev-parse` to find gitdir when generating commit-msg hook hint. |
| |
| * Performance Fix: Minimize number of advertisedHaves. |
| + |
| By filtering the refs before the objectIds are added to advertisedHaves, |
| lots of time can be saved when pushing to complex Gits. |
| |
| |
| Configuration |
| ~~~~~~~~~~~~~ |
| |
| |
| * Do not persist default project state in `project.config`. |
| |
| * Honor the `gerrit.cannonicalWebUrl` setting when opening the browser after init. |
| |
| * Fix 'query disabled' error when Query Limit is set. |
| |
| * Honor the `gerrit.createChangeId` setting from the git config in the |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-hook-commit-msg.html[ |
| `commit-msg` hook]. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2045[Issue 2045]: |
| Define user scope when parsing server config. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1990[Issue 1990]: |
| Support optional Certificate Revocation List (CRL) with `CLIENT_SSL_CERT_LDAP`. |
| |
| * Do not override error and gc logging configuration provided by the |
| `-Dlog4j.configuration` parameter. |
| |
| * Fix JdbcSQLException when numbers are read from cache. |
| |
| Web UI |
| ~~~~~~ |
| |
| |
| Global |
| ^^^^^^ |
| |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1574[Issue 1574]: |
| Correctly highlight matches of text in escaped HTML entities in suggestion results. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1996[Issue 1996]: |
| The "Keyboard Shortcuts" help popup can be closed by pressing the Escape key. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2013[Issue 2013]: |
| Correctly populate the list of watched changes when watching more than one project. |
| |
| * Display "Working..." when header is hidden. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2125[Issue 2125]: |
| Correctly shows '-1' instead of '1' for label score. |
| + |
| If a user voted '-1', and then another user voted '+1' for a label, the |
| label was shown as a red '1' in the change list instead of red '-1'. |
| |
| Change Screens |
| ^^^^^^^^^^^^^^ |
| |
| |
| * Default review comment visibility is changed to expand all recent. |
| + |
| By default all comments within the last week are expanded, rather than |
| only the most recent. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1814[Issue 1814]: |
| Sort labels alphabetically by name in the approval table. |
| |
| * Don't add "This patchset was cherry picked to ..." for the same change. |
| + |
| If a patchset is cherry-picked to the same destination branch and |
| ends up on the same change, it does not make sense to add the "This |
| patchset was cherry picked to change ..." message. |
| + |
| In this case, it makes more sense for the message to say "Uploaded |
| patch set N" instead. |
| |
| * Make links appear with consistent colors. |
| |
| * Prevent duplicate permitted_labels from being shown in labels list. |
| |
| Diff Screens |
| ^^^^^^^^^^^^ |
| |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1233[Issue 1233]: |
| Prevent expansion when whole file isn't loaded. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2122[Issue 2122]: |
| Show review comments for unchanged files. |
| + |
| When comparing patch sets and some comment was put in one side, |
| that comment was not shown if there was no code changed between |
| the two patch sets |
| |
| Project Screens |
| ^^^^^^^^^^^^^^^ |
| |
| |
| * Only enable the delete branch button when branches are selected. |
| |
| * Disable the delete branch button while branch deletion requests are |
| still being processed. |
| |
| User Profile Screens |
| ^^^^^^^^^^^^^^^^^^^^ |
| |
| |
| * The preferred email address field is shown as empty if the user has no |
| preferred email address. |
| |
| |
| REST API |
| ~~~~~~~~ |
| |
| |
| * Support raw input also in POST requests. |
| |
| * Show granted date for labels/all when using `/changes/`. |
| |
| * Return all revisions when `o=ALL_REVISIONS` is set on `/changes/`. |
| |
| ssh |
| ~~~ |
| |
| |
| * The `--force-message` option is removed from the |
| The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-review.html[ |
| `review` command]. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=1908[Issue 1908]: |
| Provide more informative error messages when rejecting updates. |
| |
| * Remove the limit in the query of patch sets by revision. |
| |
| * Add `isDraft` in the `patchSet` attribute of `stream-events` data. |
| + |
| This allows consumers of the event stream to determine whether or not |
| the event is related to a draft patch set. |
| |
| * Normalize the case of review labels submitted via the |
| The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/cmd-review.html[ |
| `review` command]. |
| |
| * The `@CommandMetaData(descr)` annotation is deprecated in favor of `@CommandMetaData(description)`. |
| |
| * Improve the error message when rejecting upload for review to a read-only project. |
| |
| |
| Plugins |
| ~~~~~~~ |
| |
| Global |
| ^^^^^^ |
| |
| * Better error message when a Javascript plugin cannot be loaded. |
| |
| * Plugin documentation links are opened in a new tab. |
| |
| * The GitReferenceUpdatedListener.Event API is simplified. |
| + |
| The Event exposed the getUpdates method which implied that one Event |
| could contain updates of more than one reference. However, this feature |
| was never used. |
| + |
| The API is simplified in the sense that one Event now corresponds to |
| one ref update only. |
| |
| * Make plugin servlet's context path authorization aware. |
| |
| |
| Review Notes |
| ^^^^^^^^^^^^ |
| |
| * Do not try to create review notes for ref deletion events. |
| |
| * Fix committing the notes from the export command. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2087[Issue 2087]: |
| Fix note creation when the same commit exists in another Git repository. |
| |
| * Improve the export command performance. |
| |
| * Create review note also when newObjectId already present in another branch. |
| |
| * Correct documentation of the export command. |
| |
| Emails |
| ~~~~~~ |
| |
| * Email notifications are sent for new changes created via actions in the |
| Web UI such as cherry-picking or reverting a change. |
| |
| |
| Tools |
| ~~~~~ |
| |
| |
| * git-exproll.sh: return non-zero on errors |
| |
| |
| Documentation |
| ------------- |
| |
| |
| * The link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/index.html[ |
| documentation index page] is rewritten in a hierarchical structure. |
| |
| * Documentation of |
| link:https://gerrit-documentation.storage.googleapis.com/Documentation/2.8/config-project-config.txt[ |
| project configuration] is added. |
| |
| * Various spelling mistakes are corrected in the documentation and previous |
| release notes. |
| |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2144[Issue 2144]: |
| Documentation of the query operator is fixed. |
| |
| |
| Upgrades |
| -------- |
| |
| * Update JGit to 3.1.0.201310021548-r |
| * Update gwtorm to 1.7 |
| * Update guice to 4.0-beta |
| * Update guava to 15.0 |
| * Update H2 to 1.3.173 |
| * Update bouncycastle to 1.44 |
| * Update Apache Mina to 2.0.7 |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2232[Issue 2232]: |
| Update Apache SSHD to 0.9.0.201311081 |
| * asciidoctor 0.1.4 is now required to build the documentation |
| * jsr305 library was removed |
| * link:https://code.google.com/p/gerrit/issues/detail?id=2232[Issue 2232]: |
| Update Jsch to 1.5.0 |