Enable client-side OpenSSL in SocketSslEchoTest

This commit is contained in:
Trustin Lee 2014-12-30 23:55:47 +09:00
parent 33cc19297a
commit d70d13091c

View File

@ -29,6 +29,8 @@ import io.netty.channel.socket.SocketChannel;
import io.netty.handler.ssl.JdkSslClientContext; import io.netty.handler.ssl.JdkSslClientContext;
import io.netty.handler.ssl.JdkSslServerContext; import io.netty.handler.ssl.JdkSslServerContext;
import io.netty.handler.ssl.OpenSsl; import io.netty.handler.ssl.OpenSsl;
import io.netty.handler.ssl.OpenSslClientContext;
import io.netty.handler.ssl.OpenSslContext;
import io.netty.handler.ssl.OpenSslServerContext; import io.netty.handler.ssl.OpenSslServerContext;
import io.netty.handler.ssl.SslContext; import io.netty.handler.ssl.SslContext;
import io.netty.handler.ssl.SslHandler; import io.netty.handler.ssl.SslHandler;
@ -123,9 +125,7 @@ public class SocketSslEchoTest extends AbstractSocketTest {
boolean hasOpenSsl = OpenSsl.isAvailable(); boolean hasOpenSsl = OpenSsl.isAvailable();
if (hasOpenSsl) { if (hasOpenSsl) {
serverContexts.add(new OpenSslServerContext(CERT_FILE, KEY_FILE)); serverContexts.add(new OpenSslServerContext(CERT_FILE, KEY_FILE));
clientContexts.add(new OpenSslClientContext(CERT_FILE));
// TODO: Client mode is not supported yet.
// clientContexts.add(new OpenSslContext(CERT_FILE));
} else { } else {
logger.warn("OpenSSL is unavailable and thus will not be tested.", OpenSsl.unavailabilityCause()); logger.warn("OpenSSL is unavailable and thus will not be tested.", OpenSsl.unavailabilityCause());
} }
@ -135,7 +135,7 @@ public class SocketSslEchoTest extends AbstractSocketTest {
for (SslContext cc: clientContexts) { for (SslContext cc: clientContexts) {
for (RenegotiationType rt: RenegotiationType.values()) { for (RenegotiationType rt: RenegotiationType.values()) {
if (rt != RenegotiationType.NONE && if (rt != RenegotiationType.NONE &&
(sc instanceof OpenSslServerContext || cc instanceof OpenSslServerContext)) { (sc instanceof OpenSslContext || cc instanceof OpenSslContext)) {
// TODO: OpenSslEngine does not support renegotiation yet. // TODO: OpenSslEngine does not support renegotiation yet.
continue; continue;
} }
@ -407,6 +407,10 @@ public class SocketSslEchoTest extends AbstractSocketTest {
@Override @Override
public final void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception { public final void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception {
if (evt instanceof SslHandshakeCompletionEvent) { if (evt instanceof SslHandshakeCompletionEvent) {
SslHandshakeCompletionEvent handshakeEvt = (SslHandshakeCompletionEvent) evt;
if (handshakeEvt.cause() != null) {
logger.warn("Handshake failed:", handshakeEvt.cause());
}
assertSame(SslHandshakeCompletionEvent.SUCCESS, evt); assertSame(SslHandshakeCompletionEvent.SUCCESS, evt);
negoCounter.incrementAndGet(); negoCounter.incrementAndGet();
logStats("HANDSHAKEN"); logStats("HANDSHAKEN");