Skip to content

Latest commit

 

History

History

openjdk

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

OpenJDK regression tests

This group of tests are the set that comes from the openjdk project, often referred to as jtreg tests, as the jtreg framework is the underlying executable used to execute them. The entire set of openjdk regression tests is quite large. For our nightly builds, we run only a subset of these tests (typically, those suites of tests that we 'tag' as sanity in the playlist.xml file). For release builds, we intend to run the suites tagged as sanity and extended in the playlist.

For more details on how the underlying jtreg harness works, you can refer to the "How to Use the JTreg harness" guide. For advanced users, you can refer to the jtreg doc and jtreg readme.

Running OpenJDK tests locally

While you can directly use the jtreg test harness to run these tests locally, we have also integrated them into our AQA test suite with TKG (TestKitGen) so that they can be run following the same pattern as any other AQA test:

  1. Ensure your test machine is set up with test prereqs. For openjdk tests, you do not need Docker installed.

  2. Download/unpack the SDK you want to your test machine (you can download them from our website: adoptium.net.

  3. export TEST_JDK_HOME=</pathToWhereYouInstalledSDK>

  4. git clone https://github.com/adoptium/aqa-tests.git

  5. cd aqa-tests

  6. ./get.sh

  7. cd TKG

  8. export BUILD_LIST=openjdk

  9. make compile (This fetches test material and compiles it, based on build.xml files in the test directories)

  10. make _jdk_math (or any TARGET you wish to run, for targets you can use any <testCaseName> defined in the openjdk/playlist.xml file and prefixed with an _ underscore. If you wish to run all tests tagged with the sanity label, then make _sanity.openjdk)

Add a sub group test

We already have a large set of tests defined in the playlist.xml file, but not all of the openjdk regression test groups are presented there. If you wish to define more, add a <test></test> in playlist.xml and specify:

  • testCaseName
  • command (how to run the test) - essentially the command that invokes the underlying jtreg harness
  • version: sdk version
  • levels: sanity, extended
  • groups: openjdk

Exclude a testcase

Update ProblemList_(JVM_VERSION).txt to exclude testcases which fails in adoptopenjdk regression test build.

List items are testnames followed by labels, all MUST BE commented as to why they are here and use a label:

  • generic-all Problems on all platforms
  • generic-ARCH Where ARCH is one of: x64, x86, s390x, ppc64le, sparc, sparcv9, i586, etc.
  • OSNAME-all Where OSNAME is one of: solaris, linux, windows, macosx, aix
  • OSNAME-ARCH Specific on to one OSNAME and ARCH, e.g. solaris-amd64
  • OSNAME-REV Specific on to one OSNAME and REV, e.g. solaris-5.8

If you need to exclude more than one testcase, put an indent after the reason and a comma in between the labels. Like the following:

* java/util/concurrent/tck/JSR166TestCase.java	0000 windows-x86,linux-aarch64

Note: If the test will be run more than once ( more than one annotation @test in test source code) need to append specific testcase number something like following:

* java/util/concurrent/tck/JSR166TestCase.java#id0  0000 generic-all

Fixing the tests:

Some tests just may need to be run with "othervm", and that can easily be done by adding a @run line (or modifying any existing @run):

* @run main/othervm NameOfMainClass

Make sure this @run follows any use of @library. Otherwise, if the test is a samevm possibility, make sure the test is cleaning up after itself, closing all streams, deleting temp files, etc. Keep in mind that the bug could be in many places, and even different per platform, it could be a bug in any one of:

  • the testcase
  • the jdk (jdk classes, native code, or hotspot)
  • the native compiler
  • the javac compiler
  • the OS (depends on what the testcase does)

If you managed to really fix one of these tests, here is how you can remove tests from this list:

  • Make sure test passes on all platforms with samevm, or mark it othervm
  • Make sure test passes on all platforms when run with it's entire group
  • Make sure both VMs are tested, -server and -client, if possible
  • Make sure you try the -d64 option on Solaris
  • Use a tool like JPRT or something to verify these results
  • Delete lines in this file, include the changes with your test changes

You may need to repeat your testing 2 or even 3 times to verify good results, some of these samevm failures are not very predictable.