forked from getodk/aggregate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCONFIGURE.txt
440 lines (309 loc) · 14.6 KB
/
CONFIGURE.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
Configuring your Build Environment
----------------------------------
The build tree relies on Maven 3 for executing unit tests and
integration tests across the 3 platforms (GAE, MySQL, PostgreSQL).
The source tree is in the top level project within Maven. The
directories underneath are Eclipse projects and/or Maven
sub-projects.
If you're a Maven expert and have suggestions about the Maven
project tree, please contact [email protected]
=====================
Minimal Eclipse Setup
---------------------
For executing only in Eclipse with the bare minimum, you need the
odk-gae-settings project and the eclipse-aggregate-gae
project. These should not require any Maven setup.
Skip to the next section if you want a fully configured development environment.
The steps required are:
(0) Install the latest Java 7 SDK
(1a) Install Eclipse IDE for Java EE -- Kepler (4.3.2). Luna has not been tested.
(1b) Increase the start-up memory sizes for the Eclipse workspace as detailed
below. The GAE database consumes huge amounts of space in the JVM and the GAE
environment runs two independent copies of the server code to mimic the existence
of a foreground and background process. This all requires very large perm space
and max memory for the underlying Java environments.
To do this, edit the eclipse.ini file, located in the
eclipse directory (e.g., C:\Users\User\eclipse\eclipse.ini). This is
in the same directory as the eclipse.exe.
This is my eclipse.ini:
------------------------------start-------------------
-startup
plugins/org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.1.200.v20140116-2212
-product
org.eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
--launcher.XXMaxPermSize
1536M
-showsplash
org.eclipse.platform
--launcher.XXMaxPermSize
1536m
--launcher.defaultAction
openFile
--launcher.appendVmargs
-vmargs
-Dosgi.requiredJavaVersion=1.7
-Xms100m
-Xmx3048m
-XX:MaxPermSize=1536m
------------------------------end----------------------
(2) Install Google Eclipse Plugin with App Engine SDK and Google Web Toolkit SDK.
(3) Start Eclipse. Choose the parent directory of the clone'd repository as your workspace.
Windows / Preferences:
Google / App Engine:
Be sure there is an App Engine 1.9.18 or higher SDK defined.
If the default App Engine version is not 1.9.18, you may need to
tweak with the project settings to get the newer jars to be added.
Google / Web Toolkit:
Be sure there is a WebToolkit SDK defined 2.7.0 or higher.
The default GWT version should match that in the maven
pom.xml (currently 2.7.0). The GWT library is installed as
part of the plugin and can be found in:
...\eclipse\plugins\com.google.gwt.eclipse.sdkbundle_2.7.0...\gwt-2.7.0
File / Import:
Choose the directory of the clone'd repository as the directory to search
(this is one level below the workspace directory).
Choose ONLY the eclipse-aggregate-gae and odk-gae-settings projects.
This should refresh and build with one error (a missing odk-settings-latest.jar).
(4) Edit odk-gae-settings / common / security.properties
In this file:
Set the security.server.superUser to your gmail account.
Additionally, set the security.server.hostname=
(blank) to a dynamic DNS name or IP for your development box.
Save.
(5) In the odk-gae-settings project, select
the 'build.xml' (Ant Buildfile), right-click, and
choose Run As / Ant Build. This will rebuild the configuration
jar and copy it into the eclipse project.
(6) Refresh the eclipse-aggregate-gae project (to pick up the updated jar file).
This should now build without errors.
On Eclipse, these additional steps may also be required:
Select eclipse-aggregate-gae
right-click Properties
under /Builders
de-select Enhancer (based on the bug: http://code.google.com/p/googleappengine/issues/detail?id=1970 )
under /Google/App Engine
toggle the App Engine SDK between the default and specific settings (to make a
rebuild as per instructions http://code.google.com/p/opendatakit/wiki/EclipseDebugging )
(7) Select eclipse-aggregate-gae project.
Click on the red toolbox (GWT compile) to compile the GWT Java code into javascript.
For the Project, specify 'eclipse-gae-project'. This should auto-populate the
'Entry Point Modules' section and highlight 'AggregateUI'. If not, click Add and
choose 'AggregateUI' as the entry point module to compile. If you ever need to browse
to this, it is located under:
Package: org.opendatakit.aggregate
Filename: AggregateUI.gwt.xml
Click on 'Advanced' to open more options.
In the 'VM Arguments' section, add:
-Xmx1536m
Click 'Compile'
This should now compile.
==================================
Running or Debugging under Eclipse
==================================
Select eclipse-aggregate-gae project.
Launch ODK Aggregate under the debugger with 'Debug As' choosing
'Web Application (GWT Super Dev Mode)'
This will fail with an Out-of-Memory error.
Stop the server (click on the small red square on the 'Development Mode' tab).
Repeat for 'Run As'
Now, to increase the JVM size:
For each of these configuration screens:
Run As 'Run Configurations...'
Debug As 'Debug Configurations...'
Open the above dialog (repeat this for each of these)
Choose 'Web Application'
Open this up, and select 'index.html'
On the '(X)= Arguments' tab,
under the 'Program Arguments' section, add an argument with whatever
hostname or IP address you have configured in your
security.properties file. i.e., if that IP is 192.168.10.2, you would
add:
-bindAddress 192.168.10.2
replace the '-Xmx512m' at the front of the 'VM Arguments' section with:
-Xmx2048m -XX:MaxPermSize=1536m
Click 'Apply'
Now close and repeat for the other configuration.
To Debug or Run the application, you will then:
choose 'Debug As' or 'Run As',
choose 'Web Application (GWT Super Dev Mode)'
choose 'index.html'
And it will use this revised configuration.
See the documentation for GWT SuperDevMode to understand how to use
that execution mode. GWT UI debugging generally needs to be done on
a Chrome browser.
==================================
Debugging GWT UI in Chrome Browser
==================================
See the documentation for running GWT SuperDevMode
e.g., http://www.gwtproject.org/articles/superdevmode.html
=====================
MySQL Eclipse Setup
---------------------
First, get the eclipse-aggregate-gae project working.
You will then copy the war directory of that project over to the
eclipse-aggregate-mysql project, and tweak it.
See the SETUP.txt instructions in the eclipse-aggregate-mysql
directory for further information.
The class files seem to get stuck and not Publish when running
under Tomcat 6.0 and MySQL. The work-around for this is to
Stop the server and Clean... it, then Start it. This seems to
make everything current.
==========================================
Troubleshooting Debugging/Running
------------------------------------------
(1) Javascript refresh loop
If the database schema has changed, the browser may flash
and be stuck in a javascript refresh loop. To remedy,
delete your local datastore (instructions below)
(2) Odd behaviors under Eclipse
The Eclipse GWT plugin does not normally keep the compiled
client-side javascript up to date with the debug-enabled
GWT Java client code. This can cause a number of inconsistencies
when the ?gwt.codesvr=127.0.0.1:9997 query string is dropped
off the URL during redirects when logging in, etc.
First, verify that if you are running under debug, you have
the ?gwt.codesvr=127.0.0.1:9997 query string on your URLs.
Second, periodically, when stopped, click on the red toolbox
to compile the javascript.
Third, periodically clear your browser cache to force a complete
re-loading of the clientside javascript.
Fourth, if you have moved or changed client interfaces, you
may need to manually browse to the war diretory and delete
the contents of the war/aggregateui and war/WEB-INF/deploy
directories.
(3) Odd errors about locking scopes.
If you are debugging code within a transaction
region (these are presently isolated to TaskLockImpl.java),
the datastore can get confused about the transaction scopes
that are active. You may need to close eclipse, re-open,
and delete the datastore to clear this problem.
-----------------------
Clearing your Datastore
-----------------------
To delete the local datastore:
(1) In Eclipse, browse to war/WEB-INF/appengine-generated
(2) Hit Refresh
(3) delete "local_db.bin"
==========================================
Full Maven Development Environment Configuration
------------------------------------------
(1) Install Maven 3. This document assumes Maven 3.0.4 or higher.
This will generally set up a maven repository under
the user's home directory: ${HOME}/.m2/repository
(2) Install Java 7 JDK.
(3) Install Eclipse Kepler (4.3.2) or higher. Luna has not been tested.
(4) Install Google Eclipse Plugin with App Engine SDK and Google Web Toolkit SDK.
(5) Optionally Install Tomcat 6.0.
This is required unless you do not import or always keep closed
the MySQL and Postgres projects and don't use maven.
(6) Optionally: Install Postgres
For Postgres, run these commands:
----postgres-script-start-----
create database "odk_unit";
create schema "odk_unit";
create user "odk_unit" with unencrypted password 'odk_unit';
grant all privileges on database "odk_unit" to "odk_unit";
alter database "odk_unit" owner to "odk_unit";
----postgres-script-end-------
From the Postgres SQL shell (psql) commandline client,
using the root account and password, if the above commands
are in the file postgres.sql, you can type:
\cd C:/your_path_no_spaces_forward_slashes_only
\i postgres.sql
\q
(6) Optionally: Install MySQL
(6a)
For MySQL, run this script:
UPDATE mysql.user SET Password=PASSWORD('odk_unit') WHERE User='root';
FLUSH PRIVILEGES;
CREATE USER 'odk_unit'@'localhost' IDENTIFIED BY 'odk_unit';
CREATE DATABASE odk_unit;
GRANT ALL PRIVILEGES ON odk_unit.* TO 'odk_unit'@'localhost' WITH GRANT OPTION;
(6b)
For MySQL, download and copy the MySQL Connector J jar into the Tomcat /lib
directory (mysql-connector-java-5.1.17.jar to apache-tomcat-6.0.26/lib).
You must stop tomcat, if it is running, in order for the library to be detected.
For Maven (3) is optional; (4), (5) and (6) are required in order
to perform a full build.
----------
(7) Register libraries in Maven: (this is also required for Eclipse builds)
Run the ANT script (build.xml) under:
src/main/libs/ -- registers various jars into your local maven repo.
To run, just cd to this directory and type 'ant'
See the src/main/libs/readme.txt for information about these jars.
(8a) Download and install Firefox. This build works for Firefox 37.
Firefox often changes and selenium plays catch-up. You might need
to update selenium or back-rev Firefox for UI testing to work.
(8b) Download the App Engine SDK and selenium java client for full-stack integration / web UI tests.
Run the ANT script (build.xml) under:
build/ -- downloads the App Engine SDK and selenium java client (for full-stack integration / web UI tests)
To run, just cd to this directory and type 'ant'
(9) Edit Maven's settings.xml file (this is in the .m2 directory).
A minimal file is:
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
http://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>local.gae</id>
<username>[email protected]</username>
<password></password>
</server>
</servers>
<profiles>
<profile>
<id>gae</id>
<activation><activeByDefault>true</activeByDefault></activation>
<properties>
<localRepository>${user.home}/.m2/repository</localRepository>
<temp.home>C:\\Users\\Administrator\\AppData\\Local\\Temp</temp.home>
<bitrock.home>C:\Program Files (x86)\BitRock InstallBuilder Professional 9.5.3</bitrock.home>
<keystore.propertyfile>\C:\\Users\\Administrator\\keystore\\jarSignerDetails.txt</keystore.propertyfile>
<headless.operation>no</headless.operation>
<mysql.client.executable>C:\\Program Files\\MySQL\\MySQL Server 5.5\\bin\\mysql.exe</mysql.client.executable>
<mysql.root.password>MYSQLROOTPASSWORDHERE</mysql.root.password>
<postgres.client.executable>C:\\Program Files\\PostgreSQL\\9.1\\bin\\psql.exe</postgres.client.executable>
<postgres.root.password>POSTGRESQLROOTPASSWORDHERE</postgres.root.password>
<test.server.hostname>YOUR.FULLY.QUALIFIED.HOSTNAME.AND.ORG</test.server.hostname>
<test.server.port>7070</test.server.port>
<test.server.secure.port>7443</test.server.secure.port>
<test.server.gae.monitor.port>7075</test.server.gae.monitor.port>
<unix.display>:20.0</unix.display>
<firefox.executable></firefox.executable>
</properties>
</profile>
</profiles>
</settings>
Be sure to update the paths and passwords to match those of your environment.
The installer is not hooked into the parent Maven project, but identifies that project as its
parent. So you can build the top-level project to build and run unit tests, integration tests,
etc. and do not need bitrock installed.
The aggregate-mysql war file is used as the starting point for the installer build process.
=========================
Maven Command Line Builds
=========================
(12) Maven command-line builds are done as follows:
mvn clean
This cleans the workspace, removing all temporary files.
If this errors out, verify that there are no orphaned java
executables running. If the GAE tests crash, they can leave
a java database background process running.
mvn install
This will build and install the projects, running the unit tests
against the 3 datastores (Google BigTable, MySQL, Postgresql),
and building the wars for the 3 platforms.
(13) If you have bitrock installed and licensed, you can
build the bitrock installer. First,
copy aggregate-mysql\target\aggregate-mysql-1.0.war bitrock-installer
cd bitrock-installer
mvn clean
mvn install
Open bitrock and open the buildWar.xml project file in this directory.
On the packaging page, build for windows, linux, linux-64 and OSX.
On Windows, the generated installers are placed under:
C:\Users\Administrator\Documents\InstallBuilder\output