View Javadoc
1   /*
2    * Copyright 2013 The Netty Project
3    *
4    * The Netty Project licenses this file to you under the Apache License,
5    * version 2.0 (the "License"); you may not use this file except in compliance
6    * with the License. You may obtain a copy of the License at:
7    *
8    *   https://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13   * License for the specific language governing permissions and limitations
14   * under the License.
15   */
16  package io.netty5.testsuite.transport.socket;
17  
18  import io.netty5.bootstrap.Bootstrap;
19  import io.netty5.buffer.api.DefaultBufferAllocators;
20  import io.netty5.channel.ChannelHandler;
21  import io.netty5.channel.ChannelHandlerContext;
22  import io.netty5.channel.socket.SocketChannel;
23  import org.junit.jupiter.api.Test;
24  import org.junit.jupiter.api.TestInfo;
25  import org.junit.jupiter.api.Timeout;
26  
27  import java.util.concurrent.TimeUnit;
28  
29  public class WriteBeforeRegisteredTest extends AbstractClientSocketTest {
30      @Test
31      @Timeout(value = 30000, unit = TimeUnit.MILLISECONDS)
32      public void testWriteBeforeConnect(TestInfo testInfo) throws Throwable {
33          run(testInfo, this::testWriteBeforeConnect);
34      }
35  
36      public void testWriteBeforeConnect(Bootstrap cb) throws Throwable {
37          TestHandler h = new TestHandler();
38          SocketChannel ch = null;
39          try {
40              cb.handler(h);
41              ch = (SocketChannel) cb.createUnregistered();
42              ch.writeAndFlush(DefaultBufferAllocators.preferredAllocator().copyOf(new byte[] { 1 }));
43              ch.register().asStage().sync();
44              ch.connect(newSocketAddress());
45          } finally {
46              if (ch != null) {
47                  ch.close();
48              }
49          }
50      }
51  
52      private static class TestHandler implements ChannelHandler {
53          @Override
54          public void channelExceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
55              cause.printStackTrace();
56          }
57      }
58  }