project.properties revision 1052:803bc3fd404d
1#
2# Copyright (c) 2010, 2014, Oracle and/or its affiliates. All rights reserved.
3# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4# 
5# This code is free software; you can redistribute it and/or modify it
6# under the terms of the GNU General Public License version 2 only, as
7# published by the Free Software Foundation.
8# 
9# This code is distributed in the hope that it will be useful, but WITHOUT
10# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12# version 2 for more details (a copy is included in the LICENSE file that
13# accompanied this code).
14# 
15# You should have received a copy of the GNU General Public License version
16# 2 along with this work; if not, write to the Free Software Foundation,
17# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18# 
19# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20# or visit www.oracle.com if you need additional information or have any
21# questions.
22#
23
24application.title=nashorn
25
26# location of JDK embedded ASM sources
27jdk.asm.src.dir=../jdk/src/share/classes/jdk/internal/org/objectweb/asm
28
29# source and target levels
30build.compiler=modern
31javac.source=1.8
32javac.target=1.8
33
34# nashorn version information
35nashorn.version=0.1
36nashorn.fullversion=0.1
37nashorn.product.name=Oracle Nashorn
38
39# This directory is removed when the project is cleaned:
40build.dir=build
41build.classes.dir=${build.dir}/classes
42build.zip=${build.dir}/nashorn.zip
43build.gzip=${build.dir}/nashorn.tar.gz
44
45# nashorn Shell tool
46nashorn.shell.tool=jdk.nashorn.tools.Shell
47
48# nasgen tool
49nasgen.tool=jdk.nashorn.internal.tools.nasgen.Main
50
51# parallel test runner tool
52parallel.test.runner=jdk.nashorn.internal.test.framework.ParallelTestRunner
53
54# test classes directory
55build.test.classes.dir=${build.dir}/test/classes
56
57# nashorn test jar - internal tests jar and api tests jar
58nashorn.internal.tests.jar=${build.dir}/nashorn-internal-tests.jar
59nashorn.api.tests.jar=${build.dir}/nashorn-api-tests.jar
60
61# test results directory
62build.test.results.dir=${build.dir}/test/reports
63build.nosecurity.test.results.dir=${build.dir}/test/nosecurity/reports
64build.nooptimistic.test.results.dir=${build.dir}/test/nooptimistic/reports
65
66# This directory is removed when the project is cleaned:
67dist.dir=dist
68dist.jar=${dist.dir}/nashorn.jar
69dist.javadoc.dir=${dist.dir}/javadoc
70
71# nashorn javafx shell
72fxshell.tool = jdk.nashorn.tools.FXShell
73fxshell.classes.dir = ${build.dir}/fxshell/classes
74fxshell.dir = tools/fxshell
75fxshell.jar = ${dist.dir}/nashornfx.jar
76
77# configuration for java flight recorder
78run.test.jvmargs.jfr=-XX:+UnlockCommercialFeatures -XX:+FlightRecorder -XX:FlightRecorderOptions=defaultrecording=true,disk=true,dumponexit=true,dumponexitpath=${build.dir},stackdepth=128
79
80# jars refererred
81file.reference.testng.jar=test/lib/testng.jar
82
83# Set testng verbose level
84# From TestNG docs: "the verbosity level (0 to 10 where 10 is most detailed) 
85# Actually, this is a lie: you can specify -1 and this will put TestNG in 
86# debug mode (no longer slicing off stack traces and all)."
87
88testng.verbose=2
89
90# TestNG listeners - we want to replace TestNG's own JUnit
91# reporter, but want everything else provided by default
92# Unfortunately, we've to clone the other default reporters here.
93
94testng.listeners=\
95 org.testng.reporters.SuiteHTMLReporter, \
96 org.testng.reporters.TestHTMLReporter, \
97 org.testng.reporters.jq.Main, \
98 org.testng.reporters.FailedReporter, \
99 org.testng.reporters.XMLReporter \
100 org.testng.reporters.EmailableReporter, \
101 jdk.nashorn.internal.test.framework.JSJUnitReportReporter
102
103javac.debug=true
104javac.encoding=ascii
105javac.classpath=\
106    ${build.classes.dir}
107javac.test.classpath=\
108    ${build.classes.dir}:\
109    ${build.test.classes.dir}:\
110    ${file.reference.testng.jar}
111
112meta.inf.dir=${src.dir}/META-INF
113
114run.classpath=\
115    ${build.classes.dir}
116
117# test scripts to run
118test.dir=test
119test.nosecurity.dir=test/script/nosecurity
120test.script.dir=test/script
121test.basic.dir=test/script/basic
122test.maptests.dir=test/script/maptests
123test.error.dir=test/script/error
124test.sandbox.dir=test/script/sandbox
125test.trusted.dir=test/script/trusted
126test.external.dir=test/script/external
127test262.dir=${test.external.dir}/test262
128test262.suite.dir=${test262.dir}/test/suite
129testjfx.dir=${test.script.dir}/jfx
130testmarkdown.dir=${test.script.dir}/markdown
131
132test-sys-prop.test.dir=${test.dir}
133test-sys-prop.test.js.roots=${test.basic.dir} ${test.maptests.dir} ${test.error.dir} ${test.sandbox.dir} ${test.trusted.dir}
134test-sys-prop.test262.suite.dir=${test262.suite.dir}
135test-sys-prop.es5conform.testcases.dir=${test.external.dir}/ES5Conform/TestCases
136test-sys-prop.test.basic.dir=${test.basic.dir}
137
138test-sys-prop-no-security.test.dir=${test.dir}
139test-sys-prop-no-security.test.js.roots=${test.nosecurity.dir}
140
141# framework root for our script tests
142test-sys-prop.test.js.framework=${test.script.dir}/assert.js
143test-sys-prop-no-security.test.js.framework=${test.script.dir}/assert.js
144
145# Control the verbosity of ParserTest
146test-sys-prop.parsertest.verbose=false
147
148# turn on/off scripting mode for parser tests
149test-sys-prop.parsertest.scripting=true
150
151# turn on/off test262 scripts for parser tests
152test-sys-prop.parsertest.test262=false
153
154# Control the verbosity of the CompilerTest
155test-sys-prop.compilertest.verbose=false
156
157# turn on/off scripting mode for compiler tests
158test-sys-prop.compilertest.scripting=true
159
160# turn on/off test262 scripts for compiler tests
161test-sys-prop.compilertest.test262=false
162
163# test directory to be excluded.
164test-sys-prop.test.js.exclude.dir=${test.script.dir}/currently-failing ${test.external.dir}
165
166# run everything that's js in here, without checking file headers for test annotations
167test-sys-prop.test.js.unchecked.dir=${test262.dir}
168
169# test root for octane
170octane-test-sys-prop.test.js.roots=${test.external.dir}/octane/
171
172# run octane benchmars in separate processes? (recommended)
173octane-test-sys-prop.separate.process=true
174
175# framework root for octane
176octane-test-sys-prop.test.js.framework=${test.basic.dir}/run-octane.js
177
178# test root for sunspider
179sunspider-test-sys-prop.test.js.roots=${test.external.dir}/sunspider/tests/sunspider-1.0.2/
180
181# framework root for sunspider
182sunspider-test-sys-prop.test.js.framework=${test.basic.dir}/runsunspider.js
183
184# list of tests to be excluded
185sunspider-test-sys-prop.test.js.exclude.list=
186
187# execute our script tests in shared nashorn context or not?
188test-sys-prop.test.js.shared.context=false
189
190# execute test262 tests in shared nashorn context or not?
191test262-test-sys-prop.test.js.shared.context=true
192
193# test262 test root
194test262-test-sys-prop.test.js.roots=${test262.suite.dir}
195
196# test262 enable/disable strict mode tests
197test262-test-sys-prop.test.js.enable.strict.mode=true
198
199# file containing test262 tests to be excluded
200# test262-test-sys-prop.test.js.excludes.file=${test262.dir}/test/config/excludelist.xml
201
202# list of test262 test dirs to be excluded
203test262-test-sys-prop.test.js.exclude.dir=\
204    ${test262.suite.dir}/intl402/ \
205    ${test262.suite.dir}/bestPractice/
206
207test262-test-sys-prop.test.failed.list.file=${build.dir}/test/failedTests
208
209# test262 test frameworks
210test262-test-sys-prop.test.js.framework=\
211    --class-cache-size=10 \
212    --no-java \
213    --no-typed-arrays \
214    -timezone=PST \
215    ${test.script.dir}/test262.js \
216    ${test262.dir}/test/harness/framework.js \
217    ${test262.dir}/test/harness/sta.js
218
219# testmarkdown test root
220testmarkdown-test-sys-prop.test.js.roots=${testmarkdown.dir}
221
222# execute testmarkdown tests in shared nashorn context or not?
223testmarkdown-test-sys-prop.test.js.shared.context=false
224
225# framework root for markdown script tests
226testmarkdown-test-sys-prop.test.js.framework=\
227    ${test.script.dir}${file.separator}markdown.js
228
229# testjfx test root
230testjfx-test-sys-prop.test.js.roots=${testjfx.dir}
231
232# execute testjfx tests in shared nashorn context or not?
233testjfx-test-sys-prop.test.js.shared.context=false
234
235# framework root for our script tests
236testjfx-test-sys-prop.test.js.framework=\
237    -fx \
238    ${test.script.dir}${file.separator}jfx.js
239
240file.reference.jemmyfx.jar=test${file.separator}lib${file.separator}JemmyFX.jar
241file.reference.jemmycore.jar=test${file.separator}lib${file.separator}JemmyCore.jar
242file.reference.jemmyawtinput.jar=test${file.separator}lib${file.separator}JemmyAWTInput.jar
243file.reference.jfxrt.jar=${java.home}${file.separator}lib${file.separator}ext${file.separator}jfxrt.jar
244testjfx.run.test.classpath=\
245    ${file.reference.jemmyfx.jar}${path.separator}\
246    ${file.reference.jemmycore.jar}${path.separator}\
247    ${file.reference.jemmyawtinput.jar}${path.separator}\
248    ${file.reference.testng.jar}${path.separator}\
249    ${nashorn.internal.tests.jar}${path.separator}\
250    ${nashorn.api.tests.jar}
251
252# testjfx VM options for script tests with @fork option
253testjfx-test-sys-prop.test.fork.jvm.options=${run.test.jvmargs.main} -Xmx${run.test.xmx} -cp ${testjfx.run.test.classpath}
254
255run.test.classpath=\
256    ${file.reference.testng.jar}:\
257    ${nashorn.internal.tests.jar}:\
258    ${nashorn.api.tests.jar}
259
260src.dir=src/jdk.scripting.nashorn/share/classes
261test.src.dir=test/src
262
263# -Xmx is used for all tests, -Xms only for octane benchmark
264run.test.xmx=2G
265run.test.xms=2G
266
267# uncomment this jfr.args to enable light recordings. the stack needs to be cranked up to 1024 frames,
268# or everything will as of the now drown in lambda forms and be cut off.
269#
270#jfr.args=-XX:+UnlockCommercialFeatures -XX:+FlightRecorder -XX:FlightRecorderOptions=defaultrecording=true,disk=true,dumponexit=true,dumponexitpath="test_suite.jfr",stackdepth=1024 \
271
272jfr.args=
273
274run.test.user.language=tr
275run.test.user.country=TR
276
277run.test.jvmargs.common=\
278  -server \
279  -Dfile.encoding=UTF-8 \
280  -Duser.language=${run.test.user.language} \
281  -Duser.country=${run.test.user.country} \
282  -Dnashorn.typeInfo.cacheDir=${build.dir}${file.separator}test${file.separator}type_info_cache \
283  ${jfr.args} \
284  -XX:+HeapDumpOnOutOfMemoryError
285
286# turn on assertions for tests
287run.test.jvmargs.main=${run.test.jvmargs.common} -ea
288
289# Extra jvmargs that might be useful for debugging
290# and performance improvements/monitoring
291#
292# -XX:+UnlockDiagnosticVMOptions 
293#
294# turn off compressed class pointers in metaspace
295# -XX:-UseCompressedKlassPointers  
296#
297# dump the heap after every GC
298# -XX:+PrintHeapAtGC
299#
300# manually set a metaspace size for class data 
301# -XX:ClassMetaspaceSize=300M
302#
303# print out methods compiled
304# -XX:+PrintCompilation 
305#
306# print all compiled nmethods with oopmaps and lots of other info
307# -XX:+PrintNMethods
308#
309# activate the generic "UseNewCode" flag to test whatever functionality
310# lies behind it. This is the preferred way to test a, yet flagless,
311# feature in HotSpot - for example, the uncommon trap placement fix
312# was hidden behind this flag before it became the default
313#
314# -XX:+UnlockDiagnosticVMOptions -XX:+UseNewCode 
315#
316# Crank up the type profile level to 222, which has some warmup
317# penalties, but produces much better code for JavaScript, where better
318# and more intrusive type profiling is required to get rid of
319# a large amount of unnecessary guard code, that could not otherwise
320# be eliminated
321#
322# -XX:TypeProfileLevel=222
323#
324
325# Use best known performance options for octane
326run.test.jvmargs.octane.main=${run.test.jvmargs.common} -XX:TypeProfileLevel=222
327
328# Security manager args - make sure that we run with the nashorn.policy that the build creates
329run.test.jvmsecurityargs=-Xverify:all -Djava.security.manager -Djava.security.policy=${build.dir}/nashorn.policy
330
331# VM options for script tests with @fork option
332test-sys-prop.test.fork.jvm.options=${run.test.jvmargs.main} -Xmx${run.test.xmx} ${run.test.jvmsecurityargs} -cp ${run.test.classpath}
333
334# path of rhino.jar for benchmarks
335rhino.dir=
336rhino.jar=${rhino.dir}/js.jar
337
338v8.shell=d8
339
340# How many iterations should 'ant octane' run for each
341# benchmark
342octane.iterations=25
343
344# List of octane tests to run, as properties prefixed with
345# "octane.benchmark." mapping to the benchmark name in 
346# the test harness
347#
348# Octane tests that are disabled should have their entire line
349# commented out  Tests may be disabled for functionality reasons when
350# they have bugs or when the runtime doesn't handle them (yet)
351octane.benchmark.box2d=box2d
352#octane.benchmark.code-load=code-load
353octane.benchmark.crypto=crypto
354octane.benchmark.deltablue=deltablue
355octane.benchmark.earley-boyer=earley-boyer
356octane.benchmark.gbemu=gbemu
357octane.benchmark.navier-stokes=navier-stokes
358octane.benchmark.mandreel=mandreel
359octane.benchmark.pdfjs=pdfjs
360octane.benchmark.raytrace=raytrace
361octane.benchmark.regexp=regexp
362octane.benchmark.richards=richards
363octane.benchmark.splay=splay
364#octane.benchmark.typescript=typescript
365#octane.benchmark.zlib=zlib
366
367#path to rhino jar file
368octaneperf-sys-prop.rhino.jar=${rhino.jar}
369
370#timeout for performance tests in minutes
371octaneperf-sys-prop.timeout.value=10
372
373#how many iterations to run sunspider after warmup
374sunspider.iterations=3000
375
376#################
377# code coverage #
378#################
379
380#enable/disable code coverage; please redifine in the ${user.home}/.nashorn.project.local.properties
381make.code.coverage=false
382
383#type of codecoverage; one of static or dynamic. Now only dynamic is supported
384jcov=dynamic
385
386#naming of CC results
387#NB directory specified in the cc.dir will be cleaned up!!!
388cc.dir=${basedir}/../Codecoverage_Nashorn
389cc.result.file.name=CC_${jcov}_nashorn.xml
390
391#dynamic CC parameters; please redefine in the ${user.home}/.nashorn.project.local.properties
392jcov2.lib.dir=${basedir}/../jcov2/lib
393jcov.jar=${jcov2.lib.dir}/jcov.jar
394cc.include=jdk\.nashorn\.*
395cc.exclude=jdk\.nashorn\.internal\.scripts\.*
396cc.dynamic.genereate.template=true
397cc.template=${cc.dir}/CC_template.xml
398cc.dynamic.args=-javaagent:${jcov.jar}=include=${cc.include},exclude=${cc.exclude},type=all,verbose=0,file=${cc.dir}/${cc.result.file.name}
399