98762d6ee0
Co-authored-by: Akhil Arora <akhil.arora@oracle.com> Co-authored-by: Andreas Woess <andreas.woess@jku.at> Co-authored-by: Attila Szegedi <attila.szegedi@oracle.com> Co-authored-by: Hannes Wallnoefer <hannes.wallnoefer@oracle.com> Co-authored-by: Henry Jen <henry.jen@oracle.com> Co-authored-by: Marcus Lagergren <marcus.lagergren@oracle.com> Co-authored-by: Pavel Semenov <pavel.semenov@oracle.com> Co-authored-by: Pavel Stepanov <pavel.stepanov@oracle.com> Co-authored-by: Petr Hejl <petr.hejl@oracle.com> Co-authored-by: Petr Pisl <petr.pisl@oracle.com> Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com> Reviewed-by: attila, hannesw, lagergren, sundar
79 lines
2.6 KiB
Plaintext
79 lines
2.6 KiB
Plaintext
Nashorn tests are TestNG based. Running tests requires downloading the TestNG
|
|
library and placing its jar file into the lib subdirectory:
|
|
|
|
# download and install TestNG
|
|
wget http://testng.org/testng-x.y.z.zip
|
|
unzip testng-x.y.z.zip
|
|
cp testng-x.y.z/testng-x.y.z.jar lib/testng.jar
|
|
|
|
# run tests
|
|
cd ..
|
|
ant test
|
|
|
|
This will fail with a message like
|
|
|
|
taskdef class org.testng.TestNGAntTask cannot be found
|
|
|
|
if the TestNG jar file is not installed properly or if the wrong
|
|
version is present. (Check build.xml to find the version of TestNG
|
|
that is required.) Only the jar file is necessary. The unzipped
|
|
hierarchy can be removed.
|
|
|
|
We have tested using TestNG 6.7 as well ad TestNG 6.8. TestNG 6.7's jar file
|
|
is also available as part of jtreg 4.1 b05 which can be downloaded at
|
|
http://download.java.net/openjdk/jtreg/
|
|
|
|
ECMAScript script test framework:
|
|
|
|
* Test tags for test framework:
|
|
|
|
The test runner crawls these directories for .js files and looks for JTReg-style
|
|
@foo comments to identify tests.
|
|
|
|
* @test - A test is tagged with @test.
|
|
|
|
* @test/fail - Tests that are supposed to fail (compiling, see @run/fail
|
|
for runtime) are tagged with @test/fail.
|
|
|
|
* @test/compile-error - Test expects compilation to fail, compares
|
|
output.
|
|
|
|
* @test/warning - Test expects compiler warnings, compares output.
|
|
|
|
* @test/nocompare - Test expects to compile [and/or run?]
|
|
successfully(may be warnings), does not compare output.
|
|
|
|
* @subtest - denotes necessary file for a main test file; itself is not
|
|
a test.
|
|
|
|
* @run - A test that should be run is also tagged with @run (otherwise
|
|
the test runner only compiles the test).
|
|
|
|
* @runif - A test that should be run only if a specific System property
|
|
is defined (Example: @runif external.v8)
|
|
|
|
* @run/fail - A test that should compile but fail with a runtime error.
|
|
|
|
* @run/param - specify runtime arguments to script.
|
|
|
|
* @run/ignore-std-error - script may produce output on stderr, ignore
|
|
this output.
|
|
|
|
* @compilearg \ - pass arg to compiler, sample.
|
|
|
|
/**
|
|
* @compilearg --dump-ir-graph
|
|
* @test/warning
|
|
*/
|
|
|
|
* @compilefirst foo.js - foo.js being a necessary file for a test; it
|
|
may or may not itself be a test. These are compiled separately before
|
|
main test file.
|
|
|
|
* @compile/fail foo.js - foo.js being a necessary file for a test; it
|
|
may or may not itself be a test, compile should fail. These are compile
|
|
with main file.
|
|
|
|
* @compile bar.js - bar.js being a necessary file for a test; it may or
|
|
may not itself be a test. These are compiled with main file.
|