[shrinkwrap-issues] [JBoss JIRA] (SHRINKWRAP-516) ContainerBase.addPackages() fails with IllegalArgumentException from ClassLoaderAsset

Falko Modler (JIRA) issues at jboss.org
Wed Jul 5 11:42:00 EDT 2017


     [ https://issues.jboss.org/browse/SHRINKWRAP-516?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Falko Modler updated SHRINKWRAP-516:
------------------------------------
              Status: Pull Request Sent  (was: Open)
    Git Pull Request: https://github.com/shrinkwrap/shrinkwrap/pull/110


PR sent.

> ContainerBase.addPackages() fails with IllegalArgumentException from ClassLoaderAsset
> -------------------------------------------------------------------------------------
>
>                 Key: SHRINKWRAP-516
>                 URL: https://issues.jboss.org/browse/SHRINKWRAP-516
>             Project: ShrinkWrap
>          Issue Type: Bug
>          Components: impl-base
>    Affects Versions: 1.2.4
>            Reporter: Falko Modler
>            Priority: Critical
>
> In my current JBoss EAP 6.4 project I tried to update Arquillian from 1.1.11 to 1.1.13 which fails with:
> {noformat}
> Caused by: java.lang.IllegalArgumentException: /com/some_company/some_project/some_package/SomeClass.class not found in classloader sun.misc.Launcher$AppClassLoader at 6bc7c054
>         at org.jboss.shrinkwrap.api.asset.ClassLoaderAsset.<init>(ClassLoaderAsset.java:70)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.foundClass(URLPackageScanner.java:165)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:157)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:159)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(URLPackageScanner.java:145)
>         at org.jboss.shrinkwrap.impl.base.URLPackageScanner.scanPackage(URLPackageScanner.java:113)
>         at org.jboss.shrinkwrap.impl.base.container.ContainerBase.addPackage(ContainerBase.java:1520)
>         at org.jboss.shrinkwrap.impl.base.container.ContainerBase.addPackages(ContainerBase.java:1485)
>         at ...
> {noformat}
> Arquillian 1.1.13 brings in Shrinkwrap 1.2.6 (we are on 1.2.3 with Arquillian 1.1.11).
> After extensive research and debugging I am almost 100% sure that this is a regression caused by this commit (SHRINKWRAP-505):
> https://github.com/shrinkwrap/shrinkwrap/commit/d0df4ba3fd12998388521219e724c3964428a28a
> The root cause of the problem lies within the {{else}} block of {{org.jboss.shrinkwrap.impl.base.URLPackageScanner.handle(File, String)}}:
> {code:java}
>     private void handle(File file, String packageName) throws ClassNotFoundException {
>         for (File child : file.listFiles()) {
>             if (!child.isDirectory() && child.getName().endsWith(SUFFIX_CLASS)) {
>                 final String packagePrefix = packageName.length() > 0 ? packageName + "." : packageName;
>                 String className = packagePrefix + child.getName().substring(0, child.getName().lastIndexOf(SUFFIX_CLASS));
>                 foundClass(className, prefix + className.replace( '.', '/' ) + SUFFIX_CLASS );
>             } else if (child.isDirectory() && addRecursively) {
>                 handle(child, packageName + "." + child.getName());
>             }
>         }
>     }
> {code}
> The first {{handle()}} invocation has an _empty_ {{packageName}} and when the {{else}} block kicks in, {{handle()}} is called recursively with with e.g. ".com" which is a malformed package name.
> While SHRINKWRAP-505 did not touch this {{else}} block it _did_ remove a crucial {{.substring(1)}} call, see:
> https://github.com/shrinkwrap/shrinkwrap/commit/d0df4ba3fd12998388521219e724c3964428a28a#diff-68209d76d20ce7a8aef1913712645af9R1514
> Suggested solution: Don't prepend a dot in case {{packageName}} is empty.
> Note: SHRINKWRAP-515 should be resolved alongside this fix as one of the affected tests was introduced in SHRINKWRAP-505.



--
This message was sent by Atlassian JIRA
(v7.2.3#72005)


More information about the shrinkwrap-issues mailing list