Google Gerrit
By - scmGalaxy.com
What is Gerrit
- Web based code review tool
- Repository management for Git
- Workflow management
- Integrated access control
- Extend using server side plugins
More
- 100% pure Java SSH and HTTP Git backend
- GWT Web-view administration
- Users and Groups
- Project and branch security
- Git repository browsing
- Git repository replication engine
- Code collaboration and review
- Code validation through Jenkins Triggers
Specifications
- Apache 2.0
- 93 included dependencies (Mostly Apache2.0, BSD, MPL1.1., EPL)
- Latest release 2.11.5
- 9 years old
How to Install Gerrit
- WAR file (Tomcat, Jetty etc)
- Self contained daemon (with embedded Jetty)
Pre-requisite
- JDK 1.7
- Database (MySql, PostgreSQL, Embedded H2)
Database Setup
- If you choose H2, Gerrit will automatically set up the embedded H2 database as backend so no set up or configuration is necessary.
Installation support
- Database Support
- For accounts, groups, metadata in database
- PostgreSQL, MySQL, or embedded H2
- Directory Support
- OpenID authentication (google, yahoo etc)
- LDAP (Users and Groups)
- HTTP
- Embedded Jetty
- Deployment of WAR to Tomcat, Jetty, etc.
- SSH
- Embedded pure java SSH daemon on port 29418 (configurable)
Workflow
- Central git repository for entire team
- Code review are at commit level
- 5 New commits, 5 new reviews
- Search the dashboards show relevant review spanning repositories
Workflow cont..
- git clone url
- git commit -m"this is fix"
- git push origin HEAD:refs/for/master
Gerrit: high level workflow
Cool, isn't it ?
- Gerrit allow "automatic" topic-branches
- Triggers with Jenkins branch validation
- Enforce collective code-ownership
- People "interacts" with the code changes
- Discussion on style and architecture
- Democratic voting (+1 / -1)
- Project history
- Reason behind changes is recorded in code-review
See Gerrit "live" in action
1 . Create a User for host the Gerrit Service
- $ sudo adduser gerrit2
- $ sudo su gerrit2
2. Set-up
- Option-A: download and install
- Option-B: Gerrit as hosted service
- Assembla.com (free for OpenSource projects)
- GitEnterprise.com (free up to 10 users)
- Gerrit Config - $site_path/etc/gerrit.config
3. Add SSH keys
- Option-A: not easy ☹
- -
- Option-B: use the provider user registration
3. Talk to Gerrit via SSH
- Gerrit SSH console
- Listen at 29418 port
- Not a real SSH server (just Gerrit listening)
data:image/s3,"s3://crabby-images/457d4/457d47fa1b82808fb4c02dbb6362bc080df74cb0" alt=""
4. Create a Gerrit project
- Gerrit Project is:
- Git repository (use "path notation" to organise projects)
- Access permissions
- Code-review and change-sets
- Option-A: use Gerrit SSH command
$ ssh -p 29418 lmilanesio@localhost gerrit create-project lmit/33degree
- Option-B: user the provider-specific page
5. Clone repo from Gerrit
- Git SSH repository URL is:
ssh://<user>@<host>:29418/<Gerrit project>.git
- Gerrit supports HTTP or HTTP/S repository URL:
http://<Gerrit URL>/p/<Gerrit project>.git
NOTE: For HTTP authentication, put your credentials on ~/.netrc file
machine <hostname> login <username> password <password>
6. Gerrit Change-Id
- SHA-1 GUID of a change-set under review
- MUST be last line of commit msg
Now all Git commit will auto-generate a Change-Id !
7. Submit a change for review
- Change for review committed locally
- Push to refs/for/<branch> for submitting local Git changes for review on <branch>
data:image/s3,"s3://crabby-images/42b51/42b51fb39d0938a27cfb70c3e8731ee002992dcb" alt=""
8. Verify change against CI
data:image/s3,"s3://crabby-images/20e2c/20e2c7f1157bc46d3b6b5220c148fcd703e94574" alt=""
9. Additional patch-set to Change-Id
- Fix the problem locally
- Amend the commit (same Change-Id)
- Push again to refs/for/ for adding one extra change-set
10. Change-Id is validated against CI
data:image/s3,"s3://crabby-images/0a8f8/0a8f8f2e28b3e604d9f83a64cb5ce8cf6c1df083" alt=""
11. Review and comment changes
data:image/s3,"s3://crabby-images/ffff4/ffff459bc436146325065308218112ea8c362f82" alt=""
12. Review merge and submit change
- One or more reviewers can "vote" for the change
- Authorised users can then "Submit" the change.
- Change is automatically merged to master
13. Master build is triggered ... SUCCESS !!
data:image/s3,"s3://crabby-images/1815c/1815ca9812da729111d30fe90c5cc4a8277bca2f" alt=""
... is just about code-review then ?
data:image/s3,"s3://crabby-images/dcf9d/dcf9d9c3a78a152a928936a2d8b534102314d373" alt=""
Credits and resources
Slides available at http://www.slideshare.net/lucamilanesio Follow me: @lucamilanesio
Gerrit: just code-review then ?
- Git Security - Groups
- Define different "roles" in the project
- System groups
- Anonymous users: use for public projects
- Registered Users: all users
- Administrators: to administer Gerrit
- Project Owners: to administer projects
- Non-interactive Users: for CI or batch operations
- Groups can be hierarchical (groups of groups)
Define groups and members
data:image/s3,"s3://crabby-images/6a75e/6a75e95c40398e9c71e95a94168844c47b0682b5" alt=""
Putting all together with projects
- Git Security: rights to projects
- Define access rights to Git operations
- Control the Gerrit identity vs Git author / committer
- Delegate project administration
- Assign code-review voting range rights
- Define who can submit and merge changes
- Organise project rights hirarchically
Define project access rights per refspec
data:image/s3,"s3://crabby-images/739c4/739c49133ed69eef10962481b6e0b5be5a215237" alt=""
Assign access rights to Groups
data:image/s3,"s3://crabby-images/7156d/7156db7e403c651d46ca5953aaef116ee582f776" alt=""
... and Gerrit replication
data:image/s3,"s3://crabby-images/03e11/03e11daac1760601556299a371888f957440d9ca" alt=""
Gerrit UI
data:image/s3,"s3://crabby-images/ce5ee/ce5eee469f55e5a3f60dc4afaab80187275193b8" alt=""