View Javadoc
1   /*
2    * ====================================================================
3    * Licensed to the Apache Software Foundation (ASF) under one
4    * or more contributor license agreements.  See the NOTICE file
5    * distributed with this work for additional information
6    * regarding copyright ownership.  The ASF licenses this file
7    * to you under the Apache License, Version 2.0 (the
8    * "License"); you may not use this file except in compliance
9    * with the License.  You may obtain a copy of the License at
10   *
11   *   http://www.apache.org/licenses/LICENSE-2.0
12   *
13   * Unless required by applicable law or agreed to in writing,
14   * software distributed under the License is distributed on an
15   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16   * KIND, either express or implied.  See the License for the
17   * specific language governing permissions and limitations
18   * under the License.
19   * ====================================================================
20   *
21   * This software consists of voluntary contributions made by many
22   * individuals on behalf of the Apache Software Foundation.  For more
23   * information on the Apache Software Foundation, please see
24   * <http://www.apache.org/>.
25   *
26   */
27  package org.apache.hc.core5.reactor;
28  
29  import java.net.InetSocketAddress;
30  
31  import org.apache.hc.core5.util.TimeValue;
32  import org.apache.hc.core5.util.Timeout;
33  import org.junit.Assert;
34  import org.junit.Test;
35  
36  public class IOReactorConfigTest {
37      @Test
38      public void testCustomIOReactorConfig() throws Exception {
39          final IOReactorConfig reactorConfig = IOReactorConfig.custom()
40                  .setSelectInterval(TimeValue.ofMilliseconds(500))
41                  .setIoThreadCount(2)
42                  .setSoTimeout(Timeout.ofSeconds(10))
43                  .setSoReuseAddress(true)
44                  .setSoLinger(TimeValue.ofSeconds(30))
45                  .setSoKeepAlive(true)
46                  .setTcpNoDelay(false)
47                  .setTrafficClass(0x02)
48                  .setSndBufSize(32767)
49                  .setRcvBufSize(8192)
50                  .setBacklogSize(5)
51                  .setSocksProxyAddress(new InetSocketAddress(8888))
52                  .setSocksProxyUsername("socksProxyUsername")
53                  .setSocksProxyPassword("socksProxyPassword")
54                  .build();
55  
56          Assert.assertEquals(TimeValue.ofMilliseconds(500), reactorConfig.getSelectInterval());
57          Assert.assertEquals(2, reactorConfig.getIoThreadCount());
58          Assert.assertEquals(Timeout.ofSeconds(10), reactorConfig.getSoTimeout());
59          Assert.assertEquals(true, reactorConfig.isSoReuseAddress());
60          Assert.assertEquals(TimeValue.ofSeconds(30), reactorConfig.getSoLinger());
61          Assert.assertEquals(true, reactorConfig.isSoKeepalive());
62          Assert.assertEquals(false, reactorConfig.isTcpNoDelay());
63          Assert.assertEquals(0x02, reactorConfig.getTrafficClass());
64          Assert.assertEquals(32767, reactorConfig.getSndBufSize());
65          Assert.assertEquals(8192, reactorConfig.getRcvBufSize());
66          Assert.assertEquals(5, reactorConfig.getBacklogSize());
67          Assert.assertEquals(new InetSocketAddress(8888), reactorConfig.getSocksProxyAddress());
68          Assert.assertEquals("socksProxyUsername", reactorConfig.getSocksProxyUsername());
69          Assert.assertEquals("socksProxyPassword", reactorConfig.getSocksProxyPassword());
70      }
71  }