From d8ef923c2ad584fd9848467fe0efa05533f4e279 Mon Sep 17 00:00:00 2001 From: James Nord Date: Tue, 14 May 2024 13:42:02 +0100 Subject: [PATCH] pass through the remote ClassLoaders name add getName to the IClassloader and set a name in the RemoteClassLoader This improves the debugability from RemoteClassloaders to understand any classloading related issues. --- .../remoting/DumbClassLoaderBridge.java | 6 ++++ .../hudson/remoting/RemoteClassLoader.java | 34 +++++++++++++++++-- 2 files changed, 37 insertions(+), 3 deletions(-) diff --git a/src/main/java/hudson/remoting/DumbClassLoaderBridge.java b/src/main/java/hudson/remoting/DumbClassLoaderBridge.java index 090a60171..4dd43aee9 100644 --- a/src/main/java/hudson/remoting/DumbClassLoaderBridge.java +++ b/src/main/java/hudson/remoting/DumbClassLoaderBridge.java @@ -79,4 +79,10 @@ public ResourceFile[] getResources2(String name) throws IOException { } return res; } + + @Override + public String getName() throws IOException { + return base.getName(); + } + } diff --git a/src/main/java/hudson/remoting/RemoteClassLoader.java b/src/main/java/hudson/remoting/RemoteClassLoader.java index 84518a82c..392bef7c3 100644 --- a/src/main/java/hudson/remoting/RemoteClassLoader.java +++ b/src/main/java/hudson/remoting/RemoteClassLoader.java @@ -170,11 +170,18 @@ public static ClassLoader create(@CheckForNull ClassLoader parent, @NonNull ICla // actually our classloader that we exported to the other side. return ((ClassLoaderProxy) proxy).cl; } - return new RemoteClassLoader(parent, proxy); + + String name; + try { + name = proxy.getName(); + } catch(IOException ignored) { + name = "unknown-due-to-io-error"; + } + return new RemoteClassLoader(name, parent, proxy); } - private RemoteClassLoader(@CheckForNull ClassLoader parent, @NonNull IClassLoader proxy) { - super(new URL[0], parent); + private RemoteClassLoader(String name, @CheckForNull ClassLoader parent, @NonNull IClassLoader proxy) { + super(name, new URL[0], parent); final Channel channel = RemoteInvocationHandler.unwrap(proxy); this.channel = channel == null ? null : channel.ref(); this.underlyingProxy = proxy; @@ -887,6 +894,12 @@ public interface IClassLoader { */ @NonNull ResourceFile[] getResources2(String name) throws IOException; + + /** + * Name of the classLoader + * @since //TODO + */ + String getName() throws IOException; } /** @@ -1178,6 +1191,11 @@ public ResourceFile[] getResources2(String name) throws IOException { return r; } + @Override + public String getName() throws IOException { + return cl.getName(); + } + @Override public boolean equals(Object that) { if (this == that) { @@ -1276,6 +1294,11 @@ public ResourceFile[] getResources2(String name) throws IOException { return proxy.getResources2(name); } + @Override + public String getName() throws IOException { + return proxy.getName(); + } + private Object readResolve() throws ObjectStreamException { try { return getChannelForSerialization().getExportedObject(oid); @@ -1336,6 +1359,11 @@ public ResourceFile[] getResources2(String name) throws IOException { throw new IOException("Cannot get " + name, cause); } + @Override + public String getName() throws IOException { + throw new IOException("Cannot getName", cause); + } + } private static Iterable analyze(InputStream bytecode) {