Set timeout for SocketSslEchoTest
Motivation: We are seeing EpollSocketSslEchoTest does not finish itself while its I/O thread is busy. Jenkins should have terminated them when the global build timeout reaches, but Jenkins seems to fail to do so. What's more interesting is that Jenkins will start another job before the EpollSocketSslEchoTest is terminated, and Linux starts to oom-kill them, impacting the uptime of the CI service. Modifications: - Set timeout for all test cases in SocketSslEchoTest so that all SSL tests terminate themselves when they take too long. - Fix a bug where the epoll testsuite uses non-daemon threads which can potentially prevent JVM from quitting. - (Cleanup) Separate boss group and worker group just like we do for NIO/OIO transport testsuite. Result: Potentially more stable CI machine.
This commit is contained in:
parent
c4bb0ea926
commit
92f0a0310d
@ -75,7 +75,7 @@ public class SocketSslEchoTest extends AbstractSocketTest {
|
|||||||
this.useCompositeByteBuf = useCompositeByteBuf;
|
this.useCompositeByteBuf = useCompositeByteBuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test(timeout = 30000)
|
||||||
public void testSslEcho() throws Throwable {
|
public void testSslEcho() throws Throwable {
|
||||||
run();
|
run();
|
||||||
}
|
}
|
||||||
@ -84,7 +84,7 @@ public class SocketSslEchoTest extends AbstractSocketTest {
|
|||||||
testSslEcho(sb, cb, true);
|
testSslEcho(sb, cb, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test(timeout = 30000)
|
||||||
public void testSslEchoNotAutoRead() throws Throwable {
|
public void testSslEchoNotAutoRead() throws Throwable {
|
||||||
run();
|
run();
|
||||||
}
|
}
|
||||||
|
@ -18,24 +18,35 @@ package io.netty.channel.epoll;
|
|||||||
import io.netty.bootstrap.Bootstrap;
|
import io.netty.bootstrap.Bootstrap;
|
||||||
import io.netty.bootstrap.ServerBootstrap;
|
import io.netty.bootstrap.ServerBootstrap;
|
||||||
import io.netty.channel.EventLoopGroup;
|
import io.netty.channel.EventLoopGroup;
|
||||||
|
import io.netty.channel.nio.NioEventLoopGroup;
|
||||||
import io.netty.testsuite.transport.TestsuitePermutation;
|
import io.netty.testsuite.transport.TestsuitePermutation;
|
||||||
|
import io.netty.util.concurrent.DefaultThreadFactory;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
final class EpollTestUtils {
|
final class EpollTestUtils {
|
||||||
private static final EventLoopGroup GROUP = new EpollEventLoopGroup();
|
|
||||||
|
private static final int BOSSES = 2;
|
||||||
|
private static final int WORKERS = 3;
|
||||||
|
|
||||||
|
private static final EventLoopGroup epollBossGroup =
|
||||||
|
new NioEventLoopGroup(BOSSES, new DefaultThreadFactory("testsuite-epoll-boss", true));
|
||||||
|
private static final EventLoopGroup epollWorkerGroup =
|
||||||
|
new NioEventLoopGroup(WORKERS, new DefaultThreadFactory("testsuite-epoll-worker", true));
|
||||||
|
|
||||||
static List<TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>> newFactories() {
|
static List<TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>> newFactories() {
|
||||||
return Collections.<TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>>singletonList(
|
return Collections.<TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>>singletonList(
|
||||||
new TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>() {
|
new TestsuitePermutation.BootstrapComboFactory<ServerBootstrap, Bootstrap>() {
|
||||||
@Override
|
@Override
|
||||||
public ServerBootstrap newServerInstance() {
|
public ServerBootstrap newServerInstance() {
|
||||||
return new ServerBootstrap().group(GROUP).channel(EpollServerSocketChannel.class);
|
return new ServerBootstrap().group(
|
||||||
|
epollBossGroup, epollWorkerGroup).channel(EpollServerSocketChannel.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Bootstrap newClientInstance() {
|
public Bootstrap newClientInstance() {
|
||||||
return new Bootstrap().group(GROUP).channel(EpollSocketChannel.class);
|
return new Bootstrap().group(epollWorkerGroup).channel(EpollSocketChannel.class);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user