blob: 383c7096d297a3daa365133da9054afc8aba2f4f [file] [log] [blame]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -08001= Gerrit Code Review - Developer Setup
Shawn O. Pearced2b73db2009-01-09 11:55:47 -08002
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +01003Bazel or Facebook Buck is needed to compile the code, and an SQL database to
David Ostrovskydcee5722013-05-15 00:10:55 +02004house the review metadata. H2 is recommended for development
5databases, as it requires no external server process.
Shawn O. Pearced2b73db2009-01-09 11:55:47 -08006
David Pursehousefec58792013-05-10 15:34:02 +01007
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -08008== Getting the Source
Shawn O. Pearced2b73db2009-01-09 11:55:47 -08009
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080010Create a new client workspace:
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080011
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080012----
David Pursehouse4f2be532013-05-09 13:47:17 +010013 git clone --recursive https://gerrit.googlesource.com/gerrit
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080014 cd gerrit
15----
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080016
David Pursehouse4f2be532013-05-09 13:47:17 +010017The `--recursive` option is needed on `git clone` to ensure that
18the core plugins, which are included as git submodules, are also
19cloned.
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080020
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010021[[compile_project]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080022== Compiling
David Pursehouse6de7ee22013-05-20 11:08:51 +090023
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010024Please refer to either <<dev-buck#,Building with Buck>> or
25<<dev-bazel#,Building with Bazel>>.
David Pursehouse6de7ee22013-05-20 11:08:51 +090026
27
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080028== Switching between branches
David Pursehoused106c8e2013-12-13 15:03:02 +090029
30When switching between branches with `git checkout`, be aware that
31submodule revisions are not altered. This may result in the wrong
32plugin revisions being present, unneeded plugins being present, or
33expected plugins being missing.
34
35After switching branches, make sure the submodules are at the correct
36revisions for the new branch with the commands:
37
38----
39 git submodule update
40 git clean -fdx
41----
42
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010043CAUTION: If you decide to store your Eclipse/IntelliJ project files in the
44Gerrit source directories, executing `git clean -fdx` will remove them and hence
45screw up your project.
46
David Pursehoused106c8e2013-12-13 15:03:02 +090047
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080048== Configuring Eclipse
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080049
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080050To use the Eclipse IDE for development, please see
David Pursehousefec58792013-05-10 15:34:02 +010051link:dev-eclipse.html[Eclipse Setup].
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080052
David Pursehouse5d9ef412013-05-22 13:33:45 +090053For details on how to configure the Eclipse workspace with Buck,
54refer to: link:dev-buck.html#eclipse[Eclipse integration with Buck].
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080055
Shawn O. Pearced2b73db2009-01-09 11:55:47 -080056
Urs Wolferc0948bd2014-04-27 21:16:25 +020057== Configuring IntelliJ IDEA
58
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010059=== Build based on Buck
60
Urs Wolferc0948bd2014-04-27 21:16:25 +020061To use IntelliJ IDEA for development, the easiest way is to follow
62Eclipse integration and then open it as Eclipse project in IDEA.
63You need the Eclipse plugin activated in IntelliJ IDEA.
64
Marco Millere7790b22015-03-16 10:28:26 -040065Once you start compiling using both buck and your Gerrit project in
66IDEA, you will likely need to mark the below directories as generated
67sources roots. You can do so using the IDEA "Project" view. In the
68context menu of each one of these, use "Mark Directory As" to mark
69them as "Generated Sources Root":
70
71----
72 __auto_value_tests_gen__
73 __httpd_gen__
74 __server_gen__
75----
Urs Wolferc0948bd2014-04-27 21:16:25 +020076
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010077=== Build based on Bazel
78
Alice Kober-Sotzekd9da89f2016-11-25 12:02:18 +010079Please refer to <<dev-intellij#,IntelliJ Setup>> for detailed
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010080instructions.
81
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080082== Mac OS X
David Pursehousefec58792013-05-10 15:34:02 +010083
Khai Doea9e4b72014-03-30 07:43:31 -070084On Mac OS X ensure "Java For Mac OS X 10.5 Update 4" (or later) has
85been installed, and that `JAVA_HOME` is set to the
86link:install.html#Requirements[required Java version].
Shawn O. Pearce461c2cc2009-02-25 09:09:31 -080087
Khai Doea9e4b72014-03-30 07:43:31 -070088Java installations can typically be found in
89"/System/Library/Frameworks/JavaVM.framework/Versions".
90
91You can check the installed Java version by running `java -version` in
92the terminal.
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080093
94[[init]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -080095== Site Initialization
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080096
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +010097After compiling <<compile_project,(above)>>, run Gerrit's 'init' command to
98create a testing site for development use:
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -080099
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100100.Build based on Buck
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800101----
David Ostrovskyf377aa92015-09-14 17:46:28 +0900102 java -jar buck-out/gen/gerrit/gerrit.war init -d ../gerrit_testsite
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800103----
104
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100105.Build based on Bazel
106----
107 $(bazel info output_base)/external/local_jdk/bin/java \
108 -jar bazel-bin/gerrit.war init -d ../gerrit_testsite
109----
110
111[[special_bazel_java_version]]
112NOTE: You must use the same Java version that Bazel used for the build.
113This Java version is available at
114`$(bazel info output_base)/external/local_jdk/bin/java`.
115
Aaron Gable5eab7202016-10-12 11:24:06 -0700116During initialization, make two changes to the default settings:
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800117
Aaron Gable5eab7202016-10-12 11:24:06 -0700118* Change the listen addresses from '*' to 'localhost' to prevent outside
119 connections from contacting the development instance; and
120* Change the auth type from 'OPENID' to 'DEVELOPMENT_BECOME_ANY_ACCOUNT' to
121 allow yourself to create and act as arbitrary test accounts on your
122 development instance.
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800123
Aaron Gable5eab7202016-10-12 11:24:06 -0700124Continue through init until it completes. The daemon will automatically start in
125the background and a web browser will launch to the start page. From here you
126can sign in as the account created during init, register additional accounts,
127create projects, and more.
128
129When you want to shut down the daemon, simply run:
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800130
131----
David Pursehouse9db23782013-12-17 11:59:22 +0900132 ../gerrit_testsite/bin/gerrit.sh stop
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800133----
134
135
Aaron Gable5eab7202016-10-12 11:24:06 -0700136[[localdev]]
137== Working with the Local Server
138
139If you need to create additional accounts on your development instance, click
140'become' in the upper right corner, select 'Switch User', and then register
141a new account.
142
143Use the `ssh` protocol to clone from and push to the local server. For
144example, to clone a repository that you've created through the admin
145interface, run:
146
147----
148git clone ssh://username@localhost:29418/projectname
149----
150
151Then you'll be able to create changes the same way users do, with
152
153----
154git push origin HEAD:refs/for/master
155----
156
157
158
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800159== Testing
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800160
David Pursehousefec58792013-05-10 15:34:02 +0100161
David Pursehouse5861a9a2013-05-15 10:25:19 +0900162[[tests]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800163=== Running the Acceptance Tests
Edwin Kempin4a3fc3f2013-02-27 15:18:43 +0100164
165Gerrit has a set of integration tests that test the Gerrit daemon via
166REST, SSH and the git protocol.
167
168A new review site is created for each test and the Gerrit daemon is
169started on that site. When the test has finished the Gerrit daemon is
170shutdown.
171
David Ostrovskydcee5722013-05-15 00:10:55 +0200172For instructions on running the integration tests with Buck,
David Pursehouse5861a9a2013-05-15 10:25:19 +0900173please refer to:
David Pursehouse5d9ef412013-05-22 13:33:45 +0900174link:dev-buck.html#tests[Running integration tests with Buck].
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100175For Bazel, please refer to <<dev-bazel#tests,Running Unit Tests with Bazel>>.
Edwin Kempin4a3fc3f2013-02-27 15:18:43 +0100176
Alice Kober-Sotzekd9da89f2016-11-25 12:02:18 +0100177[[run_daemon]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800178=== Running the Daemon
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800179
180The daemon can be directly launched from the build area, without
181copying to the test site:
182
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100183.Build based on Buck
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800184----
Han-Wen Nienhuys0c93bc82017-01-19 15:26:42 +0100185 java -jar buck-out/gen/gerrit/gerrit.war daemon -d \
186 ../gerrit_testsite --console-log
187
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800188----
189
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100190.Build based on Bazel
191----
192 $(bazel info output_base)/external/local_jdk/bin/java \
Han-Wen Nienhuys0c93bc82017-01-19 15:26:42 +0100193 -jar bazel-bin/gerrit.war daemon -d ../gerrit_testsite \
194 --console-log
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100195----
196
197NOTE: Please refer to <<special_bazel_java_version,this explanation>>
198for details why using `java -jar` isn't sufficient.
199
200
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800201=== Running the Daemon with Gerrit Inspector
Marcin Cieślaked612fb2012-04-17 16:24:34 +0000202
203link:dev-inspector.html[Gerrit Inspector] is an interactive scriptable
204environment to inspect and modify internal state of the system.
205
206This environment is available on the system console after
207the system starts. Leaving the Inspector will shutdown the Gerrit
208instance.
209
210The environment allows interactive work as well as running of
211Python scripts for troubleshooting.
212
213Gerrit Inspect can be started by adding '-s' option to the
214command used to launch the daemon:
215
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100216.Build based on Buck
Marcin Cieślaked612fb2012-04-17 16:24:34 +0000217----
David Ostrovskyf377aa92015-09-14 17:46:28 +0900218 java -jar buck-out/gen/gerrit/gerrit.war daemon -d ../gerrit_testsite -s
Marcin Cieślaked612fb2012-04-17 16:24:34 +0000219----
220
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100221.Build based on Bazel
222----
223 $(bazel info output_base)/external/local_jdk/bin/java \
224 -jar bazel-bin/gerrit.war daemon -d ../gerrit_testsite -s
225----
226
227NOTE: Please refer to <<special_bazel_java_version,this explanation>>
228for details why using `java -jar` isn't sufficient.
229
Marcin Cieślaked612fb2012-04-17 16:24:34 +0000230Gerrit Inspector examines Java libraries first, then loads
231its initialization scripts and then starts a command line
232prompt on the console:
233
234----
235 Welcome to the Gerrit Inspector
236 Enter help() to see the above again, EOF to quit and stop Gerrit
237 Jython 2.5.2 (Release_2_5_2:7206, Mar 2 2011, 23:12:06)
238 [OpenJDK 64-Bit Server VM (Sun Microsystems Inc.)] on java1.6.0 running for Gerrit 2.3-rc0-163-g01967ef
239 >>>
240----
241
242With the Inspector enabled Gerrit can be used normally and all
243interfaces (HTTP, SSH etc.) are available.
244
245Care must be taken not to modify internal state of the system
246when using the Inspector.
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800247
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800248=== Querying the Database
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800249
250The embedded H2 database can be queried and updated from the
251command line. If the daemon is not currently running:
252
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100253.Build based on Buck
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800254----
David Ostrovskyf377aa92015-09-14 17:46:28 +0900255 java -jar buck-out/gen/gerrit/gerrit.war gsql -d ../gerrit_testsite
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800256----
257
Alice Kober-Sotzek4b92e042016-11-25 10:54:30 +0100258.Build based on Bazel
259----
260 $(bazel info output_base)/external/local_jdk/bin/java \
261 -jar bazel-bin/gerrit.war gsql -d ../gerrit_testsite -s
262----
263
264NOTE: Please refer to <<special_bazel_java_version,this explanation>>
265for details why using `java -jar` isn't sufficient.
266
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800267Or, if it is running and the database is in use, connect over SSH
268using an administrator user account:
269
270----
271 ssh -p 29418 user@localhost gerrit gsql
272----
273
274
Edwin Kempin57fa1792013-03-27 10:43:41 +0100275[[debug-javascript]]
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800276=== Debugging JavaScript
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800277
Shawn Pearced07a6222013-03-21 00:11:45 -0700278When debugging browser specific issues add `?dbg=1` to the URL so the
279resulting JavaScript more closely matches the Java sources. The debug
280pages use the GWT pretty format, where function and variable names
281match the Java sources.
282
283----
284 http://localhost:8080/?dbg=1
285----
286
Shawn O. Pearce6ddb6ca2009-09-18 18:10:31 -0700287
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800288== Client-Server RPC
Shawn O. Pearced2b73db2009-01-09 11:55:47 -0800289
290The client-server RPC implementation is gwtjsonrpc, not the stock RPC
291system that comes with GWT. This buys us automatic XSRF protection.
292It also makes all of the messages readable and writable by any JSON
293implementation, facilitating "mashups" and 3rd party clients.
294
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800295The programming API is virtually identical, except service interfaces
296extend RemoteJsonService instead of RemoteService.
Shawn O. Pearced2b73db2009-01-09 11:55:47 -0800297
298
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800299== Why GWT?
Shawn O. Pearced2b73db2009-01-09 11:55:47 -0800300
301We like it. Plus we can write Java code once and run it both in
Shawn O. Pearcee2bd1b12009-08-20 11:08:32 -0700302the browser and on the server side.
Shawn O. Pearce5500e692009-05-28 15:55:01 -0700303
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800304
Yuxuan 'fishy' Wang61698b12013-12-20 12:55:51 -0800305== External Links
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800306
307Google Web Toolkit:
308
309* http://code.google.com/webtoolkit/download.html[Download]
310
Shawn O. Pearce18f1f7f2009-12-16 11:32:39 -0800311Apache SSHD:
312
313* http://mina.apache.org/sshd/[SSHD]
314
315H2:
316
317* http://www.h2database.com/[H2]
318* http://www.h2database.com/html/grammar.html[SQL Reference]
319
320PostgreSQL:
321
322* http://www.postgresql.org/download/[Download]
323* http://www.postgresql.org/docs/[Documentation]
324
325
Shawn O. Pearce5500e692009-05-28 15:55:01 -0700326GERRIT
327------
328Part of link:index.html[Gerrit Code Review]
Yuxuan 'fishy' Wang99cb68d2013-10-31 17:26:00 -0700329
330SEARCHBOX
331---------