mirror of https://github.com/apache/activemq.git
AMQ-7209 suppress stack trace in stomp error frame for SecurityExceptions to avoid any implementation detail leakage, fix and test
This commit is contained in:
parent
ac4f4a82a7
commit
4129c1f659
|
@ -297,7 +297,11 @@ public class ProtocolConverter {
|
||||||
// Let the stomp client know about any protocol errors.
|
// Let the stomp client know about any protocol errors.
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
PrintWriter stream = new PrintWriter(new OutputStreamWriter(baos, "UTF-8"));
|
PrintWriter stream = new PrintWriter(new OutputStreamWriter(baos, "UTF-8"));
|
||||||
exception.printStackTrace(stream);
|
if (exception instanceof SecurityException || exception.getCause() instanceof SecurityException) {
|
||||||
|
stream.write(exception.getLocalizedMessage());
|
||||||
|
} else {
|
||||||
|
exception.printStackTrace(stream);
|
||||||
|
}
|
||||||
stream.close();
|
stream.close();
|
||||||
|
|
||||||
HashMap<String, String> headers = new HashMap<>();
|
HashMap<String, String> headers = new HashMap<>();
|
||||||
|
|
|
@ -901,6 +901,7 @@ public class StompTest extends StompTestSupport {
|
||||||
try {
|
try {
|
||||||
String f = stompConnection.receiveFrame();
|
String f = stompConnection.receiveFrame();
|
||||||
assertTrue(f.startsWith("ERROR"));
|
assertTrue(f.startsWith("ERROR"));
|
||||||
|
assertFalse("no stack trace impl leak:" + f, f.contains("at "));
|
||||||
} catch (IOException socketMayBeClosedFirstByBroker) {}
|
} catch (IOException socketMayBeClosedFirstByBroker) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -913,6 +914,7 @@ public class StompTest extends StompTestSupport {
|
||||||
try {
|
try {
|
||||||
String f = stompConnection.receiveFrame();
|
String f = stompConnection.receiveFrame();
|
||||||
assertTrue(f.startsWith("ERROR"));
|
assertTrue(f.startsWith("ERROR"));
|
||||||
|
assertFalse("no stack trace impl leak:" + f, f.contains("at "));
|
||||||
} catch (IOException socketMayBeClosedFirstByBroker) {}
|
} catch (IOException socketMayBeClosedFirstByBroker) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -930,6 +932,7 @@ public class StompTest extends StompTestSupport {
|
||||||
stompConnection.sendFrame(frame);
|
stompConnection.sendFrame(frame);
|
||||||
String f = stompConnection.receiveFrame();
|
String f = stompConnection.receiveFrame();
|
||||||
assertTrue(f.startsWith("ERROR"));
|
assertTrue(f.startsWith("ERROR"));
|
||||||
|
assertFalse("no stack trace impl leak:" + f, f.contains("at "));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60000)
|
@Test(timeout = 60000)
|
||||||
|
@ -946,6 +949,7 @@ public class StompTest extends StompTestSupport {
|
||||||
stompConnection.sendFrame(frame);
|
stompConnection.sendFrame(frame);
|
||||||
frame = stompConnection.receiveFrame();
|
frame = stompConnection.receiveFrame();
|
||||||
assertTrue(frame.startsWith("ERROR"));
|
assertTrue(frame.startsWith("ERROR"));
|
||||||
|
assertFalse("no stack trace impl leak:" + frame, frame.contains("at "));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60000)
|
@Test(timeout = 60000)
|
||||||
|
@ -964,6 +968,7 @@ public class StompTest extends StompTestSupport {
|
||||||
frame = stompConnection.receiveFrame();
|
frame = stompConnection.receiveFrame();
|
||||||
assertTrue(frame.startsWith("ERROR"));
|
assertTrue(frame.startsWith("ERROR"));
|
||||||
assertTrue("Error Frame did not contain receipt-id", frame.indexOf(Stomp.Headers.Response.RECEIPT_ID) >= 0);
|
assertTrue("Error Frame did not contain receipt-id", frame.indexOf(Stomp.Headers.Response.RECEIPT_ID) >= 0);
|
||||||
|
assertFalse("no stack trace impl leak:" + frame, frame.contains("at "));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60000)
|
@Test(timeout = 60000)
|
||||||
|
|
Loading…
Reference in New Issue