From ac61f0e968674728994c5855c5b5ad6c40441ed8 Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Fri, 15 Sep 2017 13:34:00 -0400 Subject: [PATCH] Ensure that WebAppClassLoader.addJars considers classpath entries in a deterministic order. Signed-off-by: Jesse Glick --- .../eclipse/jetty/util/resource/Resource.java | 4 +-- .../util/resource/ResourceCollection.java | 2 +- .../jetty/webapp/WebAppClassLoader.java | 10 ++++++-- .../jetty/webapp/WebInfConfiguration.java | 1 + .../jetty/webapp/WebAppClassLoaderTest.java | 24 ++++++++++++++++++ .../src/test/webapp/WEB-INF/lib/alpha.jar | Bin 0 -> 577 bytes .../src/test/webapp/WEB-INF/lib/omega.jar | Bin 0 -> 577 bytes 7 files changed, 36 insertions(+), 5 deletions(-) create mode 100644 jetty-webapp/src/test/webapp/WEB-INF/lib/alpha.jar create mode 100644 jetty-webapp/src/test/webapp/WEB-INF/lib/omega.jar diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/resource/Resource.java b/jetty-util/src/main/java/org/eclipse/jetty/util/resource/Resource.java index fc604a4adf0..5908571fb06 100644 --- a/jetty-util/src/main/java/org/eclipse/jetty/util/resource/Resource.java +++ b/jetty-util/src/main/java/org/eclipse/jetty/util/resource/Resource.java @@ -447,8 +447,8 @@ public abstract class Resource implements ResourceFactory, Closeable /* ------------------------------------------------------------ */ /** * list of resource names contained in the given resource. - * - * @return a list of resource names contained in the given resource. + * Ordering is unspecified, so callers may wish to sort the return value to ensure deterministic behavior. + * @return a list of resource names contained in the given resource, or null. * Note: The resource names are not URL encoded. */ public abstract String[] list(); diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/resource/ResourceCollection.java b/jetty-util/src/main/java/org/eclipse/jetty/util/resource/ResourceCollection.java index d46a0858717..60ebf846151 100644 --- a/jetty-util/src/main/java/org/eclipse/jetty/util/resource/ResourceCollection.java +++ b/jetty-util/src/main/java/org/eclipse/jetty/util/resource/ResourceCollection.java @@ -438,7 +438,7 @@ public class ResourceCollection extends Resource set.add(s); } String[] result=set.toArray(new String[set.size()]); - Arrays.sort(result); + Arrays.sort(result); // TODO still necessary? return result; } diff --git a/jetty-webapp/src/main/java/org/eclipse/jetty/webapp/WebAppClassLoader.java b/jetty-webapp/src/main/java/org/eclipse/jetty/webapp/WebAppClassLoader.java index bc4c855b226..ef0236ba92a 100644 --- a/jetty-webapp/src/main/java/org/eclipse/jetty/webapp/WebAppClassLoader.java +++ b/jetty-webapp/src/main/java/org/eclipse/jetty/webapp/WebAppClassLoader.java @@ -29,6 +29,7 @@ import java.security.CodeSource; import java.security.PermissionCollection; import java.security.PrivilegedExceptionAction; import java.util.ArrayList; +import java.util.Arrays; import java.util.Collections; import java.util.Enumeration; import java.util.HashSet; @@ -324,10 +325,15 @@ public class WebAppClassLoader extends URLClassLoader */ public void addJars(Resource lib) { - if (lib.exists() && lib.isDirectory()) + if (lib.exists() && lib.isDirectory()) // TODO perhaps redundant given null check from list()? { String[] files=lib.list(); - for (int f=0;files!=null && f resources = _loader.getResources("org/acme/clashing.txt"); + assertTrue(resources.hasMoreElements()); + URL resource = resources.nextElement(); + try (InputStream data = resource.openStream()) + { + assertEquals("correct contents of " + resource, "alpha", IO.toString(data)); + } + assertTrue(resources.hasMoreElements()); + resource = resources.nextElement(); + try (InputStream data = resource.openStream()) + { + assertEquals("correct contents of " + resource, "omega", IO.toString(data)); + } + assertFalse(resources.hasMoreElements()); + } + } diff --git a/jetty-webapp/src/test/webapp/WEB-INF/lib/alpha.jar b/jetty-webapp/src/test/webapp/WEB-INF/lib/alpha.jar new file mode 100644 index 0000000000000000000000000000000000000000..a26fb083a5690e3a3fb15e8e4367942a3a02e44d GIT binary patch literal 577 zcmWIWW@Zs#;Nak3Se~ix&42_r8CV#6T|*poJ^kGD|D9rBU}gyLX6FE@V1gr^*uAi8ko2rj+>{2vkqCi97%93*ui!(Cw()CIzO1#f#p73A+TbO0}-~u~P z9V^&EMkWyk)KG&32`JQ10X!H$VHn_zsukHEpfE!KTObpz6)6NkCU7y}_AkPO!$2n7 mTgVoJ{EzG(kpB_j6_5$nh8!9J-mGjOWh_AW9Y~unf_MOmXK7Xd literal 0 HcmV?d00001 diff --git a/jetty-webapp/src/test/webapp/WEB-INF/lib/omega.jar b/jetty-webapp/src/test/webapp/WEB-INF/lib/omega.jar new file mode 100644 index 0000000000000000000000000000000000000000..b72fa753024a5e5908c9aaac0e843323369b1c61 GIT binary patch literal 577 zcmWIWW@Zs#;Nak3Se>cw&42_r8CV#6T|*poJ^kGD|D9rBU}gyLX6FE@V1gr^*uAi8ko2rj+>`F9cqCi97%93*ui!(Cw()CIzN=~2m_4Q`~TWB>`(u*Ca zjumVnBa;XNYN)}21Qcqh03HmWFbwcU)r#y7P?#ZrEszP~`xjxtVIULk mEo6&9{zvu?$o~lN3dn?OLk^7qZ&o&tG8Q2G4x~*OK|BCtyk~C! literal 0 HcmV?d00001