© Copyright 2012 MeetMe, Inc. Maintainer: Joe Hansche [email protected]
This is a fork of the original JIRA-Gerrit integration plugin but with the added functionality of being able to choose fetching changes from either the pre-existing SSH-endpoint or utilising Gerrit's Rest-Api. This feature requires a modified gerrit-events-dependency, which source code can be found here. The added functionality is fully tested.
- the
admin.vm
template now features Rest-configuration options - the existing gerrit-events-dependency has been replaced by a modified one, which can establish connections to rest-endpoints.
- the edited dependency is kept in a local repository at
/src/main/ressources/gerrit-events
,
- the edited dependency is kept in a local repository at
AdminServlet
can, in addition to the SSH-endpoint, also test its connection to Gerrit's rest-api-endpoint.IssueReviewsCacheLoader
can use gerrit-event's newGerritQueryHandlerHttp
-class to cache changes.- both
GerritChange
andGerritPatchSet
have "fromJsonRest()" functionality.
Please see the file named LICENSE.
- Available in the JIRA Marketplace for automatic installation from the JIRA "Find New Plugins" administration panel.
- Alternatively, you can also download the JAR from the above URL, and install it manually from the "Manage Plugins" administration panel.
-
Generate an SSH keypair for the JIRA user
- Save the private key in a place where you can upload it to JIRA (1)
- The public key will simply be copied/pasted (2)
-
Create a new user in Gerrit that you will use for the integration:
$ ssh gerrit.company.com -p 29418 gerrit create-account jira --email [email protected] --full-name JIRA --ssh-key <paste public key (2)>
-
In JIRA, navigate to Administration > Plugins > Gerrit Admin
-
Enter hostname, port, and user under the SSH section
-
Upload the SSH private key generated at (1) above
-
Optionally change the Gerrit search query patterns:
tr:%s
- Look for the issue key in a "Bug:" or "Issue:" footertopic:%s
- Look for the issue key in the change Topic (uploaded usingHEAD:refs/for/master/(issueKey)
)message:%s
- Look for the issue key in the commit message
- "Gerrit Reviews" issue tab panel to show all reviews related to the issue
- "Gerrit Subtask Reviews" issue tab panel to show reviews related to all the issue's subtasks
- Workflow condition to require that an issue must (or must not) have any open reviews
- Workflow condition to require that an issue must (or must not) have a certain approval score (e.g., Code-Review == 2, or ! Verified < 0)
- Workflow function to perform a Gerrit review
- This is just an argument to the
gerrit review [ChangeId] ..
command, so it could be something like--verified +1
to give a +1 score; or--submit
to submit the change - The Gerrit user configured in the admin panel must have access to perform all necessary steps
- This is just an argument to the
- Unit Tests (partial)
- Possibly per-user SSH key configurations (instead of everything done as the JIRA user)
- Possibly allow a second "suexec" SSH key so the JIRA user can spoof the acting JIRA user as a Gerrit user
Extend SshConnection in order to obtain stderr content, to know if a command failed; this is no longer required, after our patch was accepted to the gerrit-trigger-plugin project- Resolve
gerrit-events
dependency so it does not rely on a SNAPSHOT version