blob: d36a24d40a738e8ebc7467a2a58176e4596600d8 [file] [log] [blame] [view]
# Developer Guide
[TOC]
## Building
Gitiles requires [Bazel](https://bazel.build/) to build.
You need to use Java for building Gitiles. You can install Bazel from
bazel.build: https://bazel.build/versions/master/docs/install.html .
Alternatively, you can use `apt-get`.
```
$ sudo apt-get update
$ sudo apt-get install bazel
```
The best way to build and run gitiles is to use bazelisk.
```
$ go install github.com/bazelbuild/bazelisk@latest
$ export PATH=$PATH:$(go env GOPATH)/bin
```
Make sure to initialize and update the git submodules:
```
git submodule update --init
```
You are now ready to build and test.
```
$ bazelisk build //:gitiles
$ bazelisk test //...
```
## Troubleshooting
If you encounter build errors such as:
```
Error in execute: Argument 0 of execute is neither a path, label, nor string.
```
Make sure you have `python` available in your PATH. Since Debian 11 and Ubuntu
20.04 LTS (focal), there is no `/usr/bin/python` provided by default. You can
install a package to provide a link to Python 3:
```
sudo apt-get install python-is-python3
```
Upon uploading your new CL, if you encounter a message related to a
missing `Change-Id`, you are missing the commit hook. Likely the command
to download it should appear in the Hint section of the message. If it
does not, use the following command:
```
f=`git rev-parse --git-dir`/hooks/commit-msg ; mkdir -p $(dirname $f) ; curl -Lo $f https://gerrit-review.googlesource.com/tools/hooks/commit-msg ; chmod +x $f
```
## Running Locally and Testing
```
cd /path/to/repositories # Don't run from the gitiles repo.
/path/to/gitiles/tools/run_dev.sh
```
This will recompile and start a development server. Open
http://localhost:8080/ to view your local copy of gitiles, which
will serve any repositories under `/path/to/repositories`.
Passing `--debug` option to `tools/run_dev.sh` will suspend the runtime until a
remote debugger connects to port 5005. If you don't want to suspend the
runtime, make sure to assign value `n` to environment variable
`DEFAULT_JVM_DEBUG_SUSPEND`:
```
cd /path/to/repositories # Don't run from the gitiles repo.
export DEFAULT_JVM_DEBUG_SUSPEND=n; /path/to/gitiles/tools/run_dev.sh --debug
```
To run unit tests, refer to the aforementioned bazel test command.
## Pushing your changes
This repository does not work with `repo` tool. To push your CL to
staging, use the following command.
```
git push origin HEAD:refs/for/master
```
## Eclipse IDE
If you'd like to use Eclipse to edit Gitiles, first generate a project file:
```
tools/eclipse/project.sh
```
Import the project in Eclipse:
```
File -> Import -> Existing Projects into Workpace
```
The project only needs to be rebuilt if the source roots or third-party
libraries have changed. For best results, ensure the project is closed in
Eclipse before rebuilding.
## Running/Debugging from Eclipse IDE
Running Gitiles from Eclipse requires setting the
`com.google.gitiles.sourcePath` system property. The property value has to be
the root folder of the Gitiles source code, for example:
````
-Dcom.google.gitiles.sourcePath=/home/johndoe/git/gitiles
````
## Code Style
Java code in Gitiles follows the [Google Java Style Guide][java-style]
with a 100-column limit.
Code should be automatically formatted using [google-java-format][fmt]
prior to sending a code review. There is currently no Eclipse
formatter, but the tool can be run from the command line:
```
java -jar /path/to/google-java-format.jar -i path/to/java/File.java
```
CSS in Gitiles follows the [SUIT CSS naming conventions][suit].
[java-style]: https://google.github.io/styleguide/javaguide.html
[fmt]: https://github.com/google/google-java-format
[suit]: https://github.com/suitcss/suit/blob/master/doc/naming-conventions.md
## Code Review
Gitiles uses Gerrit for code review:
https://gerrit-review.googlesource.com/
Gitiles uses the ["git push" workflow][1] with server
https://gerrit.googlesource.com/gitiles. You will need a
[generated cookie][2].
[1]: https://gerrit-review.googlesource.com/Documentation/user-upload.html#_git_push
[2]: https://gerrit.googlesource.com/new-password
Gerrit depends on "Change-Id" annotations in your commit message.
If you try to push a commit without one, it will explain how to
install the proper git-hook:
```
curl -Lo `git rev-parse --git-dir`/hooks/commit-msg \
https://gerrit-review.googlesource.com/tools/hooks/commit-msg
chmod +x `git rev-parse --git-dir`/hooks/commit-msg
```
Before you create your local commit (which you'll push to Gerrit)
you will need to set your email to match your Gerrit account:
```
git config --local --add user.email foo@bar.com
```
Normally you will create code reviews by pushing for master:
```
git push origin HEAD:refs/for/master
```
## Releases
Gitiles artifacts are published to the [gerrit-maven
bucket](http://gerrit-maven.storage.googleapis.com/). To release a new version,
you must have write access to this bucket. See
[Deploy Gerrit
Artifacts](https://gerrit-review.googlesource.com/Documentation/dev-release-deploy-config.html)
for PGP key setup and Google Cloud Storage access setup.
First, increment `GITILES_VERSION` in `version.bzl`, Gitiles uses
[Semantic Versioning](https://semver.org).
Get your change reviewed and submitted.
Then, run:
```
./tools/maven/mvn.sh deploy
```
Tag the release with a signed, annotated tag matching the version number, for
example "v1.1.0".
Once released, Maven projects can consume the new version as long as they point
at the proper repository URL. Similarly, Bazel projects using the `maven_jar`
bazlet can use the new version with `repository = GERRIT`.