blob: 9c20e5c2fc1931ae26a18f97b4aeead92f589bcb [file] [log] [blame] [view]
Build
=====
This plugin is built with Bazel, and two build modes are supported:
* Standalone
* In Gerrit tree
Standalone build mode is recommended, as this mode doesn't require local Gerrit
tree to exist. Moreover, there are additional manual steps required when building
in Gerrit tree mode (see corresponding section).
## Build standalone
To build the plugin, issue the following command:
```
bazel build @PLUGIN@
```
The output is created in
```
bazel-genfiles/@PLUGIN@.jar
```
To package the plugin sources run:
```
bazel build lib@PLUGIN@__plugin-src.jar
```
The output is created in:
```
bazel-bin/lib@PLUGIN@__plugin-src.jar
```
To execute the tests run:
```
bazel test //...
```
This project can be imported into the Eclipse IDE:
```
./tools/eclipse/project.sh
```
## Build in Gerrit tree
Clone (or link) this plugin to the `plugins` directory of Gerrit's source
tree.
```
git clone https://gerrit.googlesource.com/gerrit
git clone https://gerrit.googlesource.com/plugins/@PLUGIN@
cd gerrit/plugins
ln -s ../../@PLUGIN@ .
```
Put the external dependency Bazel build file into the Gerrit /plugins
directory, replacing the existing empty one.
```
cd gerrit/plugins
rm external_plugin_deps.bzl
ln -s @PLUGIN@/external_plugin_deps.bzl .
```
From Gerrit source tree issue the command:
```
bazel build plugins/@PLUGIN@
```
The output is created in
```
bazel-genfiles/plugins/@PLUGIN@/@PLUGIN@.jar
```
To execute the tests run:
```
bazel test plugins/@PLUGIN@:@PLUGIN@_tests
```
or filtering using the comma separated tags:
````
bazel test --test_tag_filters=@PLUGIN@ //...
````
This project can be imported into the Eclipse IDE.
Add the plugin name to the `CUSTOM_PLUGINS` set in
Gerrit core in `tools/bzl/plugins.bzl`, and execute:
```
./tools/eclipse/project.py
```