NPE in CoberturaReportMojo.getAllChildren in multi-module project
-----------------------------------------------------------------

                 Key: MCOBERTURA-148
                 URL: http://jira.codehaus.org/browse/MCOBERTURA-148
             Project: Maven 2.x Cobertura Plugin
          Issue Type: Bug
    Affects Versions: 2.5.1
         Environment: Linux
            Reporter: Per RovegÄrd
            Priority: Blocker


I have a multi-module project where some of the modules have pom packaging. 
These are dependency modules and one module that does non-standard deployment. 
Thus, none is a parent module of some other module.

When I run 

{code}
mvn -e cobertura:cobertura -Dcobertura.aggregate=true
{code}

I get:

{code}
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal 
org.codehaus.mojo:cobertura-maven-plugin:2.5.1:cobertura (default-cli) on 
project zzz-test: Execution default-cli of goal 
org.codehaus.mojo:cobertura-maven-plugin:2.5.1:cobertura failed.
        at 
org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:225)
        at 
org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
        at 
org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
        at 
org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
        at 
org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
        at 
org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
        at 
org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:319)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
        at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537)
        at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at 
org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
        at 
org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
        at 
org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
        at 
org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)
Caused by: org.apache.maven.plugin.PluginExecutionException: Execution 
default-cli of goal org.codehaus.mojo:cobertura-maven-plugin:2.5.1:cobertura 
failed.
        at 
org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:110)
        at 
org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209)
        ... 19 more
Caused by: java.lang.NullPointerException
        at java.util.ArrayList.addAll(ArrayList.java:472)
        at 
org.codehaus.mojo.cobertura.CoberturaReportMojo.getAllChildren(CoberturaReportMojo.java:574)
        at 
org.codehaus.mojo.cobertura.CoberturaReportMojo.executeAggregateReport(CoberturaReportMojo.java:275)
        at 
org.codehaus.mojo.cobertura.CoberturaReportMojo.executeAggregateReport(CoberturaReportMojo.java:265)
        at 
org.codehaus.mojo.cobertura.CoberturaReportMojo.executeReport(CoberturaReportMojo.java:251)
        at 
org.apache.maven.reporting.AbstractMavenReport.generate(AbstractMavenReport.java:93)
        at 
org.apache.maven.reporting.AbstractMavenReport.execute(AbstractMavenReport.java:68)
        at 
org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101)
        ... 20 more
{code}

The zzz-test module does NOT have pom packaging, though.

I noticed in CoberturaReportMojo.getAllChildren that there is one code path 
that passes {{null}} into addAll, namely when a module with pom packaging does 
not have any child modules.

I suppose the following patch will fix the problem:

{code:java}
--- CoberturaReportMojo.java    2011-05-26 14:53:47.000000000 +0200
+++ CoberturaReportMojo.java.fix        2011-05-26 14:55:56.000000000 +0200
@@ -23,6 +23,7 @@
 import java.util.Locale;
 import java.util.Map;
 import java.util.ResourceBundle;
+import java.util.Collections;

 import net.sourceforge.cobertura.coveragedata.CoverageDataFileHandler;
 import net.sourceforge.cobertura.coveragedata.ProjectData;
@@ -563,7 +564,7 @@
         List<MavenProject> children = projectChildren.get( parentProject );
         if ( children == null )
         {
-            return null;
+            return Collections.emptyList();
         }

         List<MavenProject> result = new ArrayList<MavenProject>();
{code}

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: 
http://jira.codehaus.org/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira



---------------------------------------------------------------------
To unsubscribe from this list, please visit:

    http://xircles.codehaus.org/manage_email


Reply via email to