From 82735140954012ce2eb4c804b4a420b9a1a927c9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ivan=20=C5=A0ipka?= Date: Fri, 11 Dec 2020 14:37:25 +0000 Subject: [PATCH] 8166026: Refactor java/lang shell tests to java Reviewed-by: mullan --- .../modules/CustomSecurityManager.sh | 66 --------------- .../modules/CustomSecurityManagerTest.java | 84 +++++++++++++++++++ .../lang/SecurityManager/modules/Test.java | 34 -------- 3 files changed, 84 insertions(+), 100 deletions(-) delete mode 100644 test/jdk/java/lang/SecurityManager/modules/CustomSecurityManager.sh create mode 100644 test/jdk/java/lang/SecurityManager/modules/CustomSecurityManagerTest.java delete mode 100644 test/jdk/java/lang/SecurityManager/modules/Test.java diff --git a/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManager.sh b/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManager.sh deleted file mode 100644 index 37b527e34d3..00000000000 --- a/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManager.sh +++ /dev/null @@ -1,66 +0,0 @@ -# -# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# @test -# @summary Basic test of -Djava.security.manager to a class in named module. - -set -e - -if [ -z "$TESTJAVA" ]; then - if [ $# -lt 1 ]; then exit 1; fi - TESTJAVA="$1"; shift - COMPILEJAVA="${TESTJAVA}" - TESTSRC=`pwd` - TESTCLASSES=`pwd` -fi - -OS=`uname -s` -case "$OS" in - Windows*) - PS=";" - ;; - CYGWIN* ) - PS=";" - ;; - * ) - PS=":" - ;; -esac - -JAVAC="$COMPILEJAVA/bin/javac" -JAVA="$TESTJAVA/bin/java ${TESTVMOPTS}" - -mkdir -p mods -$JAVAC -d mods --module-source-path ${TESTSRC} `find ${TESTSRC}/m -name "*.java"` - -mkdir -p classes -$JAVAC -d classes ${TESTSRC}/Test.java - -$JAVA -cp classes --module-path mods --add-modules m \ - -Djava.security.manager \ - -Djava.security.policy=${TESTSRC}/test.policy Test -$JAVA -cp classes --module-path mods --add-modules m \ - -Djava.security.manager=p.CustomSecurityManager \ - -Djava.security.policy=${TESTSRC}/test.policy Test - -exit 0 diff --git a/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManagerTest.java b/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManagerTest.java new file mode 100644 index 00000000000..bb346f04b2a --- /dev/null +++ b/test/jdk/java/lang/SecurityManager/modules/CustomSecurityManagerTest.java @@ -0,0 +1,84 @@ +/* + * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import jdk.test.lib.Utils; +import jdk.test.lib.process.OutputAnalyzer; +import jdk.test.lib.process.ProcessTools; +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; +import java.nio.file.Paths; +import java.util.List; + +/* + * @test + * @summary Basic test of -Djava.security.manager to a class in named module. + * @library /test/lib + * @build jdk.test.lib.process.* + * m/* + * @run testng/othervm CustomSecurityManagerTest + */ +public class CustomSecurityManagerTest { + + private static final String MODULE_PATH = Paths.get(Utils.TEST_CLASSES).resolve("modules").toString(); + private static final String POLICY_PATH = Paths.get(Utils.TEST_SRC).resolve("test.policy").toString(); + + @DataProvider + public Object[][] testCases() { + return new Object[][]{ + new Object[] { List.of( + "--module-path", MODULE_PATH, + "--add-modules", "m", + "-Djava.security.manager", + String.format("-Djava.security.policy=%s", POLICY_PATH), + "RunTest" + ) }, + new Object[] { List.of( + "--module-path", MODULE_PATH, + "--add-modules", "m", + "-Djava.security.manager=p.CustomSecurityManager", + String.format("-Djava.security.policy=%s", POLICY_PATH), + "RunTest" + ) } + }; + } + + @Test(dataProvider = "testCases") + public void testProvider(List args) throws Throwable { + ProcessBuilder processBuilder = ProcessTools.createJavaProcessBuilder(args); + OutputAnalyzer outputAnalyzer = ProcessTools.executeCommand(processBuilder); + outputAnalyzer.shouldHaveExitValue(0); + } + +} + +class RunTest { + public static void main(String... args) { + SecurityManager sm = System.getSecurityManager(); + Module module = sm.getClass().getModule(); + String s = System.getProperty("java.security.manager"); + String expected = s.isEmpty() ? "java.base" : "m"; + if (!module.isNamed() || !module.getName().equals(expected)) { + throw new RuntimeException(module + " expected module m instead"); + } + } +} diff --git a/test/jdk/java/lang/SecurityManager/modules/Test.java b/test/jdk/java/lang/SecurityManager/modules/Test.java deleted file mode 100644 index db499ff6299..00000000000 --- a/test/jdk/java/lang/SecurityManager/modules/Test.java +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public class Test { - public static void main(String... args) { - SecurityManager sm = System.getSecurityManager(); - Module module = sm.getClass().getModule(); - String s = System.getProperty("java.security.manager"); - String expected = s.isEmpty() ? "java.base" : "m"; - if (!module.isNamed() || !module.getName().equals(expected)) { - throw new RuntimeException(module + " expected module m instead"); - } - } -}