mirror of
https://github.com/openjdk/jdk.git
synced 2026-02-19 14:55:17 +00:00
8344966: Remove the allowNonPublic MBean compatibility property
Reviewed-by: amenkov, sspitsyn, dfuchs
This commit is contained in:
parent
6032f6ea04
commit
c882160d03
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2025, 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
|
||||
@ -64,7 +64,6 @@ import sun.reflect.misc.MethodUtil;
|
||||
* @since 1.5
|
||||
*/
|
||||
public class Introspector {
|
||||
public static final boolean ALLOW_NONPUBLIC_MBEAN = Boolean.parseBoolean(System.getProperty("jdk.jmx.mbeans.allowNonPublic"));
|
||||
|
||||
/*
|
||||
* ------------------------------------------
|
||||
@ -517,8 +516,7 @@ public class Introspector {
|
||||
Class<?>[] interfaces = c.getInterfaces();
|
||||
for (int i = 0;i < interfaces.length; i++) {
|
||||
if (interfaces[i].getName().equals(clMBeanName) &&
|
||||
(Modifier.isPublic(interfaces[i].getModifiers()) ||
|
||||
ALLOW_NONPUBLIC_MBEAN)) {
|
||||
Modifier.isPublic(interfaces[i].getModifiers())) {
|
||||
return Util.cast(interfaces[i]);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 2025, 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
|
||||
@ -107,8 +107,7 @@ class MBeanAnalyzer<M> {
|
||||
if (!mbeanType.isInterface()) {
|
||||
throw new NotCompliantMBeanException("Not an interface: " +
|
||||
mbeanType.getName());
|
||||
} else if (!Modifier.isPublic(mbeanType.getModifiers()) &&
|
||||
!Introspector.ALLOW_NONPUBLIC_MBEAN) {
|
||||
} else if (!Modifier.isPublic(mbeanType.getModifiers())) {
|
||||
throw new NotCompliantMBeanException("Interface is not public: " +
|
||||
mbeanType.getName());
|
||||
}
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 2025, 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
|
||||
@ -375,8 +375,7 @@ public class JMX {
|
||||
public static boolean isMXBeanInterface(Class<?> interfaceClass) {
|
||||
if (!interfaceClass.isInterface())
|
||||
return false;
|
||||
if (!Modifier.isPublic(interfaceClass.getModifiers()) &&
|
||||
!Introspector.ALLOW_NONPUBLIC_MBEAN) {
|
||||
if (!Modifier.isPublic(interfaceClass.getModifiers())) {
|
||||
return false;
|
||||
}
|
||||
MXBean a = interfaceClass.getAnnotation(MXBean.class);
|
||||
|
||||
@ -1,94 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
import javax.management.MBeanServer;
|
||||
import javax.management.MBeanServerFactory;
|
||||
import javax.management.NotCompliantMBeanException;
|
||||
import javax.management.ObjectName;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8010285
|
||||
* @summary Test fallback for private MBean interfaces.
|
||||
* It needs to be a separate class because the "jdk.jmx.mbeans.allowNonPublic"
|
||||
* system property must be set before c.s.j.m.MBeanAnalyzer has been loaded.
|
||||
* @author Jaroslav Bachorik
|
||||
*
|
||||
* @run clean MBeanFallbackTest
|
||||
* @run build MBeanFallbackTest
|
||||
* @run main/othervm -Djdk.jmx.mbeans.allowNonPublic=true MBeanFallbackTest
|
||||
*/
|
||||
public class MBeanFallbackTest {
|
||||
private static interface PrivateMBean {
|
||||
public int[] getInts();
|
||||
}
|
||||
|
||||
public static class Private implements PrivateMBean {
|
||||
public int[] getInts() {
|
||||
return new int[]{1,2,3};
|
||||
}
|
||||
}
|
||||
|
||||
private static int failures = 0;
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
testPrivate(PrivateMBean.class, new Private());
|
||||
|
||||
if (failures == 0)
|
||||
System.out.println("Test passed");
|
||||
else
|
||||
throw new Exception("TEST FAILURES: " + failures);
|
||||
}
|
||||
|
||||
private static void fail(String msg) {
|
||||
failures++;
|
||||
System.out.println("FAIL: " + msg);
|
||||
}
|
||||
|
||||
private static void success(String msg) {
|
||||
System.out.println("OK: " + msg);
|
||||
}
|
||||
|
||||
private static void testPrivate(Class<?> iface, Object bean) throws Exception {
|
||||
try {
|
||||
System.out.println("Registering a private MBean " +
|
||||
iface.getName() + " ...");
|
||||
|
||||
MBeanServer mbs = MBeanServerFactory.newMBeanServer();
|
||||
ObjectName on = new ObjectName("test:type=Compliant");
|
||||
|
||||
mbs.registerMBean(bean, on);
|
||||
success("Registered a private MBean - " + iface.getName());
|
||||
} catch (Exception e) {
|
||||
Throwable t = e;
|
||||
while (t != null && !(t instanceof NotCompliantMBeanException)) {
|
||||
t = t.getCause();
|
||||
}
|
||||
if (t != null) {
|
||||
fail("MBean not registered");
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,85 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8010285
|
||||
* @summary Test for the private MXBean interface fallback.
|
||||
* It needs to be a separate class because the "jdk.jmx.mbeans.allowNonPublic"
|
||||
* system property must be set before c.s.j.m.MBeanAnalyzer has been loaded.
|
||||
* @author Jaroslav Bachorik
|
||||
*
|
||||
* @run clean MXBeanFallbackTest
|
||||
* @run build MXBeanFallbackTest
|
||||
* @run main/othervm -Djdk.jmx.mbeans.allowNonPublic=true MXBeanFallbackTest
|
||||
*/
|
||||
|
||||
import javax.management.MBeanServer;
|
||||
import javax.management.MBeanServerFactory;
|
||||
import javax.management.NotCompliantMBeanException;
|
||||
import javax.management.ObjectName;
|
||||
|
||||
public class MXBeanFallbackTest {
|
||||
public static void main(String[] args) throws Exception {
|
||||
testPrivateMXBean("Private", new Private());
|
||||
|
||||
if (failures == 0)
|
||||
System.out.println("Test passed");
|
||||
else
|
||||
throw new Exception("TEST FAILURES: " + failures);
|
||||
}
|
||||
|
||||
private static int failures = 0;
|
||||
|
||||
private static interface PrivateMXBean {
|
||||
public int[] getInts();
|
||||
}
|
||||
|
||||
public static class Private implements PrivateMXBean {
|
||||
public int[] getInts() {
|
||||
return new int[]{1,2,3};
|
||||
}
|
||||
}
|
||||
|
||||
private static void testPrivateMXBean(String type, Object bean) throws Exception {
|
||||
System.out.println(type + " MXBean test...");
|
||||
MBeanServer mbs = MBeanServerFactory.newMBeanServer();
|
||||
ObjectName on = new ObjectName("test:type=" + type);
|
||||
try {
|
||||
mbs.registerMBean(bean, on);
|
||||
success("Private MXBean registered");
|
||||
} catch (NotCompliantMBeanException e) {
|
||||
failure("Failed to register the private MXBean - " +
|
||||
bean.getClass().getInterfaces()[0].getName());
|
||||
}
|
||||
}
|
||||
|
||||
private static void success(String what) {
|
||||
System.out.println("OK: " + what);
|
||||
}
|
||||
|
||||
private static void failure(String what) {
|
||||
System.out.println("FAILED: " + what);
|
||||
failures++;
|
||||
}
|
||||
}
|
||||
@ -1,100 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
import javax.management.JMX;
|
||||
import javax.management.MBeanServer;
|
||||
import javax.management.MBeanServerFactory;
|
||||
import javax.management.NotCompliantMBeanException;
|
||||
import javax.management.ObjectName;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8010285
|
||||
* @summary Tests the fallback for creating JMX proxies for private interfaces
|
||||
* It needs to be a separate class because the "jdk.jmx.mbeans.allowNonPublic"
|
||||
* system property must be set before c.s.j.m.MBeanAnalyzer has been loaded.
|
||||
* @author Jaroslav Bachorik
|
||||
*
|
||||
* @run clean JMXProxyFallbackTest
|
||||
* @run build JMXProxyFallbackTest
|
||||
* @run main/othervm -Djdk.jmx.mbeans.allowNonPublic=true JMXProxyFallbackTest
|
||||
*/
|
||||
public class JMXProxyFallbackTest {
|
||||
private static interface PrivateMBean {
|
||||
public int[] getInts();
|
||||
}
|
||||
|
||||
private static interface PrivateMXBean {
|
||||
public int[] getInts();
|
||||
}
|
||||
|
||||
public static class Private implements PrivateMXBean, PrivateMBean {
|
||||
public int[] getInts() {
|
||||
return new int[]{1,2,3};
|
||||
}
|
||||
}
|
||||
|
||||
private static int failures = 0;
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
testPrivate(PrivateMBean.class);
|
||||
testPrivate(PrivateMXBean.class);
|
||||
|
||||
if (failures == 0)
|
||||
System.out.println("Test passed");
|
||||
else
|
||||
throw new Exception("TEST FAILURES: " + failures);
|
||||
}
|
||||
|
||||
private static void fail(String msg) {
|
||||
failures++;
|
||||
System.out.println("FAIL: " + msg);
|
||||
}
|
||||
|
||||
private static void success(String msg) {
|
||||
System.out.println("OK: " + msg);
|
||||
}
|
||||
|
||||
private static void testPrivate(Class<?> iface) throws Exception {
|
||||
try {
|
||||
System.out.println("Creating a proxy for private M(X)Bean " +
|
||||
iface.getName() + " ...");
|
||||
|
||||
MBeanServer mbs = MBeanServerFactory.newMBeanServer();
|
||||
ObjectName on = new ObjectName("test:type=Proxy");
|
||||
|
||||
JMX.newMBeanProxy(mbs, on, iface);
|
||||
success("Created a proxy for private M(X)Bean - " + iface.getName());
|
||||
} catch (Exception e) {
|
||||
Throwable t = e;
|
||||
while (t != null && !(t instanceof NotCompliantMBeanException)) {
|
||||
t = t.getCause();
|
||||
}
|
||||
if (t != null) {
|
||||
fail("Proxy not created");
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user