diff --git a/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java b/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java index a67e654e1bd..bf2999af048 100644 --- a/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java +++ b/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java @@ -40,7 +40,6 @@ import jdk.test.lib.apps.LingeredApp; import jdk.test.lib.apps.LingeredAppWithDeadlock; import jdk.test.lib.Utils; -import jdk.test.lib.Platform; import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; diff --git a/test/jdk/java/lang/ClassLoader/getResource/GetResource.java b/test/jdk/java/lang/ClassLoader/getResource/GetResource.java index 430a3e5a8ad..8c97657853d 100644 --- a/test/jdk/java/lang/ClassLoader/getResource/GetResource.java +++ b/test/jdk/java/lang/ClassLoader/getResource/GetResource.java @@ -24,7 +24,6 @@ /* * @test * @bug 6760902 - * @library /lib/testlibrary * @library /test/lib * @build jdk.test.lib.process.ProcessTools * @run testng GetResource @@ -45,7 +44,7 @@ import java.util.Map; import java.util.stream.Collectors; import java.util.stream.Stream; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import static jdk.test.lib.process.ProcessTools.*; import org.testng.annotations.BeforeTest; diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/Base.java b/test/jdk/java/lang/System/LoggerFinder/modules/Base.java index b1bb6d7a6fa..80206bffb5b 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/Base.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/Base.java @@ -32,7 +32,7 @@ import java.util.ArrayList; import java.util.List; import java.util.stream.Stream; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.compiler.CompilerUtils; import static jdk.test.lib.process.ProcessTools.executeCommand; diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForImageTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForImageTest.java index 08bd4dd92e0..9588e46131f 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForImageTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForImageTest.java @@ -32,8 +32,8 @@ * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm JDKLoggerForImageTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForJDKTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForJDKTest.java index 2b3bd182f7e..6a0543eca9e 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForJDKTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/JDKLoggerForJDKTest.java @@ -32,8 +32,8 @@ * 2. clients are in named/unnamed module, * patched system module, or Xbootclasspath * This test DOES require existence of java.logging module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm JDKLoggerForJDKTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/LoggerInImageTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/LoggerInImageTest.java index 939b4a031b1..1a617e33395 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/LoggerInImageTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/LoggerInImageTest.java @@ -32,8 +32,8 @@ * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm LoggerInImageTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForImageTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForImageTest.java index 6f4a16a3465..ff0b15abdb5 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForImageTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForImageTest.java @@ -34,8 +34,8 @@ import java.io.File; * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm NamedLoggerForImageTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForJDKTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForJDKTest.java index 5ae4d0be885..46facf7e7cb 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForJDKTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/NamedLoggerForJDKTest.java @@ -34,8 +34,8 @@ import java.io.File; * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm NamedLoggerForJDKTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForImageTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForImageTest.java index 00f3a053604..a1ea6bb8eba 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForImageTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForImageTest.java @@ -34,8 +34,8 @@ import java.io.File; * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm UnnamedLoggerForImageTest */ diff --git a/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForJDKTest.java b/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForJDKTest.java index 95d546988bf..ee93b560365 100644 --- a/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForJDKTest.java +++ b/test/jdk/java/lang/System/LoggerFinder/modules/UnnamedLoggerForJDKTest.java @@ -34,8 +34,8 @@ import java.io.File; * patched system module, or Xbootclasspath * This test does not require existence of java.logging module, * but require jdk.compiler module - * @library /lib/testlibrary /test/lib - * @build Base jdk.test.lib.compiler.CompilerUtils jdk.testlibrary.* + * @library /test/lib + * @build Base jdk.test.lib.compiler.CompilerUtils * @run main/othervm UnnamedLoggerForJDKTest */ diff --git a/test/jdk/java/lang/management/MemoryMXBean/LowMemoryTest.java b/test/jdk/java/lang/management/MemoryMXBean/LowMemoryTest.java index dd3afacc6ee..69a51e2030d 100644 --- a/test/jdk/java/lang/management/MemoryMXBean/LowMemoryTest.java +++ b/test/jdk/java/lang/management/MemoryMXBean/LowMemoryTest.java @@ -45,8 +45,8 @@ import java.util.*; import java.util.concurrent.Phaser; import javax.management.*; import javax.management.openmbean.CompositeData; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolFinder; import jdk.testlibrary.Utils; import sun.hotspot.code.Compiler; diff --git a/test/jdk/java/lang/management/MemoryMXBean/RunUtil.java b/test/jdk/java/lang/management/MemoryMXBean/RunUtil.java index 28fd7bd4491..bf6cab95cfb 100644 --- a/test/jdk/java/lang/management/MemoryMXBean/RunUtil.java +++ b/test/jdk/java/lang/management/MemoryMXBean/RunUtil.java @@ -28,10 +28,10 @@ import java.util.List; import java.util.ArrayList; import java.util.Arrays; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; import jdk.testlibrary.Utils; -import jdk.testlibrary.JDKToolFinder; public class RunUtil { diff --git a/test/jdk/java/net/MulticastSocket/MultiDead.java b/test/jdk/java/net/MulticastSocket/MultiDead.java index d542b22f564..5c616e0bc77 100644 --- a/test/jdk/java/net/MulticastSocket/MultiDead.java +++ b/test/jdk/java/net/MulticastSocket/MultiDead.java @@ -26,6 +26,7 @@ * @bug 8072466 * @summary Deadlock when initializing MulticastSocket and DatagramSocket * @library /lib/testlibrary + * @library /test/lib * @build jdk.testlibrary.* * @run main/othervm MultiDead */ @@ -36,7 +37,7 @@ import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.CountDownLatch; import static java.util.concurrent.TimeUnit.MILLISECONDS; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.testlibrary.Utils; public class MultiDead { diff --git a/test/jdk/java/net/spi/URLStreamHandlerProvider/Basic.java b/test/jdk/java/net/spi/URLStreamHandlerProvider/Basic.java index d5da7fa6621..1968ab22773 100644 --- a/test/jdk/java/net/spi/URLStreamHandlerProvider/Basic.java +++ b/test/jdk/java/net/spi/URLStreamHandlerProvider/Basic.java @@ -46,7 +46,7 @@ import javax.tools.StandardJavaFileManager; import javax.tools.StandardLocation; import javax.tools.ToolProvider; import jdk.test.lib.util.FileUtils; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import static java.lang.String.format; import static java.util.Arrays.asList; @@ -55,10 +55,10 @@ import static java.util.Arrays.asList; * @bug 8064924 * @modules jdk.compiler * @summary Basic test for URLStreamHandlerProvider - * @library /lib/testlibrary /test/lib + * @library /test/lib * @build jdk.test.lib.Platform * jdk.test.lib.util.FileUtils - * jdk.testlibrary.JDKToolFinder + * jdk.test.lib.JDKToolFinder * @compile Basic.java Child.java * @run main Basic */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/EntryProtectionTest.java b/test/jdk/java/security/KeyStore/PKCS12/EntryProtectionTest.java index 5395a72fba5..4cb4950e092 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/EntryProtectionTest.java +++ b/test/jdk/java/security/KeyStore/PKCS12/EntryProtectionTest.java @@ -40,7 +40,7 @@ import java.util.Arrays; * @summary Test for feature 'support stronger entry protection'. An entry is * stored to keystore with different PasswordProtection objects which are * specified by different PBE algorithms (use -Dseed=X to set PRNG seed) - * @library /test/lib /lib/testlibrary ../ + * @library /test/lib ../ * @key randomness * @build jdk.test.lib.RandomFactory * @run main EntryProtectionTest diff --git a/test/jdk/java/security/KeyStore/PKCS12/KeytoolReaderP12Test.java b/test/jdk/java/security/KeyStore/PKCS12/KeytoolReaderP12Test.java index a330a57a101..61e7a713483 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/KeytoolReaderP12Test.java +++ b/test/jdk/java/security/KeyStore/PKCS12/KeytoolReaderP12Test.java @@ -36,7 +36,7 @@ import java.util.List; * @bug 8048830 * @summary Test for PKCS12 keystore list , export commands. Refer README for * keystore files information - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main KeytoolReaderP12Test */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/KeytoolWriteP12Test.java b/test/jdk/java/security/KeyStore/PKCS12/KeytoolWriteP12Test.java index ebf646b2912..e73f8aca360 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/KeytoolWriteP12Test.java +++ b/test/jdk/java/security/KeyStore/PKCS12/KeytoolWriteP12Test.java @@ -31,7 +31,7 @@ import static java.lang.System.out; * @test * @bug 8048830 * @summary Tests for creating pkcs12 keystore with various algorithms - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main KeytoolWriteP12Test */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/MetadataEmptyTest.java b/test/jdk/java/security/KeyStore/PKCS12/MetadataEmptyTest.java index ece59d6bcc5..5e023b4731f 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/MetadataEmptyTest.java +++ b/test/jdk/java/security/KeyStore/PKCS12/MetadataEmptyTest.java @@ -39,7 +39,7 @@ import static java.lang.System.out; * @test * @bug 8048830 * @summary Entry's attribute set should be empty - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main MetadataEmptyTest */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/MetadataStoreLoadTest.java b/test/jdk/java/security/KeyStore/PKCS12/MetadataStoreLoadTest.java index ff779a68307..d202628f18b 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/MetadataStoreLoadTest.java +++ b/test/jdk/java/security/KeyStore/PKCS12/MetadataStoreLoadTest.java @@ -43,7 +43,7 @@ import java.util.HashSet; * @test * @bug 8048830 * @summary Test store metadata attributes to PKCS12 keystore. - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main MetadataStoreLoadTest */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertAPITest.java b/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertAPITest.java index deb8f973250..1e45bafea85 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertAPITest.java +++ b/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertAPITest.java @@ -42,7 +42,7 @@ import static java.lang.System.out; * @summary Test imports certificate from file to PKCS12 keystore store it as * trusted certificate Check import errors (must be not errors) & check keystore * content after import - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main StoreTrustedCertAPITest */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertKeytool.java b/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertKeytool.java index 677225498f0..745ad215731 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertKeytool.java +++ b/test/jdk/java/security/KeyStore/PKCS12/StoreTrustedCertKeytool.java @@ -38,7 +38,7 @@ import static java.lang.System.out; * @bug 8048830 * @summary Tests keytool command imports certificate , list keystore, print * certificate and import password help. - * @library /lib/testlibrary ../ + * @library ../ * @library /test/lib * @run main StoreTrustedCertKeytool */ diff --git a/test/jdk/java/security/KeyStore/PKCS12/Utils.java b/test/jdk/java/security/KeyStore/PKCS12/Utils.java index 1c0e88dc329..67286bd8bea 100644 --- a/test/jdk/java/security/KeyStore/PKCS12/Utils.java +++ b/test/jdk/java/security/KeyStore/PKCS12/Utils.java @@ -34,7 +34,7 @@ import java.util.Arrays; import java.util.List; import jdk.test.lib.process.ProcessTools; import jdk.test.lib.process.OutputAnalyzer; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import static java.lang.System.out; import java.util.ArrayList; diff --git a/test/jdk/javax/management/mxbean/MXBeanWeirdParamTest.java b/test/jdk/javax/management/mxbean/MXBeanWeirdParamTest.java index e1e8c7f5d53..d4d6eaffee6 100644 --- a/test/jdk/javax/management/mxbean/MXBeanWeirdParamTest.java +++ b/test/jdk/javax/management/mxbean/MXBeanWeirdParamTest.java @@ -59,8 +59,8 @@ import javax.management.openmbean.SimpleType; import javax.management.openmbean.TabularDataSupport; import javax.management.openmbean.TabularType; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolFinder; public class MXBeanWeirdParamTest { diff --git a/test/jdk/javax/management/security/AuthorizationTest.java b/test/jdk/javax/management/security/AuthorizationTest.java index 12e17dc31ae..8708c5df1df 100644 --- a/test/jdk/javax/management/security/AuthorizationTest.java +++ b/test/jdk/javax/management/security/AuthorizationTest.java @@ -65,8 +65,8 @@ import javax.management.remote.JMXServiceURL; import javax.management.Attribute ; import javax.management.ObjectName ; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolFinder; public class AuthorizationTest { diff --git a/test/jdk/javax/management/security/SecurityTest.java b/test/jdk/javax/management/security/SecurityTest.java index fc703849e6e..16835991afc 100644 --- a/test/jdk/javax/management/security/SecurityTest.java +++ b/test/jdk/javax/management/security/SecurityTest.java @@ -81,8 +81,8 @@ import javax.rmi.ssl.SslRMIServerSocketFactory; import java.security.Security; +import jdk.test.lib.JDKToolFinder; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolFinder; public class SecurityTest { diff --git a/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolFinder.java b/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolFinder.java deleted file mode 100644 index e88f4e0f9ce..00000000000 --- a/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolFinder.java +++ /dev/null @@ -1,115 +0,0 @@ -/* - * Copyright (c) 2013, 2016, 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. - */ - -package jdk.testlibrary; - -import java.io.FileNotFoundException; -import java.nio.file.Path; -import java.nio.file.Paths; - -/** - * @deprecated This class is deprecated. Use the one from - * {@code /test/lib/jdk/test/lib} - */ -@Deprecated -public final class JDKToolFinder { - - private JDKToolFinder() { - } - - /** - * Returns the full path to an executable in jdk/bin based on System - * property {@code test.jdk} or {@code compile.jdk} (both are set by the jtreg test suite) - * - * @return Full path to an executable in jdk/bin - */ - public static String getJDKTool(String tool) { - - // First try to find the executable in test.jdk - try { - return getTool(tool, "test.jdk"); - } catch (FileNotFoundException e) { - - } - - // Now see if it's available in compile.jdk - try { - return getTool(tool, "compile.jdk"); - } catch (FileNotFoundException e) { - throw new RuntimeException("Failed to find " + tool + - ", looked in test.jdk (" + System.getProperty("test.jdk") + - ") and compile.jdk (" + System.getProperty("compile.jdk") + ")"); - } - } - - /** - * Returns the full path to an executable in jdk/bin based on System - * property {@code compile.jdk} - * - * @return Full path to an executable in jdk/bin - */ - public static String getCompileJDKTool(String tool) { - try { - return getTool(tool, "compile.jdk"); - } catch (FileNotFoundException e) { - throw new RuntimeException(e); - } - } - - /** - * Returns the full path to an executable in jdk/bin based on System - * property {@code test.jdk} - * - * @return Full path to an executable in jdk/bin - */ - public static String getTestJDKTool(String tool) { - try { - return getTool(tool, "test.jdk"); - } catch (FileNotFoundException e) { - throw new RuntimeException(e); - } - } - - private static String getTool(String tool, String property) throws FileNotFoundException { - String jdkPath = System.getProperty(property); - - if (jdkPath == null) { - throw new RuntimeException( - "System property '" + property + "' not set. This property is normally set by jtreg. " - + "When running test separately, set this property using '-D" + property + "=/path/to/jdk'."); - } - - Path toolName = Paths.get("bin", tool + (isWindows() ? ".exe" : "")); - - Path jdkTool = Paths.get(jdkPath, toolName.toString()); - if (!jdkTool.toFile().exists()) { - throw new FileNotFoundException("Could not find file " + jdkTool.toAbsolutePath()); - } - - return jdkTool.toAbsolutePath().toString(); - } - - private static boolean isWindows() { - return System.getProperty("os.name").toLowerCase().startsWith("win"); - } -} diff --git a/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolLauncher.java b/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolLauncher.java deleted file mode 100644 index c19cb5df63a..00000000000 --- a/test/jdk/lib/testlibrary/jdk/testlibrary/JDKToolLauncher.java +++ /dev/null @@ -1,134 +0,0 @@ -/* - * Copyright (c) 2013, 2016, 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. - */ - -package jdk.testlibrary; - -import java.util.ArrayList; -import java.util.List; - -/** - * A utility for constructing command lines for starting JDK tool processes. - * - * The JDKToolLauncher can in particular be combined with a - * java.lang.ProcessBuilder to easily run a JDK tool. For example, the following - * code run {@code jmap -heap} against a process with GC logging turned on for - * the {@code jmap} process: - * - *
- * {@code
- * JDKToolLauncher jmap = JDKToolLauncher.create("jmap")
- *                                       .addVMArg("-Xlog:gc*=debug")
- *                                       .addToolArg("-heap")
- *                                       .addToolArg(pid);
- * ProcessBuilder pb = new ProcessBuilder(jmap.getCommand());
- * Process p = pb.start();
- * }
- * 
- * @deprecated This class is deprecated. Use the one from - * {@code /test/lib/jdk/test/lib} - */ -@Deprecated -public class JDKToolLauncher { - private final String executable; - private final List vmArgs = new ArrayList(); - private final List toolArgs = new ArrayList(); - - private JDKToolLauncher(String tool, boolean useCompilerJDK) { - if (useCompilerJDK) { - executable = JDKToolFinder.getJDKTool(tool); - } else { - executable = JDKToolFinder.getTestJDKTool(tool); - } - } - - /** - * Creates a new JDKToolLauncher for the specified tool. Using tools path - * from the compiler JDK. - * - * @param tool - * The name of the tool - * @return A new JDKToolLauncher - */ - public static JDKToolLauncher create(String tool) { - return new JDKToolLauncher(tool, true); - } - - /** - * Creates a new JDKToolLauncher for the specified tool in the Tested JDK. - * - * @param tool - * The name of the tool - * - * @return A new JDKToolLauncher - */ - public static JDKToolLauncher createUsingTestJDK(String tool) { - return new JDKToolLauncher(tool, false); - } - - /** - * Adds an argument to the JVM running the tool. - * - * The JVM arguments are passed to the underlying JVM running the tool. - * Arguments will automatically be prepended with "-J". - * - * Any platform specific arguments required for running the tool are - * automatically added. - * - * - * @param arg - * The argument to VM running the tool - * @return The JDKToolLauncher instance - */ - public JDKToolLauncher addVMArg(String arg) { - vmArgs.add(arg); - return this; - } - - /** - * Adds an argument to the tool. - * - * @param arg - * The argument to the tool - * @return The JDKToolLauncher instance - */ - public JDKToolLauncher addToolArg(String arg) { - toolArgs.add(arg); - return this; - } - - /** - * Returns the command that can be used for running the tool. - * - * @return An array whose elements are the arguments of the command. - */ - public String[] getCommand() { - List command = new ArrayList(); - command.add(executable); - // Add -J in front of all vmArgs - for (String arg : vmArgs) { - command.add("-J" + arg); - } - command.addAll(toolArgs); - return command.toArray(new String[command.size()]); - } -} diff --git a/test/jdk/sun/management/jmxremote/startstop/ManagementAgentJcmd.java b/test/jdk/sun/management/jmxremote/startstop/ManagementAgentJcmd.java index 01e875be146..0781bc941fd 100644 --- a/test/jdk/sun/management/jmxremote/startstop/ManagementAgentJcmd.java +++ b/test/jdk/sun/management/jmxremote/startstop/ManagementAgentJcmd.java @@ -33,7 +33,7 @@ import java.util.stream.Collectors; import jdk.internal.agent.Agent; import jdk.internal.agent.AgentConfigurationError; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.ProcessTools; /** diff --git a/test/jdk/sun/security/tools/jarsigner/Warning.java b/test/jdk/sun/security/tools/jarsigner/Warning.java index 2bde829c6a1..9dc8ee01b18 100644 --- a/test/jdk/sun/security/tools/jarsigner/Warning.java +++ b/test/jdk/sun/security/tools/jarsigner/Warning.java @@ -21,7 +21,7 @@ * questions. */ -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.util.JarUtils; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; diff --git a/test/jdk/sun/tools/jcmd/JcmdBase.java b/test/jdk/sun/tools/jcmd/JcmdBase.java index 93846ed2da8..2e4c8eaa1eb 100644 --- a/test/jdk/sun/tools/jcmd/JcmdBase.java +++ b/test/jdk/sun/tools/jcmd/JcmdBase.java @@ -25,7 +25,7 @@ import java.util.Arrays; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; /** * Helper class for starting jcmd process. diff --git a/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java b/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java index 49f102774d1..667ed0e3d03 100644 --- a/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java +++ b/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java @@ -44,7 +44,7 @@ import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; import jdk.test.lib.apps.LingeredApp; import jdk.test.lib.Platform; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.testlibrary.Utils; public class BasicLauncherTest { diff --git a/test/jdk/sun/tools/jhsdb/HeapDumpTest.java b/test/jdk/sun/tools/jhsdb/HeapDumpTest.java index 8ab956ad8f6..7b9a95e6481 100644 --- a/test/jdk/sun/tools/jhsdb/HeapDumpTest.java +++ b/test/jdk/sun/tools/jhsdb/HeapDumpTest.java @@ -39,12 +39,12 @@ import java.io.File; import java.util.List; import java.util.Arrays; +import jdk.test.lib.Platform; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; import jdk.test.lib.apps.LingeredApp; -import jdk.test.lib.Platform; import jdk.test.lib.hprof.parser.HprofReader; -import jdk.testlibrary.JDKToolLauncher; public class HeapDumpTest { diff --git a/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java b/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java index 25beea66f72..7793c295305 100644 --- a/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java +++ b/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java @@ -33,7 +33,7 @@ import java.util.logging.Level; import java.util.logging.Logger; import jdk.test.lib.apps.LingeredApp; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.testlibrary.Utils; public class TmtoolTestScenario { diff --git a/test/jdk/sun/tools/jinfo/BasicJInfoTest.java b/test/jdk/sun/tools/jinfo/BasicJInfoTest.java index d9865d26184..b1ddf8b8f6b 100644 --- a/test/jdk/sun/tools/jinfo/BasicJInfoTest.java +++ b/test/jdk/sun/tools/jinfo/BasicJInfoTest.java @@ -23,16 +23,14 @@ import java.util.Arrays; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolLauncher; /* * @test * @summary Unit test for jinfo utility - * @library /lib/testlibrary * @library /test/lib - * @build jdk.testlibrary.* * @run main BasicJInfoTest */ public class BasicJInfoTest { diff --git a/test/jdk/sun/tools/jmap/BasicJMapTest.java b/test/jdk/sun/tools/jmap/BasicJMapTest.java index bbfa8ef0f41..3e33e75dd94 100644 --- a/test/jdk/sun/tools/jmap/BasicJMapTest.java +++ b/test/jdk/sun/tools/jmap/BasicJMapTest.java @@ -27,10 +27,10 @@ import static jdk.testlibrary.Asserts.fail; import java.io.File; import java.util.Arrays; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.hprof.HprofParser; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolLauncher; /* * @test diff --git a/test/jdk/sun/tools/jps/JpsHelper.java b/test/jdk/sun/tools/jps/JpsHelper.java index 5d671e02851..72a87c43892 100644 --- a/test/jdk/sun/tools/jps/JpsHelper.java +++ b/test/jdk/sun/tools/jps/JpsHelper.java @@ -35,10 +35,10 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; import jdk.testlibrary.Asserts; -import jdk.testlibrary.JDKToolLauncher; import jdk.testlibrary.Utils; /** diff --git a/test/jdk/sun/tools/jstack/BasicJStackTest.java b/test/jdk/sun/tools/jstack/BasicJStackTest.java index 7435f6dc296..b17033db34a 100644 --- a/test/jdk/sun/tools/jstack/BasicJStackTest.java +++ b/test/jdk/sun/tools/jstack/BasicJStackTest.java @@ -25,14 +25,12 @@ import java.util.Arrays; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; /* * @test * @summary Unit test for jstack utility - * @library /lib/testlibrary * @library /test/lib - * @build jdk.testlibrary.* * @run main BasicJStackTest */ public class BasicJStackTest { diff --git a/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java b/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java index bf47c911448..fb352fa3dc0 100644 --- a/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java +++ b/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java @@ -32,7 +32,7 @@ import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; import jdk.testlibrary.Utils; -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; /** * @test diff --git a/test/jdk/sun/tools/jstat/JStatInterval.java b/test/jdk/sun/tools/jstat/JStatInterval.java index da4bf09fff9..edd7a788752 100644 --- a/test/jdk/sun/tools/jstat/JStatInterval.java +++ b/test/jdk/sun/tools/jstat/JStatInterval.java @@ -24,18 +24,17 @@ /** * @test * @bug 8035668 - * @library /lib/testlibrary * @library /test/lib * @summary Test checks case when target application finishes execution and jstat didn't complete work. jstat is started with interval = 100 (jstat -compiler 100) and monitored application finishes after 500ms. This shouldn't cause crash or hang in target application or in jstat. * @modules java.management - * @build jdk.testlibrary.* JStatInterval + * @build JStatInterval * @run main JStatInterval */ +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.ProcessTools; -import jdk.testlibrary.JDKToolLauncher; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicBoolean; diff --git a/test/jdk/sun/tools/jstat/jstatClassloadOutput1.sh b/test/jdk/sun/tools/jstat/jstatClassloadOutput1.sh index 14aeebe6269..ec585b2af08 100644 --- a/test/jdk/sun/tools/jstat/jstatClassloadOutput1.sh +++ b/test/jdk/sun/tools/jstat/jstatClassloadOutput1.sh @@ -22,7 +22,7 @@ # # @test -# @bug 6959965 +# @bug 6959965 # @run shell jstatClassloadOutput1.sh # @summary Test that output of 'jstat -classload 0' has expected line counts diff --git a/test/jdk/sun/tools/jstatd/JstatdTest.java b/test/jdk/sun/tools/jstatd/JstatdTest.java index 76db74019aa..e4362b3380c 100644 --- a/test/jdk/sun/tools/jstatd/JstatdTest.java +++ b/test/jdk/sun/tools/jstatd/JstatdTest.java @@ -30,8 +30,8 @@ import java.util.Arrays; import jdk.test.lib.thread.ProcessThread; import static jdk.testlibrary.Asserts.*; -import jdk.testlibrary.JDKToolLauncher; import jdk.testlibrary.Utils; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; diff --git a/test/jdk/sun/tools/jstatd/TestJstatdUsage.java b/test/jdk/sun/tools/jstatd/TestJstatdUsage.java index 3ee83b4dc18..9d594535111 100644 --- a/test/jdk/sun/tools/jstatd/TestJstatdUsage.java +++ b/test/jdk/sun/tools/jstatd/TestJstatdUsage.java @@ -21,17 +21,15 @@ * questions. */ -import jdk.testlibrary.JDKToolLauncher; +import jdk.test.lib.JDKToolLauncher; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; /* * @test * @bug 4990825 - * @library /lib/testlibrary * @library /test/lib * @modules java.management - * @build jdk.testlibrary.* * @run main TestJstatdUsage */ public class TestJstatdUsage { diff --git a/test/jdk/tools/jar/compat/CLICompatibility.java b/test/jdk/tools/jar/compat/CLICompatibility.java index e32287d5690..7c83b29720c 100644 --- a/test/jdk/tools/jar/compat/CLICompatibility.java +++ b/test/jdk/tools/jar/compat/CLICompatibility.java @@ -36,7 +36,7 @@ import java.util.jar.JarOutputStream; import java.util.stream.Stream; import jdk.test.lib.util.FileUtils; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import org.testng.annotations.BeforeTest; import org.testng.annotations.Test; @@ -52,7 +52,7 @@ import static org.testng.Assert.assertTrue; * @library /lib/testlibrary /test/lib * @build jdk.test.lib.Platform * jdk.test.lib.util.FileUtils - * jdk.testlibrary.JDKToolFinder + * jdk.test.lib.JDKToolFinder * @run testng CLICompatibility * @summary Basic test for compatibility of CLI options */ diff --git a/test/jdk/tools/jar/modularJar/Basic.java b/test/jdk/tools/jar/modularJar/Basic.java index b9dcfe3cb94..ffc58eec9d5 100644 --- a/test/jdk/tools/jar/modularJar/Basic.java +++ b/test/jdk/tools/jar/modularJar/Basic.java @@ -36,7 +36,7 @@ import java.util.stream.Collectors; import java.util.stream.Stream; import jdk.test.lib.util.FileUtils; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import org.testng.annotations.BeforeTest; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; @@ -47,12 +47,12 @@ import static java.lang.System.out; /* * @test * @bug 8167328 8171830 8165640 8174248 8176772 8196748 8191533 - * @library /lib/testlibrary /test/lib + * @library /test/lib * @modules jdk.compiler * jdk.jartool * @build jdk.test.lib.Platform * jdk.test.lib.util.FileUtils - * jdk.testlibrary.JDKToolFinder + * jdk.test.lib.JDKToolFinder * @compile Basic.java * @run testng Basic * @summary Tests for plain Modular jars & Multi-Release Modular jars diff --git a/test/jdk/tools/launcher/modules/patch/systemmodules/PatchSystemModules.java b/test/jdk/tools/launcher/modules/patch/systemmodules/PatchSystemModules.java index aed9f61090f..e8d160366f5 100644 --- a/test/jdk/tools/launcher/modules/patch/systemmodules/PatchSystemModules.java +++ b/test/jdk/tools/launcher/modules/patch/systemmodules/PatchSystemModules.java @@ -25,7 +25,7 @@ * @test * @bug 8157068 8177844 * @summary Patch java.base and user module with ModuleHashes attribute - * @library /lib/testlibrary /test/lib + * @library /test/lib * @modules jdk.compiler * @build jdk.test.lib.compiler.CompilerUtils * jdk.test.lib.util.FileUtils @@ -43,7 +43,7 @@ import java.util.stream.Stream; import jdk.test.lib.compiler.CompilerUtils; import jdk.test.lib.util.FileUtils; -import jdk.testlibrary.JDKToolFinder; +import jdk.test.lib.JDKToolFinder; import org.testng.annotations.BeforeTest; import org.testng.annotations.Test;