473266 - Better handling of MultiException

Add extra exceptions as suppressed exceptions
This commit is contained in:
Greg Wilkins 2015-07-23 22:50:20 +10:00
parent ac8316756c
commit c9c2ebc532
3 changed files with 40 additions and 53 deletions

View File

@ -18,8 +18,6 @@
package org.eclipse.jetty.util; package org.eclipse.jetty.util;
import java.io.PrintStream;
import java.io.PrintWriter;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -51,6 +49,8 @@ public class MultiException extends Exception
initCause(e); initCause(e);
nested = new ArrayList<>(); nested = new ArrayList<>();
} }
else
addSuppressed(e);
if (e instanceof MultiException) if (e instanceof MultiException)
{ {
@ -70,9 +70,8 @@ public class MultiException extends Exception
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
public List<Throwable> getThrowables() public List<Throwable> getThrowables()
{ {
if(nested == null) { if(nested == null)
return Collections.emptyList(); return Collections.emptyList();
}
return nested; return nested;
} }
@ -172,47 +171,4 @@ public class MultiException extends Exception
return str.toString(); return str.toString();
} }
/* ------------------------------------------------------------ */
@Override
public void printStackTrace()
{
super.printStackTrace();
if(nested != null) {
for(Throwable t: nested) {
t.printStackTrace();
}
}
}
/* ------------------------------------------------------------------------------- */
/**
* @see java.lang.Throwable#printStackTrace(java.io.PrintStream)
*/
@Override
public void printStackTrace(PrintStream out)
{
super.printStackTrace(out);
if(nested != null) {
for(Throwable t: nested) {
t.printStackTrace(out);
}
}
}
/* ------------------------------------------------------------------------------- */
/**
* @see java.lang.Throwable#printStackTrace(java.io.PrintWriter)
*/
@Override
public void printStackTrace(PrintWriter out)
{
super.printStackTrace(out);
if(nested != null) {
for(Throwable t: nested) {
t.printStackTrace(out);
}
}
}
} }

View File

@ -694,7 +694,12 @@ public class StdErrLog extends AbstractLogger
builder.append(string); builder.append(string);
} }
private void format(StringBuilder buffer, Throwable thrown) protected void format(StringBuilder buffer, Throwable thrown)
{
format(buffer,thrown,"");
}
protected void format(StringBuilder buffer, Throwable thrown, String indent)
{ {
if (thrown == null) if (thrown == null)
{ {
@ -702,20 +707,26 @@ public class StdErrLog extends AbstractLogger
} }
else else
{ {
buffer.append(EOL); buffer.append(EOL).append(indent);
format(buffer,thrown.toString()); format(buffer,thrown.toString());
StackTraceElement[] elements = thrown.getStackTrace(); StackTraceElement[] elements = thrown.getStackTrace();
for (int i = 0; elements != null && i < elements.length; i++) for (int i = 0; elements != null && i < elements.length; i++)
{ {
buffer.append(EOL).append("\tat "); buffer.append(EOL).append(indent).append("\tat ");
format(buffer,elements[i].toString()); format(buffer,elements[i].toString());
} }
for (Throwable suppressed:thrown.getSuppressed())
{
buffer.append(EOL).append(indent).append("Suppressed: ");
format(buffer,suppressed,"\t|"+indent);
}
Throwable cause = thrown.getCause(); Throwable cause = thrown.getCause();
if (cause != null && cause != thrown) if (cause != null && cause != thrown)
{ {
buffer.append(EOL).append("Caused by: "); buffer.append(EOL).append(indent).append("Caused by: ");
format(buffer,cause); format(buffer,cause,indent);
} }
} }
} }

View File

@ -22,6 +22,7 @@ import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.is;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintStream; import java.io.PrintStream;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.io.StringWriter; import java.io.StringWriter;
@ -683,6 +684,25 @@ public class StdErrLogTest
assertLevel(log,StdErrLog.LEVEL_WARN); // as configured assertLevel(log,StdErrLog.LEVEL_WARN); // as configured
} }
@Test
public void testSuppressed()
{
StdErrLog log = new StdErrLog("xxx",new Properties());
StdErrCapture output = new StdErrCapture(log);
Exception inner = new Exception("inner");
inner.addSuppressed( new IllegalStateException(){{addSuppressed(new Exception("branch0"));}});
IOException outer = new IOException("outer",inner);
outer.addSuppressed( new IllegalStateException(){{addSuppressed(new Exception("branch1"));}});
outer.addSuppressed( new IllegalArgumentException(){{addSuppressed(new Exception("branch2"));}});
log.warn("problem",outer);
output.assertContains("\t|\t|java.lang.Exception: branch2");
output.assertContains("\t|\t|java.lang.Exception: branch1");
output.assertContains("\t|\t|java.lang.Exception: branch0");
}
private void assertLevel(StdErrLog log, int expectedLevel) private void assertLevel(StdErrLog log, int expectedLevel)
{ {