diff --git a/jdk/make/rmic/Rmic-java.management.gmk b/jdk/make/rmic/Rmic-java.management.rmi.gmk similarity index 94% rename from jdk/make/rmic/Rmic-java.management.gmk rename to jdk/make/rmic/Rmic-java.management.rmi.gmk index 0feaac3b88b..50c090c1deb 100644 --- a/jdk/make/rmic/Rmic-java.management.gmk +++ b/jdk/make/rmic/Rmic-java.management.rmi.gmk @@ -39,8 +39,8 @@ JMX_RMI_CLASSES := javax.management.remote.rmi.RMIConnectionImpl \ # into the stub classes dir. $(eval $(call SetupRMICompilation,RMI_GEN, \ CLASSES := $(JMX_RMI_CLASSES), \ - CLASSES_DIR := $(CLASSES_DIR)/java.management, \ - STUB_CLASSES_DIR := $(RMIC_GENSRC_DIR)/java.management, \ + CLASSES_DIR := $(CLASSES_DIR)/java.management.rmi, \ + STUB_CLASSES_DIR := $(RMIC_GENSRC_DIR)/java.management.rmi, \ RUN_V12 := true, \ KEEP_GENERATED := true, \ )) diff --git a/jdk/src/java.base/share/classes/module-info.java b/jdk/src/java.base/share/classes/module-info.java index 21d8507d14d..81dfa84a26a 100644 --- a/jdk/src/java.base/share/classes/module-info.java +++ b/jdk/src/java.base/share/classes/module-info.java @@ -150,7 +150,7 @@ module java.base { java.desktop; exports jdk.internal.module to java.instrument, - java.management, + java.management.rmi, jdk.jartool, jdk.jlink; exports jdk.internal.misc to @@ -235,6 +235,7 @@ module java.base { java.desktop, java.datatransfer, java.management, + java.management.rmi, java.rmi, java.sql.rowset, java.xml, diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ProxyRef.java b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/ProxyRef.java similarity index 98% rename from jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ProxyRef.java rename to jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/ProxyRef.java index 3027bd25177..a86f26b90c9 100644 --- a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ProxyRef.java +++ b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/ProxyRef.java @@ -23,7 +23,7 @@ * questions. */ -package com.sun.jmx.remote.internal; +package com.sun.jmx.remote.internal.rmi; import java.io.IOException; import java.io.ObjectInput; diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/RMIExporter.java b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/RMIExporter.java similarity index 98% rename from jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/RMIExporter.java rename to jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/RMIExporter.java index 8568aa95f35..cd292850a2b 100644 --- a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/RMIExporter.java +++ b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/RMIExporter.java @@ -23,7 +23,7 @@ * questions. */ -package com.sun.jmx.remote.internal; +package com.sun.jmx.remote.internal.rmi; import java.rmi.NoSuchObjectException; import java.rmi.Remote; diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/Unmarshal.java b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/Unmarshal.java similarity index 97% rename from jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/Unmarshal.java rename to jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/Unmarshal.java index de865caf73a..9c8fd435bb0 100644 --- a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/Unmarshal.java +++ b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/internal/rmi/Unmarshal.java @@ -23,7 +23,7 @@ * questions. */ -package com.sun.jmx.remote.internal; +package com.sun.jmx.remote.internal.rmi; import java.io.IOException; import java.rmi.MarshalledObject; diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/protocol/rmi/ClientProvider.java b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/protocol/rmi/ClientProvider.java similarity index 100% rename from jdk/src/java.management/share/classes/com/sun/jmx/remote/protocol/rmi/ClientProvider.java rename to jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/protocol/rmi/ClientProvider.java diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/protocol/rmi/ServerProvider.java b/jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/protocol/rmi/ServerProvider.java similarity index 100% rename from jdk/src/java.management/share/classes/com/sun/jmx/remote/protocol/rmi/ServerProvider.java rename to jdk/src/java.management.rmi/share/classes/com/sun/jmx/remote/protocol/rmi/ServerProvider.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnection.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnection.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnection.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnection.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java similarity index 99% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java index fb7c00cd2d9..40cfbe03dce 100644 --- a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java +++ b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnectionImpl.java @@ -48,7 +48,7 @@ import javax.management.remote.NotificationResult; import javax.security.auth.Subject; import sun.reflect.misc.ReflectUtil; -import static com.sun.jmx.mbeanserver.Util.cast; +import static javax.management.remote.rmi.RMIConnector.Util.cast; import com.sun.jmx.remote.internal.ServerCommunicatorAdmin; import com.sun.jmx.remote.internal.ServerNotifForwarder; import com.sun.jmx.remote.security.JMXSubjectDomainCombiner; diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnector.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnector.java similarity index 98% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnector.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnector.java index 93a5c7cbdd1..7684567c1ca 100644 --- a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnector.java +++ b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnector.java @@ -25,11 +25,10 @@ package javax.management.remote.rmi; -import com.sun.jmx.mbeanserver.Util; import com.sun.jmx.remote.internal.ClientCommunicatorAdmin; import com.sun.jmx.remote.internal.ClientListenerInfo; import com.sun.jmx.remote.internal.ClientNotifForwarder; -import com.sun.jmx.remote.internal.ProxyRef; +import com.sun.jmx.remote.internal.rmi.ProxyRef; import com.sun.jmx.remote.util.ClassLogger; import com.sun.jmx.remote.util.EnvHelp; import java.io.ByteArrayInputStream; @@ -106,6 +105,7 @@ import jdk.internal.module.Modules; import sun.reflect.misc.ReflectUtil; import sun.rmi.server.UnicastRef2; import sun.rmi.transport.LiveRef; +import java.io.NotSerializableException; /** *

