mirror of https://github.com/apache/activemq.git
AMQ-8184 - Re-enable NIO tests
Re-enable the nio transport tests in activemq-unit-tests by default to
catch transport errors. Also fix broken tests
(cherry picked from commit 2cf3decd8e
)
This commit is contained in:
parent
20d822fbb8
commit
34475dbde3
|
@ -266,7 +266,7 @@ public class TransportConnector implements Connector, BrokerServiceAware {
|
||||||
LOG.info("Connector {} started", getName());
|
LOG.info("Connector {} started", getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
static Throwable getRootCause(final Throwable throwable) {
|
public static Throwable getRootCause(final Throwable throwable) {
|
||||||
final List<Throwable> list = getThrowableList(throwable);
|
final List<Throwable> list = getThrowableList(throwable);
|
||||||
return list.isEmpty() ? null : list.get(list.size() - 1);
|
return list.isEmpty() ? null : list.get(list.size() - 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ import javax.net.ssl.SSLEngine;
|
||||||
|
|
||||||
import org.apache.activemq.broker.BrokerService;
|
import org.apache.activemq.broker.BrokerService;
|
||||||
import org.apache.activemq.broker.BrokerServiceAware;
|
import org.apache.activemq.broker.BrokerServiceAware;
|
||||||
|
import org.apache.activemq.broker.TransportConnector;
|
||||||
import org.apache.activemq.transport.Transport;
|
import org.apache.activemq.transport.Transport;
|
||||||
import org.apache.activemq.transport.auto.AutoTcpTransportServer;
|
import org.apache.activemq.transport.auto.AutoTcpTransportServer;
|
||||||
import org.apache.activemq.transport.nio.AutoInitNioSSLTransport;
|
import org.apache.activemq.transport.nio.AutoInitNioSSLTransport;
|
||||||
|
@ -25,6 +26,8 @@ import org.apache.activemq.transport.tcp.TcpTransportFactory;
|
||||||
import org.apache.activemq.transport.tcp.TcpTransportServer;
|
import org.apache.activemq.transport.tcp.TcpTransportServer;
|
||||||
import org.apache.activemq.util.IntrospectionSupport;
|
import org.apache.activemq.util.IntrospectionSupport;
|
||||||
import org.apache.activemq.wireformat.WireFormat;
|
import org.apache.activemq.wireformat.WireFormat;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
@ -44,6 +47,7 @@ import org.apache.activemq.wireformat.WireFormat;
|
||||||
*/
|
*/
|
||||||
public class AutoNIOSSLTransportServer extends AutoTcpTransportServer {
|
public class AutoNIOSSLTransportServer extends AutoTcpTransportServer {
|
||||||
|
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(AutoNIOSSLTransportServer.class);
|
||||||
private SSLContext context;
|
private SSLContext context;
|
||||||
|
|
||||||
public AutoNIOSSLTransportServer(SSLContext context, TcpTransportFactory transportFactory, URI location, ServerSocketFactory serverSocketFactory,
|
public AutoNIOSSLTransportServer(SSLContext context, TcpTransportFactory transportFactory, URI location, ServerSocketFactory serverSocketFactory,
|
||||||
|
@ -118,8 +122,11 @@ public class AutoNIOSSLTransportServer extends AutoTcpTransportServer {
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
in.start();
|
in.start();
|
||||||
} catch (Exception e) {
|
} catch (Exception error) {
|
||||||
throw new IllegalStateException("Could not complete Transport start", e);
|
LOG.warn("Could not accept connection {}: {} ({})",
|
||||||
|
(in.getRemoteAddress() == null ? "" : "from " + in.getRemoteAddress()), error.getMessage(),
|
||||||
|
TransportConnector.getRootCause(error).getMessage());
|
||||||
|
throw new IllegalStateException("Could not complete Transport start", error);
|
||||||
}
|
}
|
||||||
|
|
||||||
int attempts = 0;
|
int attempts = 0;
|
||||||
|
|
|
@ -654,8 +654,6 @@
|
||||||
<exclude>**/SSHTunnelNetworkReconnectTest.*</exclude>
|
<exclude>**/SSHTunnelNetworkReconnectTest.*</exclude>
|
||||||
<!-- http://issues.apache.org/activemq/browse/AMQ-1027 -->
|
<!-- http://issues.apache.org/activemq/browse/AMQ-1027 -->
|
||||||
<exclude>**/FailoverConsumerTest.*</exclude>
|
<exclude>**/FailoverConsumerTest.*</exclude>
|
||||||
<!-- The NIO implemenation is not working properly on OS X.. -->
|
|
||||||
<exclude>**/nio/**</exclude>
|
|
||||||
<exclude>**/NioQueueSubscriptionTest.*/</exclude>
|
<exclude>**/NioQueueSubscriptionTest.*/</exclude>
|
||||||
<!-- A test used for memory profiling only. -->
|
<!-- A test used for memory profiling only. -->
|
||||||
<exclude>**/NetworkConnectionsCleanedupTest.*/**</exclude>
|
<exclude>**/NetworkConnectionsCleanedupTest.*/**</exclude>
|
||||||
|
|
|
@ -117,7 +117,7 @@ public class NIOSSLBasicTest {
|
||||||
final DefaultTestAppender appender = new DefaultTestAppender() {
|
final DefaultTestAppender appender = new DefaultTestAppender() {
|
||||||
@Override
|
@Override
|
||||||
public void doAppend(LoggingEvent event) {
|
public void doAppend(LoggingEvent event) {
|
||||||
if (event.getLevel().equals(Level.ERROR) && event.getRenderedMessage().contains("Could not accept connection")) {
|
if (event.getLevel().equals(Level.WARN) && event.getRenderedMessage().contains("Could not accept connection")) {
|
||||||
gotLogMessage.countDown();
|
gotLogMessage.countDown();
|
||||||
if (event.getRenderedMessage().contains("tcp")) {
|
if (event.getRenderedMessage().contains("tcp")) {
|
||||||
// got remote address
|
// got remote address
|
||||||
|
|
|
@ -70,7 +70,7 @@ public class NIOSSLConcurrencyTest extends TestCase {
|
||||||
broker = new BrokerService();
|
broker = new BrokerService();
|
||||||
broker.setPersistent(false);
|
broker.setPersistent(false);
|
||||||
broker.setUseJmx(false);
|
broker.setUseJmx(false);
|
||||||
TransportConnector connector = broker.addConnector("nio+ssl://localhost:0?transport.needClientAuth=true&transport.enabledCipherSuites=SSL_RSA_WITH_RC4_128_SHA,SSL_DH_anon_WITH_3DES_EDE_CBC_SHA");
|
TransportConnector connector = broker.addConnector("nio+ssl://localhost:0?socket.verifyHostName=false&transport.needClientAuth=true");
|
||||||
broker.start();
|
broker.start();
|
||||||
broker.waitUntilStarted();
|
broker.waitUntilStarted();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue