From 7becd703e3ef8c3f3ad03ed4e0a8ba861a7d790b Mon Sep 17 00:00:00 2001 From: Babneet Singh Date: Wed, 2 Feb 2022 10:05:45 -0500 Subject: [PATCH] [JDK18+] Set java.security.manager property for tests In JDK18+, java.security.manager == null behaves as -Djava.security.manager=disallow. In JDK17-, java.security.manager == null behaves as -Djava.security.manager=allow. In case of system tests, the base infra (STF) which is used to launch tests utilizes the security manager in net.adoptopenjdk.loadTest.LoadTest.overrideSecurityManager. For system tests to work as expected, -Djava.security.manager=allow behaviour is needed in JDK18+. Related: https://github.com/eclipse-openj9/openj9/issues/14412 Signed-off-by: Babneet Singh --- system/systemtest.mk | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/system/systemtest.mk b/system/systemtest.mk index a064578df4..e39f744d96 100644 --- a/system/systemtest.mk +++ b/system/systemtest.mk @@ -46,6 +46,17 @@ ifeq (,$(findstring $(JDK_IMPL),hotspot)) OPENJ9_PRAM=;$(SYSTEMTEST_RESROOT)$(D)openj9-systemtest endif +# In JDK18+, java.security.manager == null behaves as -Djava.security.manager=disallow. +# In JDK17-, java.security.manager == null behaves as -Djava.security.manager=allow. +# In case of system tests, the base infra (STF) which is used to launch tests utilizes +# the security manager in net.adoptopenjdk.loadTest.LoadTest.overrideSecurityManager. +# For system tests to work as expected, -Djava.security.manager=allow behaviour is +# needed in JDK18+. +# Related: https://github.com/eclipse-openj9/openj9/issues/14412 +ifeq ($(filter 8 9 10 11 12 13 14 15 16 17, $(JDK_VERSION)),) + JVM_OPTIONS:=-Djava.security.manager=allow $(JVM_OPTIONS) +endif + define SYSTEMTEST_CMD_TEMPLATE perl $(SYSTEMTEST_RESROOT)$(D)STF$(D)stf.core$(D)scripts$(D)stf.pl \ -test-root=$(Q)$(SYSTEMTEST_RESROOT)$(D)STF;$(SYSTEMTEST_RESROOT)$(D)aqa-systemtest$(OPENJ9_PRAM)$(Q) \