A connection to a remote RMI connector. Usually, such @@ -124,6 +124,24 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable private static final long serialVersionUID = 817323035842634473L; + static final class Util { + private Util() {} + + /* This method can be used by code that is deliberately violating the + * allowed checked casts. Rather than marking the whole method containing + * the code with @SuppressWarnings, you can use a call to this method for + * the exact place where you need to escape the constraints. Typically + * you will "import static" this method and then write either + * X x = cast(y); + * or, if that doesn't work (e.g. X is a type variable) + * Util.cast(y); + */ + @SuppressWarnings("unchecked") + public static T cast(Object x) { + return (T) x; + } + } + private RMIConnector(RMIServer rmiServer, JMXServiceURL address, Map environment) { if (rmiServer == null && address == null) throw new @@ -1390,7 +1408,9 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable throws ClassNotFoundException, IOException { // specially treating for an UnmarshalException if (ioe instanceof UnmarshalException) { - throw ioe; // the fix of 6937053 made ClientNotifForwarder.fetchNotifs + NotSerializableException nse = new NotSerializableException(); + nse.initCause(ioe); + throw nse; // the fix of 6937053 made ClientNotifForwarder.fetchNotifs // fetch one by one with UnmarshalException } @@ -1935,12 +1955,12 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable The byte code below encodes the following class, compiled using J2SE 1.4.2 with the -g:none option. - package com.sun.jmx.remote.internal; + package jdk.jmx.remote.internal.rmi; import java.lang.reflect.Method; import java.rmi.Remote; import java.rmi.server.RemoteRef; - import com.sun.jmx.remote.internal.ProxyRef; + import com.sun.jmx.remote.internal.rmi.ProxyRef; public class PRef extends ProxyRef { public PRef(RemoteRef ref) { @@ -1962,22 +1982,22 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable RMIConnection.class.getName() + "Impl_Stub"; private static final Class rmiConnectionImplStubClass; private static final String pRefClassName = - "jdk.jmx.remote.internal.PRef"; + "jdk.jmx.remote.internal.rmi.PRef"; private static final Constructor proxyRefConstructor; static { final String pRefByteCodeString = - "\312\376\272\276\0\0\0\60\0\27\12\0\5\0\15\11\0\4\0\16\13\0\17"+ + "\312\376\272\276\0\0\0\65\0\27\12\0\5\0\15\11\0\4\0\16\13\0\17"+ "\0\20\7\0\21\7\0\22\1\0\6\1\0\36(Ljava/rmi/server/Remote"+ "Ref;)V\1\0\4Code\1\0\6invoke\1\0S(Ljava/rmi/Remote;Ljava/lang/"+ "reflect/Method;[Ljava/lang/Object;J)Ljava/lang/Object;\1\0\12E"+ "xceptions\7\0\23\14\0\6\0\7\14\0\24\0\25\7\0\26\14\0\11\0\12\1"+ - "\0\34jdk/jmx/remote/internal/PRef\1\0$com/sun/jmx/remote/inter"+ - "nal/ProxyRef\1\0\23java/lang/Exception\1\0\3ref\1\0\33Ljava/rm"+ - "i/server/RemoteRef;\1\0\31java/rmi/server/RemoteRef\0!\0\4\0\5"+ - "\0\0\0\0\0\2\0\1\0\6\0\7\0\1\0\10\0\0\0\22\0\2\0\2\0\0\0\6*+\267"+ - "\0\1\261\0\0\0\0\0\1\0\11\0\12\0\2\0\10\0\0\0\33\0\6\0\6\0\0\0"+ - "\17*\264\0\2+,-\26\4\271\0\3\6\0\260\0\0\0\0\0\13\0\0\0\4\0\1\0"+ - "\14\0\0"; + "\0 jdk/jmx/remote/internal/rmi/PRef\1\0(com/sun/jmx/remote/int"+ + "ernal/rmi/ProxyRef\1\0\23java/lang/Exception\1\0\3ref\1\0\33Lj"+ + "ava/rmi/server/RemoteRef;\1\0\31java/rmi/server/RemoteRef\0!\0"+ + "\4\0\5\0\0\0\0\0\2\0\1\0\6\0\7\0\1\0\10\0\0\0\22\0\2\0\2\0\0\0"+ + "\6*+\267\0\1\261\0\0\0\0\0\1\0\11\0\12\0\2\0\10\0\0\0\33\0\6\0"+ + "\6\0\0\0\17*\264\0\2+,-\26\4\271\0\3\6\0\260\0\0\0\0\0\13\0\0\0"+ + "\4\0\1\0\14\0\0"; final byte[] pRefByteCode = NoCallStackClassLoader.stringToBytes(pRefByteCodeString); PrivilegedExceptionAction> action = diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnectorServer.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnectorServer.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIConnectorServer.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIConnectorServer.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java similarity index 99% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java index 838c092ca48..8bcbe1919ad 100644 --- a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java +++ b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIJRMPServerImpl.java @@ -37,7 +37,7 @@ import java.util.Map; import java.util.Collections; import javax.security.auth.Subject; -import com.sun.jmx.remote.internal.RMIExporter; +import com.sun.jmx.remote.internal.rmi.RMIExporter; import com.sun.jmx.remote.util.EnvHelp; import java.io.ObjectStreamClass; import java.lang.reflect.Method; diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIServer.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIServer.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIServer.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIServer.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIServerImpl.java b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIServerImpl.java similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/RMIServerImpl.java rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/RMIServerImpl.java diff --git a/jdk/src/java.management/share/classes/javax/management/remote/rmi/package.html b/jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/package.html similarity index 100% rename from jdk/src/java.management/share/classes/javax/management/remote/rmi/package.html rename to jdk/src/java.management.rmi/share/classes/javax/management/remote/rmi/package.html diff --git a/jdk/src/java.management.rmi/share/classes/module-info.java b/jdk/src/java.management.rmi/share/classes/module-info.java new file mode 100644 index 00000000000..ae6fc006c99 --- /dev/null +++ b/jdk/src/java.management.rmi/share/classes/module-info.java @@ -0,0 +1,74 @@ +/* + * Copyright (c) 2017, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * Defines the RMI Connector for the Java Management Extensions (JMX) Remote API. + *

+ * The {@linkplain javax.management.remote.rmi RMI connector} is a connector + * for the JMX Remote API that uses RMI to transmit client requests to a remote + * MBean server. + * + * @provides javax.management.remote.JMXConnectorProvider + * A provider of {@code JMXConnector} for the RMI protocol.
+ * Instances of {@code JMXConnector} using the RMI protocol + * are usually created by the {@link + * javax.management.remote.JMXConnectorFactory} which will locate + * and load the appropriate {@code JMXConnectorProvider} service + * implementation for the given protocol. + * + * @provides javax.management.remote.JMXConnectorServerProvider + * A provider of {@code JMXConnectorServer} for the RMI protocol.
+ * Instances of {@code JMXConnectorServer} using the RMI protocol + * are usually created by the {@link + * javax.management.remote.JMXConnectorServerFactory} which will locate + * and load the appropriate {@code JMXConnectorServerProvider} service + * implementation for the given protocol. + * + */ +module java.management.rmi { + + requires transitive java.management; + requires transitive java.rmi; + requires java.naming; + + exports javax.management.remote.rmi; + + // The qualified export below is required to preserve backward + // compatibility for the legacy case where an ordered list + // of package prefixes can be specified to the factory. + exports com.sun.jmx.remote.protocol.rmi to java.management; + + // jdk.management.agent needs to create an RMIExporter instance. + exports com.sun.jmx.remote.internal.rmi to jdk.management.agent; + + // The java.management.rmi module provides implementations + // of the JMXConnectorProvider and JMXConnectorServerProvider + // services supporting the RMI protocol. + provides javax.management.remote.JMXConnectorProvider + with com.sun.jmx.remote.protocol.rmi.ClientProvider; + provides javax.management.remote.JMXConnectorServerProvider + with com.sun.jmx.remote.protocol.rmi.ServerProvider; + +} diff --git a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ClientNotifForwarder.java b/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ClientNotifForwarder.java index f2014eee794..d835171c0f4 100644 --- a/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ClientNotifForwarder.java +++ b/jdk/src/java.management/share/classes/com/sun/jmx/remote/internal/ClientNotifForwarder.java @@ -52,7 +52,6 @@ import javax.management.remote.TargetedNotification; import com.sun.jmx.remote.util.ClassLogger; import com.sun.jmx.remote.util.EnvHelp; import java.lang.reflect.UndeclaredThrowableException; -import java.rmi.UnmarshalException; import java.util.concurrent.RejectedExecutionException; @@ -633,7 +632,7 @@ public abstract class ClientNotifForwarder { } return nr; - } catch (ClassNotFoundException | NotSerializableException | UnmarshalException e) { + } catch (ClassNotFoundException | NotSerializableException e) { logger.trace("NotifFetcher.fetchNotifs", e); return fetchOneNotif(); } catch (IOException ioe) { @@ -705,7 +704,7 @@ public abstract class ClientNotifForwarder { try { // 1 notif to skip possible missing class result = cnf.fetchNotifs(startSequenceNumber, 1, 0L); - } catch (ClassNotFoundException | NotSerializableException | UnmarshalException e) { + } catch (ClassNotFoundException | NotSerializableException e) { logger.warning("NotifFetcher.fetchOneNotif", "Failed to deserialize a notification: "+e.toString()); if (logger.traceOn()) { diff --git a/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorFactory.java b/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorFactory.java index 4c6479e12b5..580829c834c 100644 --- a/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorFactory.java +++ b/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorFactory.java @@ -27,13 +27,17 @@ package javax.management.remote; import com.sun.jmx.mbeanserver.Util; import java.io.IOException; +import java.io.UncheckedIOException; +import java.lang.reflect.Module; import java.net.MalformedURLException; import java.util.Collections; import java.util.HashMap; import java.util.Map; -import java.util.Iterator; import java.util.ServiceLoader; +import java.util.ServiceLoader.Provider; import java.util.StringTokenizer; +import java.util.function.Predicate; +import java.util.stream.Stream; import java.security.AccessController; import java.security.PrivilegedAction; @@ -332,25 +336,32 @@ public class JMXConnectorFactory { IOException exception = null; if (provider == null) { + Predicate> systemProvider = + JMXConnectorFactory::isSystemProvider; // Loader is null when context class loader is set to null // and no loader has been provided in map. // com.sun.jmx.remote.util.Service class extracted from j2se // provider search algorithm doesn't handle well null classloader. + JMXConnector connection = null; if (loader != null) { try { - JMXConnector connection = - getConnectorAsService(loader, providerURL, envcopy); - if (connection != null) - return connection; + connection = getConnectorAsService(loader, + providerURL, + envcopy, + systemProvider.negate()); + if (connection != null) return connection; } catch (JMXProviderException e) { throw e; } catch (IOException e) { exception = e; } } - provider = getProvider(protocol, PROTOCOL_PROVIDER_DEFAULT_PACKAGE, - JMXConnectorFactory.class.getClassLoader(), - providerClassName, targetInterface); + connection = getConnectorAsService( + JMXConnectorFactory.class.getClassLoader(), + providerURL, + Collections.unmodifiableMap(envcopy), + systemProvider); + if (connection != null) return connection; } if (provider == null) { @@ -437,13 +448,6 @@ public class JMXConnectorFactory { return instance; } - static Iterator getProviderIterator(final Class providerClass, - final ClassLoader loader) { - ServiceLoader serviceLoader = - ServiceLoader.load(providerClass, loader); - return serviceLoader.iterator(); - } - private static ClassLoader wrap(final ClassLoader parent) { return parent != null ? AccessController.doPrivileged(new PrivilegedAction() { @Override @@ -459,44 +463,265 @@ public class JMXConnectorFactory { }) : null; } + /** + * Checks whether the given provider is our system provider for + * the RMI connector. + * If providers for additional protocols are added in the future + * then the name of their modules may need to be added here. + * System providers will be loaded only if no other provider is found. + * @param provider the provider to test. + * @return true if this provider is a default system provider. + */ + static boolean isSystemProvider(Provider provider) { + Module providerModule = provider.type().getModule(); + return providerModule.isNamed() + && providerModule.getName().equals("java.management.rmi"); + } + + /** + * Creates a JMXConnector from the first JMXConnectorProvider service + * supporting the given url that can be loaded from the given loader. + *

+ * Parses the list of JMXConnectorProvider services that can be loaded + * from the given loader, only retaining those that satisfy the given filter. + * Then for each provider, attempts to create a new JMXConnector. + * The first JMXConnector successfully created is returned. + *

+ * The filter predicate is usually used to either exclude system providers + * or only retain system providers (see isSystemProvider(...) above). + * + * @param loader The ClassLoader to use when looking up an implementation + * of the service. If null, then only installed services will be + * considered. + * + * @param url The JMXServiceURL of the connector for which a provider is + * requested. + * + * @param filter A filter used to exclude or return provider + * implementations. Typically the filter will either exclude + * system services (system default implementations) or only + * retain those. + * This can allow to first look for custom implementations (e.g. + * deployed on the CLASSPATH with META-INF/services) and + * then only default to system implementations. + * + * @throws IOException if no connector could not be instantiated, and + * at least one provider threw an exception that wasn't a + * {@code MalformedURLException} or a {@code JMProviderException}. + * + * @throws JMXProviderException if a provider for the protocol in + * url was found, but couldn't create the connector + * some reason. + * + * @return an instance of JMXConnector if a provider was found from + * which one could be instantiated, {@code null} otherwise. + */ private static JMXConnector getConnectorAsService(ClassLoader loader, JMXServiceURL url, - Map map) + Map map, + Predicate> filter) throws IOException { - Iterator providers = - getProviderIterator(JMXConnectorProvider.class, loader); - JMXConnector connection; - IOException exception = null; - while (providers.hasNext()) { - JMXConnectorProvider provider = providers.next(); - try { - connection = provider.newJMXConnector(url, map); - return connection; - } catch (JMXProviderException e) { - throw e; - } catch (Exception e) { - if (logger.traceOn()) - logger.trace("getConnectorAsService", - "URL[" + url + - "] Service provider exception: " + e); - if (!(e instanceof MalformedURLException)) { - if (exception == null) { - if (e instanceof IOException) { - exception = (IOException) e; - } else { - exception = EnvHelp.initCause( - new IOException(e.getMessage()), e); + final ConnectorFactory factory = + (p) -> p.newJMXConnector(url, map); + return getConnectorAsService(JMXConnectorProvider.class, loader, url, + filter, factory); + } + + + /** + * A factory function that can create a connector from a provider. + * The pair (P,C) will be either one of: + * a. (JMXConnectorProvider, JMXConnector) or + * b. (JMXConnectorServerProvider, JMXConnectorServer) + */ + @FunctionalInterface + static interface ConnectorFactory { + public C apply(P provider) throws Exception; + } + + /** + * An instance of ProviderFinder is used to traverse a + * {@code Stream>} and find the first implementation of P + * that supports creating a connector C from the given JMXServiceURL. + *

+ * The pair (P,C) will be either one of:
+ * a. (JMXConnectorProvider, JMXConnector) or
+ * b. (JMXConnectorServerProvider, JMXConnectorServer) + *

+ * The first connector successfully created while traversing the stream + * is stored in the ProviderFinder instance. After that, the + * ProviderFinder::test method, if called, will always return false, skipping + * the remaining providers. + *

+ * An instance of ProviderFinder is always expected to be used in conjunction + * with Stream::findFirst, so that the stream traversal is stopped as soon + * as a matching provider is found. + *

+ * At the end of the stream traversal, the ProviderFinder::get method can be + * used to obtain the connector instance (an instance of C) that was created. + * If no connector could be created, and an exception was encountered while + * traversing the stream and attempting to create the connector, then that + * exception will be thrown by ProviderFinder::get, wrapped, if needed, + * inside an IOException. + *

+ * If any JMXProviderException is encountered while traversing the stream and + * attempting to create the connector, that exception will be wrapped in an + * UncheckedIOException and thrown immediately within the stream, thus + * interrupting the traversal. + *

+ * If no matching provider was found (no provider found or attempting + * factory.apply always returned null or threw a MalformedURLException, + * indicating the provider didn't support the protocol asked for by + * the JMXServiceURL), then ProviderFinder::get will simply return null. + */ + private static final class ProviderFinder implements Predicate> { + + final ConnectorFactory factory; + final JMXServiceURL url; + private IOException exception = null; + private C connection = null; + + ProviderFinder(ConnectorFactory factory, JMXServiceURL url) { + this.factory = factory; + this.url = url; + } + + /** + * Returns {@code true} for the first provider {@code sp} that can + * be used to obtain an instance of {@code C} from the given + * {@code factory}. + * + * @param sp a candidate provider for instantiating {@code C}. + * + * @throws UncheckedIOException if {@code sp} throws a + * JMXProviderException. The JMXProviderException is set as the + * root cause. + * + * @return {@code true} for the first provider {@code sp} for which + * {@code C} could be instantiated, {@code false} otherwise. + */ + public boolean test(Provider

sp) { + if (connection == null) { + P provider = sp.get(); + try { + connection = factory.apply(provider); + return connection != null; + } catch (JMXProviderException e) { + throw new UncheckedIOException(e); + } catch (Exception e) { + if (logger.traceOn()) + logger.trace("getConnectorAsService", + "URL[" + url + + "] Service provider exception: " + e); + if (!(e instanceof MalformedURLException)) { + if (exception == null) { + if (e instanceof IOException) { + exception = (IOException) e; + } else { + exception = EnvHelp.initCause( + new IOException(e.getMessage()), e); + } } } } - continue; + } + return false; + } + + /** + * Returns an instance of {@code C} if a provider was found from + * which {@code C} could be instantiated. + * + * @throws IOException if {@code C} could not be instantiated, and + * at least one provider threw an exception that wasn't a + * {@code MalformedURLException} or a {@code JMProviderException}. + * + * @return an instance of {@code C} if a provider was found from + * which {@code C} could be instantiated, {@code null} otherwise. + */ + C get() throws IOException { + if (connection != null) return connection; + else if (exception != null) throw exception; + else return null; + } + } + + /** + * Creates a connector from a provider loaded from the ServiceLoader. + *

+ * The pair (P,C) will be either one of:
+ * a. (JMXConnectorProvider, JMXConnector) or
+ * b. (JMXConnectorServerProvider, JMXConnectorServer) + * + * @param providerClass The service type for which an implementation + * should be looked up from the {@code ServiceLoader}. This will + * be either {@code JMXConnectorProvider.class} or + * {@code JMXConnectorServerProvider.class} + * + * @param loader The ClassLoader to use when looking up an implementation + * of the service. If null, then only installed services will be + * considered. + * + * @param url The JMXServiceURL of the connector for which a provider is + * requested. + * + * @param filter A filter used to exclude or return provider + * implementations. Typically the filter will either exclude + * system services (system default implementations) or only + * retain those. + * This can allow to first look for custom implementations (e.g. + * deployed on the CLASSPATH with META-INF/services) and + * then only default to system implementations. + * + * @param factory A functional factory that can attempt to create an + * instance of connector {@code C} from a provider {@code P}. + * Typically, this is a simple wrapper over {@code + * JMXConnectorProvider::newJMXConnector} or {@code + * JMXConnectorProviderServer::newJMXConnectorServer}. + * + * @throws IOException if {@code C} could not be instantiated, and + * at least one provider {@code P} threw an exception that wasn't a + * {@code MalformedURLException} or a {@code JMProviderException}. + * + * @throws JMXProviderException if a provider {@code P} for the protocol in + * url was found, but couldn't create the connector + * {@code C} for some reason. + * + * @return an instance of {@code C} if a provider {@code P} was found from + * which one could be instantiated, {@code null} otherwise. + */ + static C getConnectorAsService(Class

providerClass, + ClassLoader loader, + JMXServiceURL url, + Predicate> filter, + ConnectorFactory factory) + throws IOException { + + // sanity check + if (JMXConnectorProvider.class != providerClass + && JMXConnectorServerProvider.class != providerClass) { + // should never happen + throw new InternalError("Unsupported service interface: " + + providerClass.getName()); + } + + ServiceLoader

serviceLoader = loader == null + ? ServiceLoader.loadInstalled(providerClass) + : ServiceLoader.load(providerClass, loader); + Stream> stream = serviceLoader.stream().filter(filter); + ProviderFinder finder = new ProviderFinder<>(factory, url); + + try { + stream.filter(finder).findFirst(); + return finder.get(); + } catch (UncheckedIOException e) { + if (e.getCause() instanceof JMXProviderException) { + throw (JMXProviderException) e.getCause(); + } else { + throw e; } } - if (exception == null) - return null; - else - throw exception; } static T getProvider(String protocol, diff --git a/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorServerFactory.java b/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorServerFactory.java index 2bfae84c688..4cc54cbcc9c 100644 --- a/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorServerFactory.java +++ b/jdk/src/java.management/share/classes/javax/management/remote/JMXConnectorServerFactory.java @@ -30,13 +30,16 @@ import com.sun.jmx.remote.util.ClassLogger; import com.sun.jmx.remote.util.EnvHelp; import java.io.IOException; +import java.io.UncheckedIOException; import java.net.MalformedURLException; import java.util.Collections; import java.util.HashMap; -import java.util.Iterator; import java.util.Map; +import java.util.ServiceLoader.Provider; +import java.util.function.Predicate; import javax.management.MBeanServer; +import javax.management.remote.JMXConnectorFactory.ConnectorFactory; /** *

Factory to create JMX API connector servers. There @@ -205,43 +208,15 @@ public class JMXConnectorServerFactory { } private static JMXConnectorServer - getConnectorServerAsService(ClassLoader loader, - JMXServiceURL url, - Map map, - MBeanServer mbs) + getConnectorServerAsService(ClassLoader loader, JMXServiceURL url, + Map map, MBeanServer mbs, + Predicate> filter) throws IOException { - Iterator providers = - JMXConnectorFactory. - getProviderIterator(JMXConnectorServerProvider.class, loader); - - IOException exception = null; - while (providers.hasNext()) { - try { - return providers.next().newJMXConnectorServer(url, map, mbs); - } catch (JMXProviderException e) { - throw e; - } catch (Exception e) { - if (logger.traceOn()) - logger.trace("getConnectorAsService", - "URL[" + url + - "] Service provider exception: " + e); - if (!(e instanceof MalformedURLException)) { - if (exception == null) { - if (e instanceof IOException) { - exception = (IOException) e; - } else { - exception = EnvHelp.initCause( - new IOException(e.getMessage()), e); - } - } - } - continue; - } - } - if (exception == null) - return null; - else - throw exception; + final ConnectorFactory + factory = (p) -> p.newJMXConnectorServer(url, map, mbs); + return JMXConnectorFactory.getConnectorAsService( + JMXConnectorServerProvider.class, + loader, url, filter, factory); } /** @@ -309,18 +284,22 @@ public class JMXConnectorServerFactory { loader); IOException exception = null; + JMXConnectorServer connection = null; if (provider == null) { + Predicate> systemProvider = + JMXConnectorFactory::isSystemProvider; // Loader is null when context class loader is set to null // and no loader has been provided in map. // com.sun.jmx.remote.util.Service class extracted from j2se // provider search algorithm doesn't handle well null classloader. if (loader != null) { try { - JMXConnectorServer connection = + connection = getConnectorServerAsService(loader, serviceURL, envcopy, - mbeanServer); + mbeanServer, + systemProvider.negate()); if (connection != null) return connection; } catch (JMXProviderException e) { @@ -329,13 +308,13 @@ public class JMXConnectorServerFactory { exception = e; } } - provider = - JMXConnectorFactory.getProvider( - protocol, - PROTOCOL_PROVIDER_DEFAULT_PACKAGE, - JMXConnectorFactory.class.getClassLoader(), - providerClassName, - targetInterface); + connection = getConnectorServerAsService( + JMXConnectorFactory.class.getClassLoader(), + serviceURL, + Collections.unmodifiableMap(envcopy), + mbeanServer, + systemProvider); + if (connection != null) return connection; } if (provider == null) { diff --git a/jdk/src/java.management/share/classes/module-info.java b/jdk/src/java.management/share/classes/module-info.java index b9c13902773..ef7940a10ab 100644 --- a/jdk/src/java.management/share/classes/module-info.java +++ b/jdk/src/java.management/share/classes/module-info.java @@ -30,8 +30,6 @@ * JVM and other components in the Java runtime. */ module java.management { - requires transitive java.rmi; - requires java.naming; exports java.lang.management; exports javax.management; @@ -41,10 +39,14 @@ module java.management { exports javax.management.openmbean; exports javax.management.relation; exports javax.management.remote; - exports javax.management.remote.rmi; exports javax.management.timer; - exports com.sun.jmx.remote.internal to jdk.management.agent; - exports com.sun.jmx.remote.security to jdk.management.agent; + exports com.sun.jmx.remote.internal to + java.management.rmi, + jdk.management.agent; + exports com.sun.jmx.remote.security to + java.management.rmi, + jdk.management.agent; + exports com.sun.jmx.remote.util to java.management.rmi; exports sun.management to jdk.jconsole, jdk.management, diff --git a/jdk/src/java.rmi/share/classes/module-info.java b/jdk/src/java.rmi/share/classes/module-info.java index 750d8a4b487..7b975859f12 100644 --- a/jdk/src/java.rmi/share/classes/module-info.java +++ b/jdk/src/java.rmi/share/classes/module-info.java @@ -41,13 +41,12 @@ module java.rmi { exports sun.rmi.registry to jdk.management.agent; exports sun.rmi.server to - java.management, + java.management.rmi, jdk.management.agent, jdk.jconsole; exports sun.rmi.transport to - java.management, + java.management.rmi, jdk.management.agent, jdk.jconsole; uses java.rmi.server.RMIClassLoaderSpi; } - diff --git a/jdk/src/java.se/share/classes/module-info.java b/jdk/src/java.se/share/classes/module-info.java index 2756756588a..1e1c0ed6abd 100644 --- a/jdk/src/java.se/share/classes/module-info.java +++ b/jdk/src/java.se/share/classes/module-info.java @@ -36,6 +36,7 @@ module java.se { requires transitive java.instrument; requires transitive java.logging; requires transitive java.management; + requires transitive java.management.rmi; requires transitive java.naming; requires transitive java.prefs; requires transitive java.rmi; @@ -47,4 +48,3 @@ module java.se { requires transitive java.xml; requires transitive java.xml.crypto; } - diff --git a/jdk/src/jdk.jconsole/share/classes/module-info.java b/jdk/src/jdk.jconsole/share/classes/module-info.java index e3a1b348998..6f885b7b42f 100644 --- a/jdk/src/jdk.jconsole/share/classes/module-info.java +++ b/jdk/src/jdk.jconsole/share/classes/module-info.java @@ -26,7 +26,7 @@ module jdk.jconsole { requires transitive java.desktop; requires transitive java.management; - requires java.logging; + requires java.management.rmi; requires java.rmi; requires jdk.attach; requires jdk.jvmstat; @@ -35,4 +35,3 @@ module jdk.jconsole { exports com.sun.tools.jconsole; uses com.sun.tools.jconsole.JConsolePlugin; } - diff --git a/jdk/src/jdk.management.agent/share/classes/module-info.java b/jdk/src/jdk.management.agent/share/classes/module-info.java index 0d19d599c4c..0afeaf0ccd6 100644 --- a/jdk/src/jdk.management.agent/share/classes/module-info.java +++ b/jdk/src/jdk.management.agent/share/classes/module-info.java @@ -25,9 +25,9 @@ module jdk.management.agent { requires java.management; + requires java.management.rmi; exports jdk.internal.agent to jdk.jconsole; uses jdk.internal.agent.spi.AgentProvider; } - diff --git a/jdk/src/jdk.management.agent/share/classes/sun/management/jmxremote/ConnectorBootstrap.java b/jdk/src/jdk.management.agent/share/classes/sun/management/jmxremote/ConnectorBootstrap.java index 0c3e9653124..322b180eab4 100644 --- a/jdk/src/jdk.management.agent/share/classes/sun/management/jmxremote/ConnectorBootstrap.java +++ b/jdk/src/jdk.management.agent/share/classes/sun/management/jmxremote/ConnectorBootstrap.java @@ -73,7 +73,7 @@ import javax.rmi.ssl.SslRMIClientSocketFactory; import javax.rmi.ssl.SslRMIServerSocketFactory; import javax.security.auth.Subject; -import com.sun.jmx.remote.internal.RMIExporter; +import com.sun.jmx.remote.internal.rmi.RMIExporter; import com.sun.jmx.remote.security.JMXPluggableAuthenticator; import jdk.internal.agent.Agent; diff --git a/jdk/test/javax/management/MBeanInfo/NotificationInfoTest.java b/jdk/test/javax/management/MBeanInfo/NotificationInfoTest.java index 0e375aea52a..a0cca183181 100644 --- a/jdk/test/javax/management/MBeanInfo/NotificationInfoTest.java +++ b/jdk/test/javax/management/MBeanInfo/NotificationInfoTest.java @@ -27,7 +27,7 @@ * @summary Test that JMX classes use fully-qualified class names * in MBeanNotificationInfo * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean NotificationInfoTest * @run build NotificationInfoTest * @run main NotificationInfoTest diff --git a/jdk/test/javax/management/MBeanServer/ExceptionTest.java b/jdk/test/javax/management/MBeanServer/ExceptionTest.java index 571e43d3a03..3ea04f7d7ca 100644 --- a/jdk/test/javax/management/MBeanServer/ExceptionTest.java +++ b/jdk/test/javax/management/MBeanServer/ExceptionTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks that exceptions are correctly wired (compared to reference). * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @run main/othervm/timeout=300 -DDEBUG_STANDARD ExceptionTest */ @@ -368,5 +368,3 @@ public class ExceptionTest { } } - - diff --git a/jdk/test/javax/management/MBeanServer/OldMBeanServerTest.java b/jdk/test/javax/management/MBeanServer/OldMBeanServerTest.java index 5f9a8b06174..0080fbe44da 100644 --- a/jdk/test/javax/management/MBeanServer/OldMBeanServerTest.java +++ b/jdk/test/javax/management/MBeanServer/OldMBeanServerTest.java @@ -97,7 +97,7 @@ import javax.management.remote.JMXServiceURL; * @bug 5072268 * @summary Test that nothing assumes a post-1.2 MBeanServer * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run main/othervm -ea OldMBeanServerTest */ diff --git a/jdk/test/javax/management/modelmbean/UnserializableTargetObjectTest.java b/jdk/test/javax/management/modelmbean/UnserializableTargetObjectTest.java index ce93eadf711..fa369cd891b 100644 --- a/jdk/test/javax/management/modelmbean/UnserializableTargetObjectTest.java +++ b/jdk/test/javax/management/modelmbean/UnserializableTargetObjectTest.java @@ -27,7 +27,7 @@ * @summary Test that a RequiredModelMBean operation can have a targetObject * that is not serializable * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean UnserializableTargetObjectTest * @run build UnserializableTargetObjectTest * @run main UnserializableTargetObjectTest diff --git a/jdk/test/javax/management/mxbean/GenericArrayTypeTest.java b/jdk/test/javax/management/mxbean/GenericArrayTypeTest.java index d22a4a1587c..dec6a8a3d36 100644 --- a/jdk/test/javax/management/mxbean/GenericArrayTypeTest.java +++ b/jdk/test/javax/management/mxbean/GenericArrayTypeTest.java @@ -27,7 +27,7 @@ * @summary Test support for arrays in parameterized types. * @author Luis-Miguel Alventosa * @key intermittent - * @modules java.management + * @modules java.management.rmi * @run clean GenericArrayTypeTest * @run build GenericArrayTypeTest * @run main GenericArrayTypeTest diff --git a/jdk/test/javax/management/mxbean/MXBeanExceptionHandlingTest.java b/jdk/test/javax/management/mxbean/MXBeanExceptionHandlingTest.java index 96071980c1e..031b029bf87 100644 --- a/jdk/test/javax/management/mxbean/MXBeanExceptionHandlingTest.java +++ b/jdk/test/javax/management/mxbean/MXBeanExceptionHandlingTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks correct exception and error events from NotificationListener * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile Basic.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD MXBeanExceptionHandlingTest -timeForNotificationInSeconds 3 diff --git a/jdk/test/javax/management/mxbean/MXBeanInteropTest1.java b/jdk/test/javax/management/mxbean/MXBeanInteropTest1.java index 5f0e834a72e..500fef1c2f3 100644 --- a/jdk/test/javax/management/mxbean/MXBeanInteropTest1.java +++ b/jdk/test/javax/management/mxbean/MXBeanInteropTest1.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Test all MXBeans available by default on the platform * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @run main/othervm/timeout=300 -DDEBUG_STANDARD MXBeanInteropTest1 */ diff --git a/jdk/test/javax/management/mxbean/MXBeanInteropTest2.java b/jdk/test/javax/management/mxbean/MXBeanInteropTest2.java index 4c713574100..0ca10d575e2 100644 --- a/jdk/test/javax/management/mxbean/MXBeanInteropTest2.java +++ b/jdk/test/javax/management/mxbean/MXBeanInteropTest2.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks access to test MXBean * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile Basic.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD MXBeanInteropTest2 diff --git a/jdk/test/javax/management/mxbean/MXBeanNotifTest.java b/jdk/test/javax/management/mxbean/MXBeanNotifTest.java index 021731e4fa7..d91fb4fa4d0 100644 --- a/jdk/test/javax/management/mxbean/MXBeanNotifTest.java +++ b/jdk/test/javax/management/mxbean/MXBeanNotifTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks MXBean proper registration both as its implementation class and interface * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile Basic.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD MXBeanNotifTest -numOfNotifications 239 -timeForNotificationInSeconds 4 diff --git a/jdk/test/javax/management/mxbean/MXBeanTest.java b/jdk/test/javax/management/mxbean/MXBeanTest.java index 6123be2365e..a6353083a7f 100644 --- a/jdk/test/javax/management/mxbean/MXBeanTest.java +++ b/jdk/test/javax/management/mxbean/MXBeanTest.java @@ -27,7 +27,7 @@ * @summary General MXBean test. * @author Eamonn McManus * @author Jaroslav Bachorik - * @modules java.management + * @modules java.management.rmi * @run clean MXBeanTest MerlinMXBean TigerMXBean * @run build MXBeanTest MerlinMXBean TigerMXBean * @run main MXBeanTest diff --git a/jdk/test/javax/management/mxbean/MXBeanWeirdParamTest.java b/jdk/test/javax/management/mxbean/MXBeanWeirdParamTest.java index 358233f79a3..6630db062da 100644 --- a/jdk/test/javax/management/mxbean/MXBeanWeirdParamTest.java +++ b/jdk/test/javax/management/mxbean/MXBeanWeirdParamTest.java @@ -27,7 +27,7 @@ * @summary Checks that a serialized instance is not transmitted from an MXBean. * All the communication should be done via Open Types * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile Basic.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD MXBeanWeirdParamTest diff --git a/jdk/test/javax/management/query/SupportedQueryTypesTest.java b/jdk/test/javax/management/query/SupportedQueryTypesTest.java index fab8128a317..8c254329915 100644 --- a/jdk/test/javax/management/query/SupportedQueryTypesTest.java +++ b/jdk/test/javax/management/query/SupportedQueryTypesTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Tests most of the existing query types. * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @compile TestQuery.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD SupportedQueryTypesTest -mbeanClassName TestQuery */ diff --git a/jdk/test/javax/management/remote/mandatory/connection/AddressableTest.java b/jdk/test/javax/management/remote/mandatory/connection/AddressableTest.java index 32639ce9e0d..eb8897e4019 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/AddressableTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/AddressableTest.java @@ -26,7 +26,7 @@ * @bug 6238815 * @summary test the new interface Addressable * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean AddressableTest * @run build AddressableTest * @run main AddressableTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/BrokenConnectionTest.java b/jdk/test/javax/management/remote/mandatory/connection/BrokenConnectionTest.java index 869c5ed8343..590c7263967 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/BrokenConnectionTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/BrokenConnectionTest.java @@ -27,7 +27,7 @@ * @summary Tests behaviour when connections break * @author Eamonn McManus * @key intermittent - * @modules java.management + * @modules java.management.rmi * @run clean BrokenConnectionTest * @run build BrokenConnectionTest * @run main BrokenConnectionTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/CloseableTest.java b/jdk/test/javax/management/remote/mandatory/connection/CloseableTest.java index ca6bb6e64e8..791cd89d9b3 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/CloseableTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/CloseableTest.java @@ -28,7 +28,7 @@ * the method "void close() throws IOException;" extend * or implement the java.io.Closeable interface. * @author Luis-Miguel Alventosa - * @modules java.management + * @modules java.management.rmi * @run clean CloseableTest * @run build CloseableTest * @run main CloseableTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/ConnectionListenerNullTest.java b/jdk/test/javax/management/remote/mandatory/connection/ConnectionListenerNullTest.java index d819d0008eb..cbe216526c5 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/ConnectionListenerNullTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/ConnectionListenerNullTest.java @@ -26,7 +26,7 @@ * @bug 4943248 * @summary Tests that NullPointerException is thrown when listener is null. * @author Daniel Fuchs - * @modules java.management + * @modules java.management.rmi * @run clean ConnectionListenerNullTest * @run build ConnectionListenerNullTest * @run main ConnectionListenerNullTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/ConnectionTest.java b/jdk/test/javax/management/remote/mandatory/connection/ConnectionTest.java index 13a84a8349b..c16412d843b 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/ConnectionTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/ConnectionTest.java @@ -26,7 +26,7 @@ * @bug 4865397 * @summary Tests remote JMX connections * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean ConnectionTest * @run build ConnectionTest * @run main ConnectionTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/DaemonRMIExporterTest.java b/jdk/test/javax/management/remote/mandatory/connection/DaemonRMIExporterTest.java index 42bb5e6d50d..de0184ca3a2 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/DaemonRMIExporterTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/DaemonRMIExporterTest.java @@ -28,7 +28,7 @@ * @summary test the connector server option that causes it not to prevent the * VM from exiting * @author Shanliang JIANG, Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run main/othervm DaemonRMIExporterTest */ import java.util.Arrays; diff --git a/jdk/test/javax/management/remote/mandatory/connection/GetConnectionTest.java b/jdk/test/javax/management/remote/mandatory/connection/GetConnectionTest.java index 7b978db7aad..7c3bf66fe52 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/GetConnectionTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/GetConnectionTest.java @@ -26,7 +26,7 @@ * @bug 4951414 * @summary Try to get an IOException. * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean GetConnectionTest * @run build GetConnectionTest * @run main GetConnectionTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/IIOPURLTest.java b/jdk/test/javax/management/remote/mandatory/connection/IIOPURLTest.java index 1f177c915f4..49aa0e426f0 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/IIOPURLTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/IIOPURLTest.java @@ -26,7 +26,7 @@ * @bug 4886799 * @summary Check that IIOP URLs have /ior/ in the path * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean IIOPURLTest * @run build IIOPURLTest * @run main IIOPURLTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/IdleTimeoutTest.java b/jdk/test/javax/management/remote/mandatory/connection/IdleTimeoutTest.java index 08d68896bde..f0e6504c27a 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/IdleTimeoutTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/IdleTimeoutTest.java @@ -26,7 +26,8 @@ * @bug 4886838 4886830 8025204 * @summary Tests that idle timeouts happen at appropriate times * @author Eamonn McManus - * @modules java.management/com.sun.jmx.remote.util + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.util * @run clean IdleTimeoutTest * @run build IdleTimeoutTest * @run main IdleTimeoutTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/MultiThreadDeadLockTest.java b/jdk/test/javax/management/remote/mandatory/connection/MultiThreadDeadLockTest.java index f3ee55b95bd..63542a464bf 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/MultiThreadDeadLockTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/MultiThreadDeadLockTest.java @@ -45,7 +45,7 @@ import javax.management.remote.rmi.RMIConnectorServer; * @bug 6697180 * @summary test on a client notification deadlock. * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean MultiThreadDeadLockTest * @run build MultiThreadDeadLockTest * @run main MultiThreadDeadLockTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/ObjectInputStreamWithLoaderNullCheckTest.java b/jdk/test/javax/management/remote/mandatory/connection/ObjectInputStreamWithLoaderNullCheckTest.java index acf21cb2793..afb99ceb0b3 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/ObjectInputStreamWithLoaderNullCheckTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/ObjectInputStreamWithLoaderNullCheckTest.java @@ -29,7 +29,7 @@ * thrown when constructor is invoked with null class loader as * an argument. * @author Amit Sapre - * @modules java.management/javax.management.remote.rmi:open + * @modules java.management.rmi/javax.management.remote.rmi:open * @run clean ObjectInputStreamWithLoaderNullCheckTest * @run build ObjectInputStreamWithLoaderNullCheckTest * @run main ObjectInputStreamWithLoaderNullCheckTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorInternalMapTest.java b/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorInternalMapTest.java index a6063f1d306..b797563017d 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorInternalMapTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorInternalMapTest.java @@ -42,7 +42,7 @@ import javax.security.auth.Subject; * @bug 6566891 * @summary Check no memory leak on RMIConnector's rmbscMap * @author Shanliang JIANG - * @modules java.management/javax.management.remote.rmi:open + * @modules java.management.rmi/javax.management.remote.rmi:open * @run clean RMIConnectorInternalMapTest * @run build RMIConnectorInternalMapTest * @run main RMIConnectorInternalMapTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorNullSubjectConnTest.java b/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorNullSubjectConnTest.java index 5b616a7eb98..de60f5ea875 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorNullSubjectConnTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/RMIConnectorNullSubjectConnTest.java @@ -38,7 +38,7 @@ import javax.management.remote.rmi.RMIConnector; * @bug 6566891 * @summary Check no memory leak on RMIConnector's nullSubjectConn * @author Shanliang JIANG - * @modules java.management/javax.management.remote.rmi:open + * @modules java.management.rmi/javax.management.remote.rmi:open * @run clean RMIConnectorNullSubjectConnTest * @run build RMIConnectorNullSubjectConnTest * @run main RMIConnectorNullSubjectConnTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/RMIConnector_NPETest.java b/jdk/test/javax/management/remote/mandatory/connection/RMIConnector_NPETest.java index 732f8998184..29a91a464c7 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/RMIConnector_NPETest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/RMIConnector_NPETest.java @@ -26,7 +26,7 @@ * @summary NPE IN RMIConnector.connect * @bug 6984520 * @library /java/rmi/testlibrary - * @modules java.management + * @modules java.management.rmi * java.rmi/sun.rmi.registry * java.rmi/sun.rmi.server * java.rmi/sun.rmi.transport @@ -75,4 +75,3 @@ public class RMIConnector_NPETest { } } - diff --git a/jdk/test/javax/management/remote/mandatory/connection/RMIExitTest.java b/jdk/test/javax/management/remote/mandatory/connection/RMIExitTest.java index cfa64ab7768..df81b362187 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/RMIExitTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/RMIExitTest.java @@ -27,7 +27,7 @@ * @bug 4917237 * @summary test that process exit immediately after stop() / close() called * @author Jean Francois Denise - * @modules java.management + * @modules java.management.rmi * @run clean RMIExitTest * @run build RMIExitTest * @run main RMIExitTest diff --git a/jdk/test/javax/management/remote/mandatory/connection/RMISerializeTest.java b/jdk/test/javax/management/remote/mandatory/connection/RMISerializeTest.java index 7b90441d8b2..ac5331d9fae 100644 --- a/jdk/test/javax/management/remote/mandatory/connection/RMISerializeTest.java +++ b/jdk/test/javax/management/remote/mandatory/connection/RMISerializeTest.java @@ -26,7 +26,7 @@ * @summary Tests to serialize RMIConnector * @bug 5032052 * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean RMISerializeTest * @run build RMISerializeTest * @run main RMISerializeTest diff --git a/jdk/test/javax/management/remote/mandatory/connectorServer/ConnectorStopDeadlockTest.java b/jdk/test/javax/management/remote/mandatory/connectorServer/ConnectorStopDeadlockTest.java index 35ce6db28bd..ad84f39142a 100644 --- a/jdk/test/javax/management/remote/mandatory/connectorServer/ConnectorStopDeadlockTest.java +++ b/jdk/test/javax/management/remote/mandatory/connectorServer/ConnectorStopDeadlockTest.java @@ -26,7 +26,7 @@ * @bug 6475157 * @summary Tests deadlock in simultaneous connection and connector-server close * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi */ /* This test is somewhat dependent on implementation details. If it suddenly diff --git a/jdk/test/javax/management/remote/mandatory/connectorServer/JNDIFailureTest.java b/jdk/test/javax/management/remote/mandatory/connectorServer/JNDIFailureTest.java index 8607d0266ba..d102ecbd01d 100644 --- a/jdk/test/javax/management/remote/mandatory/connectorServer/JNDIFailureTest.java +++ b/jdk/test/javax/management/remote/mandatory/connectorServer/JNDIFailureTest.java @@ -27,7 +27,7 @@ * @summary Tests that JNDI bind failure doesn't leave an orphan RMI * Connector Server object * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean JNDIFailureTest * @run build JNDIFailureTest * @run main JNDIFailureTest diff --git a/jdk/test/javax/management/remote/mandatory/connectorServer/MBSFPreStartPostStartTest.java b/jdk/test/javax/management/remote/mandatory/connectorServer/MBSFPreStartPostStartTest.java index c6a0e793d56..1d0355edce3 100644 --- a/jdk/test/javax/management/remote/mandatory/connectorServer/MBSFPreStartPostStartTest.java +++ b/jdk/test/javax/management/remote/mandatory/connectorServer/MBSFPreStartPostStartTest.java @@ -27,7 +27,7 @@ * @summary Test that setting an MBeanServerForwarder on an already * started RMI connector server has the expected behavior. * @author Luis-Miguel Alventosa - * @modules java.management + * @modules java.management.rmi * @run clean MBSFPreStartPostStartTest * @run build MBSFPreStartPostStartTest * @run main MBSFPreStartPostStartTest diff --git a/jdk/test/javax/management/remote/mandatory/connectorServer/RMIExporterTest.java b/jdk/test/javax/management/remote/mandatory/connectorServer/RMIExporterTest.java index 2d305cd4886..3b010e38a13 100644 --- a/jdk/test/javax/management/remote/mandatory/connectorServer/RMIExporterTest.java +++ b/jdk/test/javax/management/remote/mandatory/connectorServer/RMIExporterTest.java @@ -26,7 +26,7 @@ * @bug 5016705 * @summary Tests the use of the RMIExporter class. * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.internal + * @modules java.management.rmi/com.sun.jmx.remote.internal.rmi * @run clean RMIExporterTest * @run build RMIExporterTest * @run main RMIExporterTest @@ -46,7 +46,7 @@ import javax.management.remote.JMXConnectorFactory; import javax.management.remote.JMXConnectorServer; import javax.management.remote.JMXConnectorServerFactory; import javax.management.remote.JMXServiceURL; -import com.sun.jmx.remote.internal.RMIExporter; +import com.sun.jmx.remote.internal.rmi.RMIExporter; public class RMIExporterTest { diff --git a/jdk/test/javax/management/remote/mandatory/connectorServer/SetMBeanServerForwarder.java b/jdk/test/javax/management/remote/mandatory/connectorServer/SetMBeanServerForwarder.java index 4fa67da40ec..22bd8741aea 100644 --- a/jdk/test/javax/management/remote/mandatory/connectorServer/SetMBeanServerForwarder.java +++ b/jdk/test/javax/management/remote/mandatory/connectorServer/SetMBeanServerForwarder.java @@ -27,7 +27,8 @@ * @summary Tests that IllegalArgumentException is thrown when * MBeanServerForwrder is null. * @author Daniel Fuchs - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean SetMBeanServerForwarder * @run build SetMBeanServerForwarder * @run main SetMBeanServerForwarder diff --git a/jdk/test/javax/management/remote/mandatory/loading/DeserializeEncodedURLTest.java b/jdk/test/javax/management/remote/mandatory/loading/DeserializeEncodedURLTest.java index 10a929f73f4..2cb8d8742e1 100644 --- a/jdk/test/javax/management/remote/mandatory/loading/DeserializeEncodedURLTest.java +++ b/jdk/test/javax/management/remote/mandatory/loading/DeserializeEncodedURLTest.java @@ -26,7 +26,7 @@ * @bug 4924683 * @summary Check RMI/JRMP stubs can be deserialized using user's loader * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean DeserializeEncodedURLTest SingleClassLoader * @run build DeserializeEncodedURLTest SingleClassLoader * @run main DeserializeEncodedURLTest diff --git a/jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java b/jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java index 644b8dacf0e..7c93e0c3563 100644 --- a/jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java +++ b/jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java @@ -26,7 +26,7 @@ * @bug 4915825 4921009 4934965 4977469 8019584 * @summary Tests behavior when client or server gets object of unknown class * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean MissingClassTest SingleClassLoader * @run build MissingClassTest SingleClassLoader * @run main MissingClassTest diff --git a/jdk/test/javax/management/remote/mandatory/loading/RMIDownloadTest.java b/jdk/test/javax/management/remote/mandatory/loading/RMIDownloadTest.java index fdb8e8c86a8..ebdf181cdf5 100644 --- a/jdk/test/javax/management/remote/mandatory/loading/RMIDownloadTest.java +++ b/jdk/test/javax/management/remote/mandatory/loading/RMIDownloadTest.java @@ -26,7 +26,7 @@ * @bug 5021246 * @summary Check that class downloading is supported by RMI connector * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run main RMIDownloadTest receive without * @run main RMIDownloadTest send without * @run main RMIDownloadTest receive with diff --git a/jdk/test/javax/management/remote/mandatory/loading/TargetMBeanTest.java b/jdk/test/javax/management/remote/mandatory/loading/TargetMBeanTest.java index f6422ee817f..a5df3856ec8 100644 --- a/jdk/test/javax/management/remote/mandatory/loading/TargetMBeanTest.java +++ b/jdk/test/javax/management/remote/mandatory/loading/TargetMBeanTest.java @@ -26,7 +26,7 @@ * @bug 4910428 * @summary Tests target MBean class loader used before JSR 160 loader * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * @run clean TargetMBeanTest * @run build TargetMBeanTest * @run main TargetMBeanTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/ConcurrentModificationTest.java b/jdk/test/javax/management/remote/mandatory/notif/ConcurrentModificationTest.java index 3958d2bfa13..a7830faf921 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/ConcurrentModificationTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/ConcurrentModificationTest.java @@ -26,7 +26,7 @@ * @bug 7120365 * @summary test on Concurrent Modification * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run main ConcurrentModificationTest */ diff --git a/jdk/test/javax/management/remote/mandatory/notif/DeadListenerTest.java b/jdk/test/javax/management/remote/mandatory/notif/DeadListenerTest.java index b202163e3eb..11942eace3a 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/DeadListenerTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/DeadListenerTest.java @@ -25,7 +25,7 @@ * @test * @bug 6957378 * @summary Test that a listener can be removed remotely from an MBean that no longer exists. - * @modules java.management/javax.management.remote.rmi:open + * @modules java.management.rmi/javax.management.remote.rmi:open * java.management/com.sun.jmx.remote.internal:+open * @author Eamonn McManus * @run main/othervm -XX:+UsePerfData DeadListenerTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/EmptyDomainNotificationTest.java b/jdk/test/javax/management/remote/mandatory/notif/EmptyDomainNotificationTest.java index 7301c4faa0b..5041a6bbd69 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/EmptyDomainNotificationTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/EmptyDomainNotificationTest.java @@ -27,7 +27,7 @@ * @summary Check that the expected notification is received by the JMX * client even when the domain in the ObjectName is not specified * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean EmptyDomainNotificationTest * @run build EmptyDomainNotificationTest * @run main EmptyDomainNotificationTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/ListenerScaleTest.java b/jdk/test/javax/management/remote/mandatory/notif/ListenerScaleTest.java index 0d7080e6b7d..bc6922f350d 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/ListenerScaleTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/ListenerScaleTest.java @@ -26,7 +26,7 @@ * @bug 6338874 * @summary Check that notification dispatch is not linear in number of MBeans. * @author Eamonn McManus - * @modules java.management + * @modules java.management.rmi * * @library /lib/testlibrary * @run build jdk.testlibrary.* ListenerScaleTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/NotSerializableNotifTest.java b/jdk/test/javax/management/remote/mandatory/notif/NotSerializableNotifTest.java index c0365eb241f..8bd7aea59e8 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/NotSerializableNotifTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/NotSerializableNotifTest.java @@ -26,7 +26,7 @@ * @summary Tests to send a not serializable notification. * @bug 5022196 8132003 * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean NotSerializableNotifTest * @run build NotSerializableNotifTest * @run main NotSerializableNotifTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/NotifReconnectDeadlockTest.java b/jdk/test/javax/management/remote/mandatory/notif/NotifReconnectDeadlockTest.java index fa8986340a0..74b2ee582ed 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/NotifReconnectDeadlockTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/NotifReconnectDeadlockTest.java @@ -26,7 +26,7 @@ * @bug 6199899 * @summary Tests reconnection done by a fetching notif thread. * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean NotifReconnectDeadlockTest * @run build NotifReconnectDeadlockTest * @run main NotifReconnectDeadlockTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/NotificationAccessControllerTest.java b/jdk/test/javax/management/remote/mandatory/notif/NotificationAccessControllerTest.java index 2a77ccb63a2..99e5460325c 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/NotificationAccessControllerTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/NotificationAccessControllerTest.java @@ -26,7 +26,8 @@ * @bug 5106721 * @summary Check the NotificationAccessController methods are properly called. * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean NotificationAccessControllerTest * @run build NotificationAccessControllerTest * @run main NotificationAccessControllerTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/NotificationBufferCreationTest.java b/jdk/test/javax/management/remote/mandatory/notif/NotificationBufferCreationTest.java index 85a06afb956..030d9c2d1a0 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/NotificationBufferCreationTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/NotificationBufferCreationTest.java @@ -26,7 +26,7 @@ * @bug 4934236 * @summary Tests that NotificationBuffer is created when used. * @author jfd@... - * @modules java.management + * @modules java.management.rmi * @run clean NotificationBufferCreationTest NotificationSender * @run build NotificationBufferCreationTest * @run main NotificationBufferCreationTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/NotificationEmissionTest.java b/jdk/test/javax/management/remote/mandatory/notif/NotificationEmissionTest.java index 7edc956cb93..bdacde2ff4e 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/NotificationEmissionTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/NotificationEmissionTest.java @@ -28,7 +28,7 @@ * installed. Test the property "jmx.remote.x.check.notification.emission". * @author Luis-Miguel Alventosa * @key intermittent - * @modules java.management + * @modules java.management.rmi * @run clean NotificationEmissionTest * @run build NotificationEmissionTest * @run main NotificationEmissionTest 1 diff --git a/jdk/test/javax/management/remote/mandatory/notif/RMINotifTest.java b/jdk/test/javax/management/remote/mandatory/notif/RMINotifTest.java index 092eb6413ea..6531b4414a5 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/RMINotifTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/RMINotifTest.java @@ -27,7 +27,7 @@ * @summary Tests to receive notifications for opened and closed connections ions * @author sjiang - * @modules java.management + * @modules java.management.rmi * @run clean RMINotifTest * @run build RMINotifTest * @run main RMINotifTest diff --git a/jdk/test/javax/management/remote/mandatory/notif/ServerNotifs.java b/jdk/test/javax/management/remote/mandatory/notif/ServerNotifs.java index 773ddfd1cc5..036ef7f1682 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/ServerNotifs.java +++ b/jdk/test/javax/management/remote/mandatory/notif/ServerNotifs.java @@ -27,7 +27,7 @@ * @summary Tests the reception of the notifications for opened and closed * connections * @author sjiang - * @modules java.management + * @modules java.management.rmi * @run clean ServerNotifs * @run build ServerNotifs * @run main ServerNotifs diff --git a/jdk/test/javax/management/remote/mandatory/notif/UnexpectedNotifTest.java b/jdk/test/javax/management/remote/mandatory/notif/UnexpectedNotifTest.java index 9623773ea59..39a7f444157 100644 --- a/jdk/test/javax/management/remote/mandatory/notif/UnexpectedNotifTest.java +++ b/jdk/test/javax/management/remote/mandatory/notif/UnexpectedNotifTest.java @@ -27,7 +27,7 @@ * @summary Tests whether a listener receives notifs emitted before the * listener is registered. * @author Shanliang JIANG - * @modules java.management + * @modules java.management.rmi * @run clean UnexpectedNotifTest * @run build UnexpectedNotifTest * @run main UnexpectedNotifTest diff --git a/jdk/test/javax/management/remote/mandatory/passwordAccessFile/NonJMXPrincipalsTest.java b/jdk/test/javax/management/remote/mandatory/passwordAccessFile/NonJMXPrincipalsTest.java index b94c6663d32..b178b04b632 100644 --- a/jdk/test/javax/management/remote/mandatory/passwordAccessFile/NonJMXPrincipalsTest.java +++ b/jdk/test/javax/management/remote/mandatory/passwordAccessFile/NonJMXPrincipalsTest.java @@ -27,7 +27,7 @@ * @summary Tests that MBeanServerFileAccessController supports * principals other than JMXPrincipal. * @author Luis-Miguel Alventosa - * @modules java.management + * @modules java.management.rmi * @run clean NonJMXPrincipalsTest SimpleStandard SimpleStandardMBean * @run build NonJMXPrincipalsTest SimpleStandard SimpleStandardMBean * @run main NonJMXPrincipalsTest diff --git a/jdk/test/javax/management/remote/mandatory/passwordAccessFile/PasswordAccessFileTest.java b/jdk/test/javax/management/remote/mandatory/passwordAccessFile/PasswordAccessFileTest.java index 057e3640767..43e17772d5f 100644 --- a/jdk/test/javax/management/remote/mandatory/passwordAccessFile/PasswordAccessFileTest.java +++ b/jdk/test/javax/management/remote/mandatory/passwordAccessFile/PasswordAccessFileTest.java @@ -27,7 +27,7 @@ * @summary Tests the use of the "jmx.remote.x.password.file" and * "jmx.remote.x.access.file" environment map properties. * @author Luis-Miguel Alventosa - * @modules java.management + * @modules java.management.rmi * @run clean PasswordAccessFileTest SimpleStandard SimpleStandardMBean * @run build PasswordAccessFileTest SimpleStandard SimpleStandardMBean * @run main PasswordAccessFileTest diff --git a/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIAltAuthTest.java b/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIAltAuthTest.java index f5c4fd13571..befe03cbab3 100644 --- a/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIAltAuthTest.java +++ b/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIAltAuthTest.java @@ -26,7 +26,8 @@ * @bug 5016508 * @summary Supplies an alternative JAAS configuration for authenticating RMI clients * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean RMIAltAuthTest * @run build RMIAltAuthTest SimpleStandard SimpleStandardMBean * @run main RMIAltAuthTest diff --git a/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIPasswdAuthTest.java b/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIPasswdAuthTest.java index 0a383622561..f5277b231e5 100644 --- a/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIPasswdAuthTest.java +++ b/jdk/test/javax/management/remote/mandatory/passwordAuthenticator/RMIPasswdAuthTest.java @@ -26,7 +26,8 @@ * @bug 5016508 * @summary Tests the default JAAS configuration for authenticating RMI clients * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean RMIPasswdAuthTest * @run build RMIPasswdAuthTest SimpleStandard SimpleStandardMBean * @run main RMIPasswdAuthTest diff --git a/jdk/test/javax/management/remote/mandatory/provider/ProviderTest.java b/jdk/test/javax/management/remote/mandatory/provider/ProviderTest.java index 87e15fae068..8491f24caa1 100644 --- a/jdk/test/javax/management/remote/mandatory/provider/ProviderTest.java +++ b/jdk/test/javax/management/remote/mandatory/provider/ProviderTest.java @@ -24,7 +24,7 @@ /* * @test ProviderTest.java * @summary Tests jar services provider are called - * @modules java.management + * @modules java.management.rmi * @run clean ProviderTest provider.JMXConnectorProviderImpl provider.JMXConnectorServerProviderImpl * @run build ProviderTest provider.JMXConnectorProviderImpl provider.JMXConnectorServerProviderImpl * @run main ProviderTest diff --git a/jdk/test/javax/management/remote/mandatory/serverError/JMXServerErrorTest.java b/jdk/test/javax/management/remote/mandatory/serverError/JMXServerErrorTest.java index 33d471b7326..b37c3e20a8c 100644 --- a/jdk/test/javax/management/remote/mandatory/serverError/JMXServerErrorTest.java +++ b/jdk/test/javax/management/remote/mandatory/serverError/JMXServerErrorTest.java @@ -26,7 +26,8 @@ * @bug 4871761 * @summary Tests that JMXServiceErrorException is correctly emitted. * @author Daniel Fuchs - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean JMXServerErrorTest * @run build JMXServerErrorTest * @run main JMXServerErrorTest diff --git a/jdk/test/javax/management/remote/mandatory/socketFactories/RMISocketFactoriesTest.java b/jdk/test/javax/management/remote/mandatory/socketFactories/RMISocketFactoriesTest.java index 30e550a1dfb..c8aa8bdf269 100644 --- a/jdk/test/javax/management/remote/mandatory/socketFactories/RMISocketFactoriesTest.java +++ b/jdk/test/javax/management/remote/mandatory/socketFactories/RMISocketFactoriesTest.java @@ -26,7 +26,7 @@ * @bug 7654321 * @summary Tests the use of the custom RMI socket factories. * @author Luis-Miguel Alventosa - * @modules java.management + * @modules java.management.rmi * @run clean RMISocketFactoriesTest * @run build RMISocketFactoriesTest RMIClientFactory RMIServerFactory * @run main RMISocketFactoriesTest test_server_factory diff --git a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation1Test.java b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation1Test.java index 1e996a724fc..9b1d0323444 100644 --- a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation1Test.java +++ b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation1Test.java @@ -27,7 +27,8 @@ * @summary Tests the use of the subject delegation feature in the * RMI connector * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean SubjectDelegation1Test SimpleStandard SimpleStandardMBean * @run build SubjectDelegation1Test SimpleStandard SimpleStandardMBean * @run main SubjectDelegation1Test policy11 ok diff --git a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation2Test.java b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation2Test.java index 20399d12fc2..c5553029d6f 100644 --- a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation2Test.java +++ b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation2Test.java @@ -27,7 +27,8 @@ * @summary Tests the use of the subject delegation feature on the authenticated * principals within the RMI connector server's creator codebase. * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean SubjectDelegation2Test SimpleStandard SimpleStandardMBean * @run build SubjectDelegation2Test SimpleStandard SimpleStandardMBean * @run main SubjectDelegation2Test policy21 ok diff --git a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation3Test.java b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation3Test.java index 3dc0928e3ce..27479d1c6db 100644 --- a/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation3Test.java +++ b/jdk/test/javax/management/remote/mandatory/subjectDelegation/SubjectDelegation3Test.java @@ -28,7 +28,8 @@ * principals within the RMI connector server's creator codebase with * subject delegation. * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.security + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.security * @run clean SubjectDelegation3Test SimpleStandard SimpleStandardMBean * @run build SubjectDelegation3Test SimpleStandard SimpleStandardMBean * @run main SubjectDelegation3Test policy31 ok diff --git a/jdk/test/javax/management/remote/mandatory/util/MapNullValuesTest.java b/jdk/test/javax/management/remote/mandatory/util/MapNullValuesTest.java index 6990f0c4aa0..c5173eb167c 100644 --- a/jdk/test/javax/management/remote/mandatory/util/MapNullValuesTest.java +++ b/jdk/test/javax/management/remote/mandatory/util/MapNullValuesTest.java @@ -31,7 +31,8 @@ * Check also that null values for keys are not allowed in * the maps passed to the JMXConnector[Server] factories. * @author Luis-Miguel Alventosa - * @modules java.management/com.sun.jmx.remote.util + * @modules java.management.rmi + * java.management/com.sun.jmx.remote.util * @run clean MapNullValuesTest * @run build MapNullValuesTest * @run main MapNullValuesTest diff --git a/jdk/test/javax/management/security/AuthorizationTest.java b/jdk/test/javax/management/security/AuthorizationTest.java index 54309ab059b..e511ab0b454 100644 --- a/jdk/test/javax/management/security/AuthorizationTest.java +++ b/jdk/test/javax/management/security/AuthorizationTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks various authentication behavior from remote jmx client * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile Simple.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD -Dusername=username1 -Dpassword=password1 AuthorizationTest -server -mapType x.access.file;x.password.file -populate -client -mapType credentials diff --git a/jdk/test/javax/management/security/SecurityTest.java b/jdk/test/javax/management/security/SecurityTest.java index 6d245bd6ab4..c9756d2896a 100644 --- a/jdk/test/javax/management/security/SecurityTest.java +++ b/jdk/test/javax/management/security/SecurityTest.java @@ -26,7 +26,7 @@ * @bug 8058865 * @summary Checks various secure ways of connecting from remote jmx client * @author Olivier Lagneau - * @modules java.management + * @modules java.management.rmi * @library /lib/testlibrary * @compile MBS_Light.java ServerDelegate.java TestSampleLoginModule.java * @run main/othervm/timeout=300 -DDEBUG_STANDARD -Dusername=SQE_username -Dpassword=SQE_password SecurityTest -server -mapType x.password.file -client -mapType credentials diff --git a/jdk/test/sun/management/jmxremote/bootstrap/TestManager.java b/jdk/test/sun/management/jmxremote/bootstrap/TestManager.java index 2d02d4c8423..85dc548dd11 100644 --- a/jdk/test/sun/management/jmxremote/bootstrap/TestManager.java +++ b/jdk/test/sun/management/jmxremote/bootstrap/TestManager.java @@ -57,7 +57,7 @@ public class TestManager { try { VirtualMachine.attach(pid).startLocalManagementAgent(); } catch (Exception x) { - throw new IOException(x.getMessage()); + throw new IOException(x.getMessage(), x); } } diff --git a/jdk/test/tools/launcher/modules/listmods/ListModsTest.java b/jdk/test/tools/launcher/modules/listmods/ListModsTest.java index b386f402c47..7b1dd9340e7 100644 --- a/jdk/test/tools/launcher/modules/listmods/ListModsTest.java +++ b/jdk/test/tools/launcher/modules/listmods/ListModsTest.java @@ -147,7 +147,7 @@ public class ListModsTest { @Test public void testListWithLimitMods1() throws Exception { OutputAnalyzer output - = executeTestJava("--limit-modules", "java.management", "--list-modules") + = executeTestJava("--limit-modules", "java.management.rmi", "--list-modules") .outputTo(System.out) .errorTo(System.out); output.shouldContain("java.rmi");