[MNG-6626] fix DefaultExceptionHandler NPE

Closes #241
This commit is contained in:
Sergey Chernov 2019-04-05 22:29:33 +03:00 committed by Sylwester Lachiewicz
parent 3ac9718f82
commit 1a18eb6c9c
2 changed files with 55 additions and 7 deletions

View File

@ -209,12 +209,15 @@ public class DefaultExceptionHandler
{
Throwable cause2 = cause.getCause();
if ( cause2 instanceof NoClassDefFoundError
&& cause2.getMessage().contains( "org/sonatype/aether/" ) )
if ( cause2 instanceof NoClassDefFoundError )
{
String message = cause2.getMessage();
if ( message != null && message.contains( "org/sonatype/aether/" ) )
{
reference = "AetherClassNotFound";
}
}
}
if ( StringUtils.isEmpty( reference ) )
{

View File

@ -22,15 +22,22 @@ package org.apache.maven.exception;
import java.io.IOException;
import java.net.ConnectException;
import org.apache.maven.model.Plugin;
import org.apache.maven.plugin.MojoExecution;
import org.apache.maven.plugin.MojoExecutionException;
import junit.framework.TestCase;
import org.apache.maven.plugin.PluginContainerException;
import org.apache.maven.plugin.PluginExecutionException;
import org.apache.maven.plugin.descriptor.MojoDescriptor;
import org.apache.maven.plugin.descriptor.PluginDescriptor;
import org.junit.Test;
import static org.junit.Assert.assertEquals;
/**
* @author <a href="mailto:baerrach@apache.org">Barrie Treloar</a>
*/
public class DefaultExceptionHandlerTest
extends TestCase
{
/**
* Running Maven under JDK7 may cause connection issues because IPv6 is used by default.
@ -42,11 +49,11 @@ public class DefaultExceptionHandlerTest
* http://cwiki.apache.org/confluence/display/MAVEN/ConnectException
* </p>
*/
@Test
public void testJdk7ipv6()
{
ConnectException connEx = new ConnectException( "Connection refused: connect" );
IOException ioEx = new IOException( "Unable to establish loopback connection" );
ioEx.initCause( connEx );
IOException ioEx = new IOException( "Unable to establish loopback connection", connEx );
MojoExecutionException mojoEx =
new MojoExecutionException( "Error executing Jetty: Unable to establish loopback connection", ioEx );
@ -57,4 +64,42 @@ public class DefaultExceptionHandlerTest
assertEquals( expectedReference, exceptionSummary.getReference() );
}
@Test
public void testHandleExceptionAetherClassNotFound()
{
Throwable cause2 = new NoClassDefFoundError( "org/sonatype/aether/RepositorySystem" );
Plugin plugin = new Plugin();
Exception cause = new PluginContainerException( plugin, null, null, cause2 );
PluginDescriptor pluginDescriptor = new PluginDescriptor();
MojoDescriptor mojoDescriptor = new MojoDescriptor();
mojoDescriptor.setPluginDescriptor( pluginDescriptor );
MojoExecution mojoExecution = new MojoExecution(mojoDescriptor);
Throwable exception = new PluginExecutionException( mojoExecution, null, cause );
DefaultExceptionHandler handler = new DefaultExceptionHandler();
ExceptionSummary summary = handler.handleException( exception );
String expectedReference = "http://cwiki.apache.org/confluence/display/MAVEN/AetherClassNotFound";
assertEquals( expectedReference, summary.getReference() );
}
@Test
public void testHandleExceptionNoClassDefFoundErrorNull()
{
Throwable cause2 = new NoClassDefFoundError();
Plugin plugin = new Plugin();
Exception cause = new PluginContainerException( plugin, null, null, cause2 );
PluginDescriptor pluginDescriptor = new PluginDescriptor();
MojoDescriptor mojoDescriptor = new MojoDescriptor();
mojoDescriptor.setPluginDescriptor( pluginDescriptor );
MojoExecution mojoExecution = new MojoExecution(mojoDescriptor);
Throwable exception = new PluginExecutionException( mojoExecution, null, cause );
DefaultExceptionHandler handler = new DefaultExceptionHandler();
ExceptionSummary summary = handler.handleException( exception );
String expectedReference = "http://cwiki.apache.org/confluence/display/MAVEN/PluginContainerException";
assertEquals( expectedReference, summary.getReference() );
}
}