If you have immediate test-related questions, please post them to the AdoptOpenJDK testing Slack channel.
Platform: x64_linux | x64_mac | s390x_linux | ppc64le_linux | aarch64_linux
Java Version: SE80 | SE90 | SE100
Set up your test machine with this set of prerequisites.
While you can run all the tests manually via the make targets on the command line, you may also run the tests in Jenkins. As part of the AdoptOpenJDK continuous integration (CI), AdoptOpenJDK runs test builds against the release and nightly SDK builds.
You can set up your own Jenkins-based test builds using the adoptium aqa-tests Jenkinsfiles by:
- Configure a Jenkins job with a Customized URL
- Ensure your Jenkins machines are configured properly (see the openjdk-infrastructure playbooks for details)
- Ensure machines are labeled following the AdoptOpenJDK labeling scheme. Minimally, your Jenkins nodes should have hw.arch.xxxx and sw.os.xxxx labels (for example, hw.arch.x86 and sw.os.linux for an x86_linux machine).
- Create Pipeline test build job using Pipeline script from SCM
- Repository url - :https://github.com/adoptium/aqa-tests.git
- Branches to build - */master
- Script path - buildenv/jenkins/fileToMatchVersionAndPlatformToTest, example openjdk8_x86-64_linux
- Create necessary parameters
- TARGET - relates to the test target you wish to run (system, openjdk, perf, external, jck, functional are the top-level targets, but you can also add any of the sub-targets, including those defined in playlist.xml files in test directories)
- JVM_VERSION - depending on what SDK you are testing against (some possible values are: openjdk8, openjdk8-openj9, openjdk9, openjdk9-openj9, openjdk10, openjdk10-openj9, openjdk10-sap)
- CUSTOMIZED_SDK_URL - the URL for where to pick up the SDK to test (if you are picking up builds from AdoptOpenJDK, please refer to the openjdk-api README for more details)
This is the guide on how to pass in environment variables when making builds with Jenkins. For the directions on this, we will be using the example variable below: TR_Options='verbose,vlog=testExample1.log' There are three ways to do this, and there will be screenshot demonstrations for each step. Keep in mind that this operation is not typically necessary, and is usually used for debugging purposes.
This method is typically used if that environment variable is to be used in that specific test target.
- Find the folder that your test is in
- Open the playlist.xml file
- Find the testCaseName matching with the test you want to run
- In the corresponding command section, at the beginning, add the key word
export
, your environment variable, followed by a semicolon, just as you might do if you were running this set of commands locally
- Save it, git add, commit, push
git add --all
git commit -m "Added TR_Options as an environment variable in the playlist"
git push origin env_var
- Go to the Jenkins page, and open up the Grinders
-
Click “Build with Parameters” on the left side of the page, third down from the top
-
In the ADOPTOPENJDK_REPO section, put in the repository you were working from when you made those changes
- In the ADOPTOPENJDK_BRANCH section, put in the branch you were on
- In the BUILD_LIST and TARGET sections, put in the corresponding information
- Scroll to the bottom and hit the Build button
This method is to be used when the objective is to set that environment variable for all test targets in the group being run. For this example, we will be looking at the system.mk file.
- Open the aqa-tests/system folder
- Open the .mk file corresponding to your test
- Find the last line of the file with the RESROOT name, the line that says SYSTEMTEST_RESROOT=$(TEST_RESROOT)/../ in this example
- Insert the key word
export
, followed by your environment variable, without any single or double quotation marks, in the line above it
- Save it, git add, commit, push
git add --all
git commit -m "Added TR_Options as an environment variable in the playlist"
git push origin env_var
- Go to the Jenkins page, and open up the Grinders
-
Click “Build with Parameters” on the left side of the page, third down from the top
-
In the ADOPTOPENJDK_REPO section, put in the repository you were working from when you made those changes
- In the ADOPTOPENJDK_BRANCH section, put in the branch you were on
- In the BUILD_LIST and TARGET sections, put in the corresponding information
- Scroll to the bottom and hit the Build button
This method is to be used when the objective is to set that environment variable for a more generic case.
- Edit the testEnv.mk file
- Insert the key word export, followed by your environment variable, without any single or double quotation marks, or spaces
- Save it, git add, commit, push
git add --all
git commit -m "Added TR_Options as an environment variable in testEnv"
git push origin env_var
- Go to the Jenkins page, and open up the Grinder_TKG job
-
Click “Build with Parameters” on the left side of the page, third down from the top
-
Use your TKG_REPO and TKG_BRANCH where you have made your changes for those parameters instead of the default values
-
Scroll to the bottom and hit the Build button
git clone https://github.com/adoptium/aqa-tests.git
cd aqa-tests
get.sh -t aqa-testsDIR -p platform [-j SE80] [-i hotspot] [-R latest] [-T jdk] [-s downloadBinarySDKDIR] [-r SDK_RESOURCE] [-c CUSTOMIZED_SDK_URL]
Where possible values of get.sh script are:
Usage : get.sh --testdir|-t openjdktestdir
--platform|-p x64_linux | x64_mac | s390x_linux | ppc64le_linux | aarch64_linux | ppc64_aix
[--jdk_version|-j ] : optional. JDK version
[--jdk_impl|-i ] : optional. JDK implementation
[--releases|-R ] : optional. Example: latest, jdk8u172-b00-201807161800
[--type|-T ] : optional. jdk or jre
[--sdkdir|-s binarySDKDIR] : optional. Used if do not have a local sdk available and wish to download one to specify preferred directory to download into
[--sdk_resource|-r ] : optional. Indicate where to download an sdk from - releases, nightly, upstream or customized
[--customizedURL|-c ] : optional. If downloading an sdk and if sdk source is set as customized, indicates sdk url
[--clone_openj9 ] : optional. ture or false. Clone openj9 if this flag is set to true. Default to true
[--openj9_repo ] : optional. OpenJ9 git repo. Default value https://github.com/eclipse-openj9/openj9.git is used if not provided
[--openj9_sha ] : optional. OpenJ9 pull request sha
[--openj9_branch ] : optional. OpenJ9 branch
[--tkg_repo ] : optional. TKG git repo. Default value https://github.com/AdoptOpenJDK/TKG.git is used if not provided
[--tkg_sha ] : optional. TkG pull request sha
[--tkg_branch ] : optional. TKG branch
[--vendor_repos ] : optional. Comma separated Git repository URLs of the vendor repositories
[--vendor_shas ] : optional. Comma separated SHAs of the vendor repositories
[--vendor_branches ] : optional. Comma separated vendor branches
[--vendor_dirs ] : optional. Comma separated directories storing vendor test resources
You can use the same approach as described in the OpenJ9 functional tests README file. In the case of the tests run at AdoptOpenJDK, instead of using a make target called _sanity.functional, you can provide the appropriate make target to run the tests of interest to you.
- openjdk
- system
- external
- perf
- jck
- _sanity.openjdk, _sanity.system, _sanity.external, _sanity.perf, etc.
- _extended.openjdk, _extended.system, _extended.external, _extended.perf, etc.
Refer to these instructions for how to run tests by directory
In each playlist.xml file in each test directory, there are tests defined. Test targets are generated from the <testCaseName>
tag, so you can use the test case name as a make target.
For example, for this excerpt from a playlist:
<test>
<testCaseName>scala_test</testCaseName>
...
you will be able to run 'make scala_test' to execute the test.
Consider you are an upstream OpenJDK developer on Linux x86_64, and you'd like to run OpenJDK sanity tests locally on a patch for OpenJDK 8. Let the OpenJDK checkout be at openjdk-jdk8u
, you've produced
a fastdebug build and would like to run the regression test suite, _sanity.openjdk
on it.
$ OPENJDK_SOURCES="$(pwd)/openjdk-jdk8u"
$ OPENJDK_BUILD=$OPENJDK_SOURCES/build/linux-x86_64-normal-server-fastdebug/images/j2sdk-image
$ tmpdir=$(mktemp -d)
$ pushd $tmpdir
$ git clone https://github.com/adoptium/aqa-tests
$ cd aqa-tests
$ TOP_DIR=$(pwd)
$ TEST_DIR="$TOP_DIR"
$ pushd openjdk
$ ln -s $OPENJDK_SOURCES openjdk-jdk
$ popd
$ export BUILD_LIST=openjdk
$ export BUILD_ROOT=$TOP_DIR/test-results
$ export JRE_IMAGE=$OPENJDK_BUILD/../j2re-image
$ export TEST_JDK_HOME=$OPENJDK_BUILD
$ ./get.sh -t $TEST_DIR
$ cd ./TKG
$ make compile
$ make _sanity.openjdk
$ popd
$ echo "aqa-tests located at $tmpdir/aqa-tests"
If all goes well, this should run sanity JTREG OpenJDK tests on your hotspot JDK 8 build and all of them should be passing. Output will then look like this:
[...]
TEST TARGETS SUMMARY
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
PASSED test targets:
jdk_io_0
jdk_lang_0
jdk_math_0
jdk_math_jre_0
jdk_net_0
jdk_nio_0
jdk_security1_0
jdk_util_0
jdk_rmi_0
TOTAL: 9 EXECUTED: 9 PASSED: 9 FAILED: 0 SKIPPED: 0
ALL TESTS PASSED
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
_sanity.openjdk done
[...]
Additional test output can be found in the following folders:
aqa-tests/test-results/openjdk/TKG/output_<timestamp>`
aqa-tests/test-results/openjdk/work
aqa-tests/test-results/openjdk/report
The JTREG report HTML summary file is then located at aqa-tests/test-results/openjdk/report/html/index.html
TKG has a script that monitors the test progress live. It can be your only friend in darkest nights. When you run tests locally, you may want to use that feature. It shows how many tests are passed currently etc. Now let's look how to use it. You need Python3 installed on your machine in order to use it. Note that this feature currently works with openjdk tests only. This means you need to use:
export BUILD_LIST=openjdk
before compiling or you need to run just openjdk tests and pipe them. Otherwise it won't work.
-
You need to change the verbose option of jtreg. In order to do that, you need to change 1 line of code in /openjdk/openjdk.mk file.
You need to change
`JTREG_BASIC_OPTIONS += -v:fail,error,time,nopass`
line to
`JTREG_BASIC_OPTIONS += -v:all`
-
After that, you are ready to run the scripts. Here is the example of how you can do it :
make _sanity.openjdk | python3 -u scripts/liveMonitor_countTests/jtreg-monitor.py
TKG has a script that counts how many test exists in a specified folder. This script currently works on just openjdk tests. It simply checks for the java files contains "@test" annotation. Here is an example of how you can use this script :
aqa-tests/TKG# python3 -u scripts/liveMonitor_countTests/count-java-tests.py ../openjdk/openjdk-jdk/test/langtools/tools/javac/warnings/
The output of the code above is :
Counting tests in 'aqa-tests/openjdk/openjdk-jdk/test/langtools/tools/javac/warnings/' ...
Found 41 java files
. ................ 11
6594914 ........... 2
6747671 ........... 1
6885255 ........... 1
7090499 ........... 1
AuxiliaryClass .... 3
NestedDeprecation . 1
suppress ......... 10
Found 30 java files containing @test
Instead of having to manually create a PR to disable test targets, they can now be automatically disabled via Github workflow (see autoTestPR.yml). In the issue that describes the test failure, add a comment with the following format:
auto exclude test <testName>
If the testName matches the testCaseName defined in <testCaseName>
element of playlist.xml, the entire test suite will be excluded. If the testName is testCaseName followed by _n, only the (n+1)th variation will be excluded.
For example:
<test>
<testCaseName>jdk_test</testCaseName>
<variations>
<variation>NoOptions</variation>
<variation>-Xmx1024m</variation>
</variations>
...
To exclude the entire suite:
auto exclude test jdk_test
To exclude the 2nd variation listed which is assigned suffix_1 -Xmx1024m
:
auto exclude test jdk_test_1
To exclude the test for openj9 only:
auto exclude test jdk_test impl=openj9
To exclude the test for adoptopenjdk vendor only:
auto exclude test jdk_test vendor=adoptopenjdk
To exclude the test for java 8 only:
auto exclude test jdk_test ver=8
To exclude the test for all linux platforms:
auto exclude test jdk_test plat=.*linux.*
To exclude the test for AOT testing:
auto exclude test jdk_test testflag=AOT
plat is defined in regular expression. All platforms can be found here: https://github.com/adoptium/aqa-tests/blob/master/buildenv/jenkins/openjdk_tests
To exclude the 2nd variation listed which is assigned suffix_1 -Xmx1024m
against eclipse openj9 java 8 on windows for AOT testing only:
auto exclude test jdk_test_1 impl=openj9 vendor=eclipse ver=8 plat=.*windows.* testflag=AOT
After the comment is left, there will be a auto PR created with the exclude change in the playlist.xml. The PR will be linked to issue. If the testName can not be found in the repo, no PR will be created and there will be a comment left in the issue linking to the failed workflow run for more details. In the case where the parameter contains space separated values, use single quotes to group the parameter.
Search the test name to find its playlist.xml file. Add a <disables>
element after <testCaseName>
element. The <disables>
element is used to capsulate all <disable>
elements. The <disable>
element should always contain a <comment>
element to specify the related issue url (or issue comment url).
For example:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<disable>
</disables>
...
This will disable the entire test suite. The following section describes how to disable the specific test cases.
Add a <variation>
element in the <disable>
element to specify the variation. The <variation>
element must match an element defined in the <variations>
element.
For example, to exclude the test case with variation -Xmx1024m
:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<variation>-Xmx1024m</variation>
</disable>
</disables>
...
<variations>
<variation>NoOptions</variation>
<variation>-Xmx1024m</variation>
</variations>
...
Add a <impl>
element in the <disable>
element to specify the implementation.
For example, to exclude the test for openj9 only:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<impl>openj9</impl>
</disable>
</disables>
...
Add a <vendor>
element in the <disable>
element to specify the vendor information.
For example, to exclude the test for AdoptOpenJDK only:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<vendor>adoptopenjdk</vendor>
</disable>
</disables>
...
Add a <version>
element in the <disable>
element to specify the version.
For example, to exclude the test for java 11 and up:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<version>11+</version>
</disable>
</disables>
...
Add a <platform>
element in the <disable>
element to specify the platform in regular expression. All platforms can be found here: https://github.com/adoptium/aqa-tests/blob/master/buildenv/jenkins/openjdk_tests
For example, to exclude the test for all linux platforms:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<platform>.*linux.*</plat>
</disable>
</disables>
...
Add a <testflag>
element in the <disable>
element to specify the TEST_FLAG.
For example, to exclude the test for testing AOT (i.e.,TEST_FLAG=AOT):
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<testflag>AOT</testflag>
</disable>
</disables>
...
Defined a combination of <variation>
, <impl>
, <version>
, <platform>
, and <testflag>
in the <disable>
element.
For example, to exclude the test with variation -Xmx1024m
against eclipse openj9 java 8 on windows for AOT testing only:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<variation>-Xmx1024m</variation>
<version>8</version>
<impl>openj9</impl>
<vendor>eclipse</vendor>
<platform>.*windows.*</platform>
<testflag>AOT</testflag>
</disable>
</disables>
...
Note: Same element cannot be defined multiple times inside one <disable>
element. It is because the elements inside the disable element are in AND relationship.
For example, to exclude test on against hotspot and openj9. It is required to define multiple <disable>
elements, each with a single <impl>
element inside:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<version>8</version>
<impl>openj9</impl>
</disable>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<version>8</version>
<impl>hotspot</impl>
</disable>
</disables>
...
Or remove <impl>
element to exclude test against all implementations:
<test>
<testCaseName>jdk_test</testCaseName>
<disables>
<disable>
<comment>https://github.com/adoptium/aqa-tests/issues/123456</comment>
<version>8</version>
</disable>
</disables>
...