8209773: Refactor shell test javax/naming/module/basic.sh to java
Reviewed-by: vtewari, alanb
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/test/jdk/javax/naming/module/RunBasic.java Tue Sep 11 09:27:47 2018 +0800
@@ -0,0 +1,122 @@
+/*
+ * Copyright (c) 2015, 2018, 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.JDKToolFinder;
+import jdk.test.lib.Utils;
+import jdk.test.lib.compiler.CompilerUtils;
+import jdk.test.lib.process.ProcessTools;
+
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+import java.util.stream.Collectors;
+import java.util.stream.Stream;
+
+import static jdk.test.lib.Utils.TEST_SRC;
+
+/*
+ * @test
+ * @summary Test of JNDI factories using classes exported by third-party modules.
+ * @library /test/lib
+ * @modules jdk.compiler
+ * @run main RunBasic
+ */
+
+/*
+ * Demonstrates Java object storage/retrieval, LDAP control and URL context
+ * usage using an LDAP directory. The objects and their associated object
+ * factories, state factories, control factories and URL context factories
+ * are exported from third-party modules.
+ *
+ * Seven types of object are used:
+ * - an AWT object (Serializable) from the 'java.desktop' JDK module
+ * - a Person object (DirContext) from the 'person' third-party module
+ * - a Fruit object (Referenceable) from the 'fruit' third-party module
+ * - an RMI object (Remote) from the 'hello' third-party module
+ * - an LDAP request control (Control) from the 'foo' third-party module
+ * - an LDAP response control (Control) from the 'authz' third-party module
+ * - an ldapv4 URL (DirContext) from the 'ldapv4' third-party module
+ */
+
+public class RunBasic {
+
+ private static final List<String> JAVA_CMDS;
+
+ static {
+ String javaPath = JDKToolFinder.getJDKTool("java");
+
+ JAVA_CMDS = Stream
+ .concat(Stream.of(javaPath), Stream.of(Utils.getTestJavaOpts()))
+ .collect(Collectors.collectingAndThen(Collectors.toList(),
+ Collections::unmodifiableList));
+ }
+
+ public static void main(String[] args) throws Throwable {
+ // prepare all test modules
+ prepareModule("person");
+ prepareModule("fruit");
+ prepareModule("hello");
+ prepareModule("foo");
+ prepareModule("authz");
+ prepareModule("ldapv4");
+ prepareModule("test", "--module-source-path",
+ Path.of(TEST_SRC, "src").toString());
+
+ // run tests
+ runTest("java.desktop", "test.StoreObject");
+ runTest("person", "test.StorePerson");
+ runTest("fruit", "test.StoreFruit");
+ runTest("hello", "test.StoreRemote");
+ runTest("foo", "test.ConnectWithFoo");
+ runTest("authz", "test.ConnectWithAuthzId");
+ runTest("ldapv4", "test.ReadByUrl");
+ }
+
+ private static void prepareModule(String mod, String... opts)
+ throws IOException {
+ System.out.println("Preparing the '" + mod + "' module...");
+ makeDir("mods", mod);
+ CompilerUtils.compile(Path.of(TEST_SRC, "src", mod),
+ Path.of("mods", (mod.equals("test") ? "" : mod)), opts);
+ }
+
+ private static void makeDir(String first, String... more)
+ throws IOException {
+ Files.createDirectories(Path.of(first, more));
+ }
+
+ private static void runTest(String desc, String clsName) throws Throwable {
+ System.out.println("Running with the '" + desc + "' module...");
+ runJava("-Dtest.src=" + TEST_SRC, "-p", "mods", "-m", "test/" + clsName,
+ "ldap://localhost/dc=ie,dc=oracle,dc=com");
+ }
+
+ private static void runJava(String... opts) throws Throwable {
+ ProcessTools.executeCommand(
+ Stream.of(JAVA_CMDS, List.of(opts)).flatMap(Collection::stream)
+ .toArray(String[]::new)).shouldHaveExitValue(0);
+ }
+}
--- a/test/jdk/javax/naming/module/basic.sh Tue Sep 11 08:48:26 2018 +0800
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,104 +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 Test of JNDI factories using classes exported by third-party modules.
-
-# Demonstrates Java object storage/retrieval, LDAP control and URL context
-# usage using an LDAP directory. The objects and their associated object
-# factories, state factories, control factories and URL context factories
-# are exported from third-party modules.
-#
-# Seven types of object are used:
-# - an AWT object (Serializable) from the 'java.desktop' JDK module
-# - a Person object (DirContext) from the 'person' third-party module
-# - a Fruit object (Referenceable) from the 'fruit' third-party module
-# - an RMI object (Remote) from the 'hello' third-party module
-# - an LDAP request control (Control) from the 'foo' third-party module
-# - an LDAP response control (Control) from the 'authz' third-party module
-# - an ldapv4 URL (DirContext) from the 'ldapv4' third-party module
-#
-
-set -e
-
-if [ -z "$TESTJAVA" ]; then
- if [ $# -lt 1 ]; then exit 1; fi
- TESTJAVA="$1"; shift
- COMPILEJAVA="${TESTJAVA}"
- TESTSRC="`pwd`"
- TESTCLASSES="`pwd`"
-fi
-
-JAVAC="$COMPILEJAVA/bin/javac"
-JAVA="$TESTJAVA/bin/java"
-
-echo "\nPreparing the 'person' module..."
-mkdir -p mods/person
-$JAVAC -d mods/person `find $TESTSRC/src/person -name "*.java"`
-
-echo "\nPreparing the 'fruit' module..."
-mkdir -p mods/fruit
-$JAVAC -d mods/fruit `find $TESTSRC/src/fruit -name "*.java"`
-
-echo "\nPreparing the 'hello' module..."
-mkdir -p mods/hello
-$JAVAC -d mods/hello `find $TESTSRC/src/hello -name "*.java"`
-
-echo "\nPreparing the 'foo' module..."
-mkdir -p mods/foo
-$JAVAC -d mods/foo `find $TESTSRC/src/foo -name "*.java"`
-
-echo "\nPreparing the 'authz' module..."
-mkdir -p mods/authz
-$JAVAC -d mods/authz `find $TESTSRC/src/authz -name "*.java"`
-
-echo "\nPreparing the 'ldapv4' module..."
-mkdir -p mods/ldapv4
-$JAVAC -d mods/ldapv4 `find $TESTSRC/src/ldapv4 -name "*.java"`
-
-echo "\nPreparing the 'test' module..."
-mkdir -p mods/test
-$JAVAC -d mods --module-source-path $TESTSRC/src `find $TESTSRC/src/test -name "*.java"`
-
-
-echo "\nRunning with the 'java.desktop' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.StoreObject ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'person' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.StorePerson ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'fruit' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.StoreFruit ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'hello' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.StoreRemote ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'foo' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.ConnectWithFoo ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'authz' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.ConnectWithAuthzId ldap://localhost/dc=ie,dc=oracle,dc=com
-
-echo "\nRunning with the 'ldapv4' module..."
-$JAVA -Dtest.src=${TESTSRC} -p mods -m test/test.ReadByUrl ldap://localhost/dc=ie,dc=oracle,dc=com
-