jdk-24/nashorn/test
Srinivas Dama 81752d9a5d 8184720: Nashorn engine in strict mode throws a java.lang.ClassCastException when calling apply() and passing the arguments object
Fixed needsCallee method to return true properly in strict mode

Reviewed-by: hannesw, sundar
2017-09-01 07:55:00 +05:30
..
examples 8062141: Various performance issues parsing JSON 2015-02-05 14:42:14 +01:00
lib 8044638: Tidy up Nashorn codebase for code standards 2014-06-04 13:08:57 +02:00
opt 8044638: Tidy up Nashorn codebase for code standards 2014-06-04 13:08:57 +02:00
script 8184720: Nashorn engine in strict mode throws a java.lang.ClassCastException when calling apply() and passing the arguments object 2017-09-01 07:55:00 +05:30
src 8184723: jdk.nashorn.internal.runtime.linker.JSObjectLinker.callToApply erroneously asserts given arguments 2017-08-30 18:47:37 +02:00
Makefile 8170629: Remove code duplication in test makefiles 2016-12-07 09:48:24 +01:00
ProblemList.txt 8173888: Test for JDK-8169481 causes stack overflows in parser tests 2017-02-03 13:28:00 +01:00
README 8005403: Open-source Nashorn 2012-12-21 16:36:24 -04:00
TEST.groups 8129597: Add tier 3 test definitions to the JDK 9 forest 2015-06-24 15:19:50 -07:00
TEST.ROOT 8186095: upgrade to jtreg 4.2 b08 2017-08-20 20:36:11 -07:00

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.