NioUdtMessageRendezvousChannelTest Class — netty Architecture
Architecture documentation for the NioUdtMessageRendezvousChannelTest class in NioUdtMessageRendezvousChannelTest.java from the netty codebase.
Entity Profile
Dependency Diagram
graph TD 205723ff_47db_e5bb_e037_ad10fbe1146c["NioUdtMessageRendezvousChannelTest"] 8047d8bd_4e67_c18a_e2c7_bdc6763bd908["NioUdtMessageRendezvousChannelTest.java"] 205723ff_47db_e5bb_e037_ad10fbe1146c -->|defined in| 8047d8bd_4e67_c18a_e2c7_bdc6763bd908 8a9a6206_ffdc_57a0_9e1e_9f2a862e0dec["metadata()"] 205723ff_47db_e5bb_e037_ad10fbe1146c -->|method| 8a9a6206_ffdc_57a0_9e1e_9f2a862e0dec 5e2f0109_e08b_f01d_a745_629ecdaad715["basicEcho()"] 205723ff_47db_e5bb_e037_ad10fbe1146c -->|method| 5e2f0109_e08b_f01d_a745_629ecdaad715
Relationship Graph
Source Code
transport-udt/src/test/java/io/netty/test/udt/nio/NioUdtMessageRendezvousChannelTest.java lines 42–117
public class NioUdtMessageRendezvousChannelTest extends AbstractUdtTest {
private static final InternalLogger log = InternalLoggerFactory.getInstance(NioUdtByteAcceptorChannelTest.class);
/**
* verify channel meta data
*/
@Test
public void metadata() throws Exception {
assertFalse(new NioUdtMessageRendezvousChannel().metadata().hasDisconnect());
}
/**
* verify basic echo message rendezvous
*
* FIXME: Re-enable after making it pass on Windows without unncessary tight loop.
* https://github.com/netty/netty/issues/2853
*/
@Test
@Timeout(value = 10000, unit = TimeUnit.MILLISECONDS)
@Disabled
public void basicEcho() throws Exception {
final int messageSize = 64 * 1024;
final int transferLimit = messageSize * 16;
final InetSocketAddress addr1 = UnitHelp.localSocketAddress();
final InetSocketAddress addr2 = UnitHelp.localSocketAddress();
final EchoMessageHandler handler1 = new EchoMessageHandler(messageSize);
final EchoMessageHandler handler2 = new EchoMessageHandler(messageSize);
final EventLoopGroup group1 = new MultiThreadIoEventLoopGroup(
1, Executors.defaultThreadFactory(), NioIoHandler.newFactory(NioUdtProvider.MESSAGE_PROVIDER));
final EventLoopGroup group2 = new MultiThreadIoEventLoopGroup(
1, Executors.defaultThreadFactory(), NioIoHandler.newFactory(NioUdtProvider.MESSAGE_PROVIDER));
final Bootstrap boot1 = new Bootstrap();
boot1.group(group1)
.channelFactory(NioUdtProvider.MESSAGE_RENDEZVOUS)
.localAddress(addr1).remoteAddress(addr2).handler(handler1);
final Bootstrap boot2 = new Bootstrap();
boot2.group(group2)
.channelFactory(NioUdtProvider.MESSAGE_RENDEZVOUS)
.localAddress(addr2).remoteAddress(addr1).handler(handler2);
final ChannelFuture connectFuture1 = boot1.connect();
final ChannelFuture connectFuture2 = boot2.connect();
while (handler1.counter() < transferLimit
&& handler2.counter() < transferLimit) {
log.info("progress : {} {}", handler1.counter(), handler2.counter());
Thread.sleep(1000);
}
connectFuture1.channel().close().sync();
connectFuture2.channel().close().sync();
log.info("handler1 : {}", handler1.counter());
log.info("handler2 : {}", handler2.counter());
assertTrue(handler1.counter() >= transferLimit);
assertTrue(handler2.counter() >= transferLimit);
assertEquals(handler1.counter(), handler2.counter());
group1.shutdownGracefully();
group2.shutdownGracefully();
group1.terminationFuture().sync();
group2.terminationFuture().sync();
}
}
Defined In
Source
Frequently Asked Questions
What is the NioUdtMessageRendezvousChannelTest class?
NioUdtMessageRendezvousChannelTest is a class in the netty codebase, defined in transport-udt/src/test/java/io/netty/test/udt/nio/NioUdtMessageRendezvousChannelTest.java.
Where is NioUdtMessageRendezvousChannelTest defined?
NioUdtMessageRendezvousChannelTest is defined in transport-udt/src/test/java/io/netty/test/udt/nio/NioUdtMessageRendezvousChannelTest.java at line 42.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free