gerrit/Documentation/dev-readme.txt
David Pursehouse 4f2be538e7 Update developer instructions for cloning the Gerrit project
The core plugins are now included as git submodules.

When cloning the gerrit project, the --recursive option must be
used otherwise the submodules will not be cloned and the build
will not work.

Update the documentation accordingly.

Change-Id: I02decd68a1de061b60d3e7b6ce2ffdd24d12505a
2013-05-09 14:41:44 +01:00

284 lines
6.5 KiB
Plaintext

Gerrit Code Review - Developer Setup
====================================
Apache Maven is needed to compile the code, and a SQL database
to house the review metadata. H2 is recommended for development
databases, as it requires no external server process.
Get the Source
--------------
Create a new client workspace:
----
git clone --recursive https://gerrit.googlesource.com/gerrit
cd gerrit
----
The `--recursive` option is needed on `git clone` to ensure that
the core plugins, which are included as git submodules, are also
cloned.
Configuring Eclipse
-------------------
To use the Eclipse IDE for development, please see
link:dev-eclipse.html[Eclipse Setup] for more details on how to
configure the workspace with the Maven build scripts.
[[build]]
Building
--------
From the command line:
----
mvn clean package
----
By default the build will run tests and build the documentation.
To build without tests:
----
mvn clean package -DskipTests
----
To build without documentation:
----
mvn clean package -Dgerrit.documentation.skip
----
Output executable WAR will be placed in:
----
gerrit-war/target/gerrit-*.war
----
Mac OS X
~~~~~~~~
On Mac OS X ensure "Java For Mac OS X 10.5 Upate 4" (or later) has
been installed, and that `JAVA_HOME` is set to
"/System/Library/Frameworks/JavaVM.framework/Versions/1.6/Home".
Check the installed version by running `java -version` and looking
for 'build 1.6.0_13-b03-211'. Versions of Java 6 prior to this
version crash during the build due to a bug in the JIT compiler.
[[init]]
Site Initialization
-------------------
After compiling (above), run Gerrit's 'init' command to create a
testing site for development use:
----
java -jar gerrit-war/target/gerrit-*.war init -d ../test_site
----
Accept defaults by pressing Enter until 'init' completes, or add
the '\--batch' command line option to avoid them entirely. It is
recommended to change the listen addresses from '*' to 'localhost' to
prevent outside connections from contacting the development instance.
The daemon will automatically start in the background and a web
browser will launch to the start page, enabling login via OpenID.
Shutdown the daemon after registering the administrator account
through the web interface:
----
../test_site/bin/gerrit.sh stop
----
Testing
-------
[[run-acceptance-tests]]
Running the Acceptance Tests
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Gerrit has a set of integration tests that test the Gerrit daemon via
REST, SSH and the git protocol.
A new review site is created for each test and the Gerrit daemon is
started on that site. When the test has finished the Gerrit daemon is
shutdown.
Since the acceptance tests are too expensive to run every time
Gerrit is built, they are only executed during the Maven verify phase
if the Maven profile `acceptance` is enabled.
To execute the acceptance tests run:
----
mvn clean verify -Pacceptance
----
Running the Daemon
~~~~~~~~~~~~~~~~~~
The daemon can be directly launched from the build area, without
copying to the test site:
----
java -jar gerrit-war/target/gerrit-*.war daemon -d ../test_site
----
Querying the Database
~~~~~~~~~~~~~~~~~~~~~
The embedded H2 database can be queried and updated from the
command line. If the daemon is not currently running:
----
java -jar gerrit-war/target/gerrit-*.war gsql -d ../test_site
----
Or, if it is running and the database is in use, connect over SSH
using an administrator user account:
----
ssh -p 29418 user@localhost gerrit gsql
----
[[debug-javascript]]
Debugging JavaScript
~~~~~~~~~~~~~~~~~~~~
When debugging browser specific issues add `?dbg=1` to the URL so the
resulting JavaScript more closely matches the Java sources. The debug
pages use the GWT pretty format, where function and variable names
match the Java sources.
----
http://localhost:8080/?dbg=1
----
To use the GWT DETAILED style the package must be recompiled and
`?dbg=1` must be omitted from the URL:
----
mvn package -Dgwt.style=DETAILED
----
[[test-rest-api]]
Testing the REST API
~~~~~~~~~~~~~~~~~~~~
Basic testing of REST API functionality can be done with `curl`:
----
curl http://localhost:8080/path/to/api/
----
By default, `curl` sends `GET` requests. To test APIs with `PUT` or `POST`,
an additional argument is required:
----
curl -X PUT http://localhost:8080/path/to/api/
curl -X POST http://localhost:8080/path/to/api/
----
Some REST APIs accept data in the request body of `PUT` and `POST` requests.
Test data can be included from a local file:
----
curl -X PUT -d@testdata.txt --header "Content-Type: application/json" http://localhost:8080/path/to/api/
----
To test APIs that require authentication, the username and password must be specified on
the command line:
----
curl --digest --user username:password http://localhost:8080/path/to/api
----
This makes it easy to switch users for testing of permissions.
It is also possible to test with a username and password from the `.netrc`
file (on Windows, `_netrc`):
----
curl --digest -n http://localhost:8080/a/path/to/api/
----
In both cases, the password should be the user's link:user-upload.html#http[HTTP password].
Release Builds
--------------
To create a release build for a production server, or deployment
through the download site:
----
./tools/release.sh
----
If AsciiDoc isn't installed or is otherwise unavailable, the WAR
can still be built without the embedded documentation by passing
an additional flag:
----
./tools/release.sh --without-documentation
----
Client-Server RPC
-----------------
The client-server RPC implementation is gwtjsonrpc, not the stock RPC
system that comes with GWT. This buys us automatic XSRF protection.
It also makes all of the messages readable and writable by any JSON
implementation, facilitating "mashups" and 3rd party clients.
The programming API is virtually identical, except service interfaces
extend RemoteJsonService instead of RemoteService.
Why GWT?
--------
We like it. Plus we can write Java code once and run it both in
the browser and on the server side.
External Links
--------------
Google Web Toolkit:
* http://code.google.com/webtoolkit/download.html[Download]
Apache Maven:
* http://maven.apache.org/download.html[Download]
* http://maven.apache.org/run-maven/index.html[Running]
Apache SSHD:
* http://mina.apache.org/sshd/[SSHD]
H2:
* http://www.h2database.com/[H2]
* http://www.h2database.com/html/grammar.html[SQL Reference]
PostgreSQL:
* http://www.postgresql.org/download/[Download]
* http://www.postgresql.org/docs/[Documentation]
GERRIT
------
Part of link:index.html[Gerrit Code Review]