RFR: 8364227: MBeanServer registerMBean throws NPE [v3]
Alan Bateman
alanb at openjdk.org
Thu Jul 31 15:50:55 UTC 2025
On Wed, 30 Jul 2025 17:54:34 GMT, Kevin Walls <kevinw at openjdk.org> wrote:
>> A long-standing omission where MBeanServer.registerMBean documents exception behaviour, but we actually throw an NPE. We should recognise a null object and return the wrapped exception we document.
>>
>> This wrapping behaviour is common elsewhere in this area, e.g. unregisterMBean which checks for a null name and throws RuntimeOperationsException.
>>
>> Docs:
>> https://docs.oracle.com/en/java/javase/24/docs/api/java.management/javax/management/MBeanServer.html#registerMBean(java.lang.Object,javax.management.ObjectName)
>>
>> Throws:
>> RuntimeOperationsException - Wraps a java.lang.IllegalArgumentException: The object passed in parameter is null or no object name is specified.
>>
>>
>> Current behaviour:
>>
>>
>> $ java MBS_NPE.java
>> Exception in thread "main" java.lang.NullPointerException: Cannot invoke "Object.getClass()" because "object" is null
>> at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:296)
>> at java.management/com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:511)
>> at MBS_NPE.main(MBS_NPE.java:11)
>>
>>
>> Should be changed to:
>>
>>
>> $ java MBS_NPE.java
>> javax.management.RuntimeOperationsException: Exception occurred trying to register the MBean
>> at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:297)
>> at java.management/com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:511)
>> at MBS_NPE.main(MBS_NPE.java:11)
>> at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:104)
>> at java.base/java.lang.reflect.Method.invoke(Method.java:565)
>> at jdk.compiler/com.sun.tools.javac.launcher.SourceLauncher.execute(SourceLauncher.java:258)
>> at jdk.compiler/com.sun.tools.javac.launcher.SourceLauncher.run(SourceLauncher.java:138)
>> at jdk.compiler/com.sun.tools.javac.launcher.SourceLauncher.main(SourceLauncher.java:76)
>> Caused by: java.lang.IllegalArgumentException: Object cannot be null
>> at java.management/com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:295)
>> ... 7 more
>
> Kevin Walls has updated the pull request incrementally with one additional commit since the last revision:
>
> One more case
test/jdk/javax/management/MBeanServer/ExceptionTestNulls.java line 29:
> 27: * @summary Test various null parameters and verify Exceptions thrown
> 28: * @modules java.management.rmi
> 29: * @run main ExceptionTestNulls
The test looks okay but I wonder if you've considered making it a JUnit test?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/26548#discussion_r2245767679
More information about the serviceability-dev
mailing list