1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 package org.apache.hc.client5.testing.async;
28
29 import java.util.concurrent.ExecutionException;
30 import java.util.concurrent.Future;
31 import java.util.concurrent.TimeUnit;
32
33 import javax.net.ssl.SSLException;
34
35 import org.apache.hc.client5.http.impl.async.MinimalHttpAsyncClient;
36 import org.apache.hc.client5.http.impl.nio.PoolingAsyncClientConnectionManager;
37 import org.apache.hc.client5.http.ssl.DefaultClientTlsStrategy;
38 import org.apache.hc.client5.testing.extension.async.ClientProtocolLevel;
39 import org.apache.hc.client5.testing.extension.async.ServerProtocolLevel;
40 import org.apache.hc.core5.http.HttpHost;
41 import org.apache.hc.core5.http.URIScheme;
42 import org.apache.hc.core5.http.nio.AsyncClientEndpoint;
43 import org.apache.hc.core5.ssl.SSLContexts;
44 import org.junit.jupiter.api.Assertions;
45 import org.junit.jupiter.api.Test;
46
47 class TestHttpAsyncMinimalTlsHandshake extends AbstractIntegrationTestBase {
48
49 public TestHttpAsyncMinimalTlsHandshake() {
50 super(URIScheme.HTTPS, ClientProtocolLevel.MINIMAL, ServerProtocolLevel.STANDARD);
51 }
52
53 @Test
54 void testSuccessfulTlsHandshake() throws Exception {
55 final HttpHost target = startServer();
56
57 final int maxConnNo = 2;
58 final PoolingAsyncClientConnectionManager connectionManager = startClient().getConnectionManager();
59 connectionManager.setDefaultMaxPerRoute(maxConnNo);
60 connectionManager.setMaxTotal(maxConnNo);
61
62 final MinimalHttpAsyncClient client = startClient().getImplementation();
63
64 for (int i = 0; i < maxConnNo + 1; i++) {
65 final Future<AsyncClientEndpoint> endpointLease = client.lease(target, null);
66 final AsyncClientEndpoint endpoint = endpointLease.get(5, TimeUnit.SECONDS);
67 endpoint.releaseAndDiscard();
68 }
69 }
70
71 @Test
72 void testTlsHandshakeFailure() throws Exception {
73 final HttpHost target = startServer();
74
75 configureClient(builder ->
76 builder.setTlsStrategy(new DefaultClientTlsStrategy(SSLContexts.createDefault())));
77
78 final int maxConnNo = 2;
79 final PoolingAsyncClientConnectionManager connectionManager = startClient().getConnectionManager();
80 connectionManager.setDefaultMaxPerRoute(maxConnNo);
81 connectionManager.setMaxTotal(maxConnNo);
82
83 final MinimalHttpAsyncClient client = startClient().getImplementation();
84
85 for (int i = 0; i < maxConnNo + 1; i++) {
86 final Future<AsyncClientEndpoint> endpointLease = client.lease(target, null);
87 final ExecutionException executionException = Assertions.assertThrows(ExecutionException.class,
88 () -> endpointLease.get(5, TimeUnit.SECONDS));
89 Assertions.assertInstanceOf(SSLException.class, executionException.getCause());
90 }
91 }
92
93 }