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
28 package org.apache.hc.core5.testing.nio.extension;
29
30 import java.util.function.Consumer;
31
32 import org.apache.hc.core5.http.impl.bootstrap.AsyncRequesterBootstrap;
33 import org.apache.hc.core5.http.impl.bootstrap.HttpAsyncRequester;
34 import org.apache.hc.core5.http.nio.ssl.BasicClientTlsStrategy;
35 import org.apache.hc.core5.io.CloseMode;
36 import org.apache.hc.core5.testing.SSLTestContexts;
37 import org.apache.hc.core5.testing.classic.LoggingConnPoolListener;
38 import org.apache.hc.core5.testing.nio.LoggingHttp1StreamListener;
39 import org.apache.hc.core5.testing.nio.LoggingIOSessionDecorator;
40 import org.apache.hc.core5.testing.nio.LoggingIOSessionListener;
41 import org.junit.jupiter.api.Assertions;
42 import org.junit.jupiter.api.extension.AfterEachCallback;
43 import org.junit.jupiter.api.extension.BeforeEachCallback;
44 import org.junit.jupiter.api.extension.ExtensionContext;
45 import org.slf4j.Logger;
46 import org.slf4j.LoggerFactory;
47
48 public class HttpAsyncRequesterResource implements BeforeEachCallback, AfterEachCallback {
49
50 private static final Logger LOG = LoggerFactory.getLogger(HttpAsyncRequesterResource.class);
51
52 private final Consumer<AsyncRequesterBootstrap> bootstrapCustomizer;
53
54 private HttpAsyncRequester requester;
55
56 public HttpAsyncRequesterResource(final Consumer<AsyncRequesterBootstrap> bootstrapCustomizer) {
57 this.bootstrapCustomizer = bootstrapCustomizer;
58 }
59
60 @Override
61 public void beforeEach(final ExtensionContext extensionContext) throws Exception {
62 LOG.debug("Starting up test client");
63 final AsyncRequesterBootstrap bootstrap = AsyncRequesterBootstrap.bootstrap()
64 .setTlsStrategy(new BasicClientTlsStrategy(SSLTestContexts.createClientSSLContext()))
65 .setMaxTotal(2)
66 .setDefaultMaxPerRoute(2)
67 .setIOSessionListener(LoggingIOSessionListener.INSTANCE)
68 .setStreamListener(LoggingHttp1StreamListener.INSTANCE_CLIENT)
69 .setConnPoolListener(LoggingConnPoolListener.INSTANCE)
70 .setIOSessionDecorator(LoggingIOSessionDecorator.INSTANCE);
71 bootstrapCustomizer.accept(bootstrap);
72 requester = bootstrap.create();
73 }
74
75 @Override
76 public void afterEach(final ExtensionContext extensionContext) throws Exception {
77 LOG.debug("Shutting down test client");
78 if (requester != null) {
79 try {
80 requester.close(CloseMode.GRACEFUL);
81 } catch (final Exception ignore) {
82 }
83 }
84 }
85
86 public HttpAsyncRequester start() {
87 Assertions.assertNotNull(requester);
88 requester.start();
89 return requester;
90 }
91
92 }