use of io.undertow.client.ClientRequest in project spring-framework by spring-projects.
the class UndertowXhrTransport method executeRequest.
protected ResponseEntity<String> executeRequest(URI url, HttpString method, HttpHeaders headers, @Nullable String body) {
CountDownLatch latch = new CountDownLatch(1);
List<ClientResponse> responses = new CopyOnWriteArrayList<>();
try {
ClientConnection connection = this.httpClient.connect(url, this.worker, this.bufferPool, this.optionMap).get();
try {
ClientRequest request = new ClientRequest().setMethod(method).setPath(url.getPath());
request.getRequestHeaders().add(HttpString.tryFromString(HttpHeaders.HOST), url.getHost());
if (StringUtils.hasLength(body)) {
HttpString headerName = HttpString.tryFromString(HttpHeaders.CONTENT_LENGTH);
request.getRequestHeaders().add(headerName, body.length());
}
addHttpHeaders(request, headers);
connection.sendRequest(request, createRequestCallback(body, responses, latch));
latch.await();
ClientResponse response = responses.iterator().next();
HttpStatus status = HttpStatus.valueOf(response.getResponseCode());
HttpHeaders responseHeaders = toHttpHeaders(response.getResponseHeaders());
String responseBody = response.getAttachment(RESPONSE_BODY);
return (responseBody != null ? new ResponseEntity<>(responseBody, responseHeaders, status) : new ResponseEntity<>(responseHeaders, status));
} finally {
IoUtils.safeClose(connection);
}
} catch (IOException ex) {
throw new SockJsTransportFailureException("Failed to execute request to " + url, ex);
} catch (InterruptedException ex) {
Thread.currentThread().interrupt();
throw new SockJsTransportFailureException("Interrupted while processing request to " + url, ex);
}
}
use of io.undertow.client.ClientRequest in project undertow by undertow-io.
the class H2CUpgradeContinuationTestCase method sendRequest.
/**
* Method that sends a GET or POST request adding count number of custom
* headers and sending contentLength data. GET is used if no content length
* is passed, POST if contentLength is greater than 0.
* @param connection The connection to use
* @param requestCount The number of requests to send
* @param headersCount The number of custom headers to send
* @param contentLength The content length to send (POST method used if >0)
* @throws Exception Some error
*/
private void sendRequest(ClientConnection connection, int requestCount, int headersCount, int contentLength) throws Exception {
final CountDownLatch latch = new CountDownLatch(requestCount);
final List<ClientResponse> responses = new CopyOnWriteArrayList<>();
StringBuilder sb = new StringBuilder();
for (int i = 0; i < contentLength; i++) {
sb.append(i % 10);
}
final String content = sb.length() > 0 ? sb.toString() : null;
connection.getIoThread().execute(new Runnable() {
@Override
public void run() {
for (int i = 0; i < requestCount; i++) {
final ClientRequest request = new ClientRequest().setMethod(contentLength > 0 ? Methods.POST : Methods.GET).setPath(ECHO_PATH);
request.getRequestHeaders().put(Headers.HOST, DefaultServer.getHostAddress());
if (contentLength > 0) {
request.getRequestHeaders().put(Headers.CONTENT_LENGTH, contentLength);
}
for (int j = 0; j < headersCount; j++) {
request.getRequestHeaders().put(new HttpString(HEADER_PREFFIX + j), HEADER_PREFFIX + j);
}
connection.sendRequest(request, createClientCallback(responses, latch, content));
}
}
});
latch.await(10, TimeUnit.SECONDS);
Assert.assertEquals("No responses received from server in 10s", requestCount, responses.size());
for (int i = 0; i < requestCount; i++) {
Assert.assertEquals("Response " + i + " code was not OK", StatusCodes.OK, responses.get(i).getResponseCode());
Assert.assertEquals("Incorrect data received for response " + i, contentLength > 0 ? content : "", responses.get(i).getAttachment(RESPONSE_BODY));
int headersReturned = 0;
for (HeaderValues header : responses.get(i).getResponseHeaders()) {
if (header.getFirst().startsWith(HEADER_PREFFIX)) {
headersReturned += header.size();
}
}
Assert.assertEquals("Incorrect number of headers returned for response " + i, headersCount, headersReturned);
}
}
use of io.undertow.client.ClientRequest in project undertow by undertow-io.
the class Http2ClientTestCase method testHeadRequest.
@Test
public void testHeadRequest() throws Exception {
//
final UndertowClient client = createClient();
final List<ClientResponse> responses = new CopyOnWriteArrayList<>();
final CountDownLatch latch = new CountDownLatch(10);
final ClientConnection connection = client.connect(ADDRESS, worker, new UndertowXnioSsl(worker.getXnio(), OptionMap.EMPTY, DefaultServer.getClientSSLContext()), DefaultServer.getBufferPool(), OptionMap.create(UndertowOptions.ENABLE_HTTP2, true)).get();
try {
connection.getIoThread().execute(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
final ClientRequest request = new ClientRequest().setMethod(Methods.HEAD).setPath(MESSAGE);
request.getRequestHeaders().put(Headers.HOST, DefaultServer.getHostAddress());
connection.sendRequest(request, createClientCallback(responses, latch));
}
}
});
latch.await(10, TimeUnit.SECONDS);
Assert.assertEquals(10, responses.size());
for (final ClientResponse response : responses) {
Assert.assertEquals("", response.getAttachment(RESPONSE_BODY));
}
} finally {
IoUtils.safeClose(connection);
}
}
use of io.undertow.client.ClientRequest in project undertow by undertow-io.
the class Http2ClientTestCase method testSimpleBasic.
@Test
public void testSimpleBasic() throws Exception {
//
final UndertowClient client = createClient();
final List<ClientResponse> responses = new CopyOnWriteArrayList<>();
final CountDownLatch latch = new CountDownLatch(10);
final ClientConnection connection = client.connect(ADDRESS, worker, new UndertowXnioSsl(worker.getXnio(), OptionMap.EMPTY, DefaultServer.getClientSSLContext()), DefaultServer.getBufferPool(), OptionMap.create(UndertowOptions.ENABLE_HTTP2, true)).get();
try {
connection.getIoThread().execute(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
final ClientRequest request = new ClientRequest().setMethod(Methods.GET).setPath(MESSAGE);
request.getRequestHeaders().put(Headers.HOST, DefaultServer.getHostAddress());
connection.sendRequest(request, createClientCallback(responses, latch));
}
}
});
latch.await(10, TimeUnit.SECONDS);
Assert.assertEquals(10, responses.size());
for (final ClientResponse response : responses) {
Assert.assertEquals(message, response.getAttachment(RESPONSE_BODY));
}
} finally {
IoUtils.safeClose(connection);
}
}
use of io.undertow.client.ClientRequest in project undertow by undertow-io.
the class AjpClientTestCase method testSendPing.
@Test
public void testSendPing() throws Exception {
//
final UndertowClient client = createClient();
final List<ClientResponse> responses = new CopyOnWriteArrayList<>();
final FutureResult<Boolean> result = new FutureResult<>();
final CountDownLatch latch = new CountDownLatch(3);
final ClientConnection connection = client.connect(ADDRESS, worker, DefaultServer.getBufferPool(), OptionMap.EMPTY).get();
assertTrue(connection.isPingSupported());
try {
connection.getIoThread().execute(() -> {
final ClientRequest request = new ClientRequest().setMethod(Methods.GET).setPath(MESSAGE);
request.getRequestHeaders().put(Headers.HOST, DefaultServer.getHostAddress());
connection.sendRequest(request, createClientCallback(responses, latch));
connection.sendPing(new ClientConnection.PingListener() {
@Override
public void acknowledged() {
result.setResult(true);
latch.countDown();
}
@Override
public void failed(IOException e) {
result.setException(e);
latch.countDown();
}
}, 5, TimeUnit.SECONDS);
connection.sendRequest(request, createClientCallback(responses, latch));
});
assertTrue(latch.await(10, TimeUnit.SECONDS));
Assert.assertEquals(2, responses.size());
assertTrue(result.getIoFuture().get());
for (final ClientResponse response : responses) {
Assert.assertEquals(message, response.getAttachment(RESPONSE_BODY));
}
// now try a failed ping
try {
undertow.stop();
final FutureResult<Boolean> failResult = new FutureResult<>();
connection.getIoThread().execute(() -> connection.sendPing(new ClientConnection.PingListener() {
@Override
public void acknowledged() {
failResult.setResult(true);
}
@Override
public void failed(IOException e) {
failResult.setException(e);
}
}, 4, TimeUnit.SECONDS));
try {
failResult.getIoFuture().get();
Assert.fail("ping should have failed");
} catch (IOException e) {
// ignored
}
} finally {
// add an extra sleep time to make sure we are not getting a BindException
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// ignore
}
undertow.start();
}
} finally {
IoUtils.safeClose(connection);
}
}
Aggregations