@Override public void logRequest(RawHttpRequest request, RawHttpResponse<?> response) { executor.submit(() -> { if (request.getSenderAddress().isPresent()) { InetAddress senderAddress = request.getSenderAddress().get(); System.out.print(senderAddress.getHostAddress() + " "); } Long bytes = response.getBody() .map(b -> b.getLengthIfKnown().orElse(-1L)) .orElse(-1L); System.out.println("[" + LocalDateTime.now().format(dateFormat) + "] \"" + request.getStartLine() + "\" " + response.getStatusCode() + " " + bytes); }); }
.withBody(new StreamedChunkedBody(sender.getChunkStream()))); if (response.getStatusCode() != 200) { if (client instanceof Closeable) { ((Closeable) client).close(); throw new RuntimeException("Server response status code is not 200: " + response.getStatusCode());
@Test public void sendRawRequest() throws IOException { RawHttp http = new RawHttp(); RawHttpRequest request = http.parseRequest( "GET / HTTP/1.1\r\n" + "Host: headers.jsontest.com\r\n" + "User-Agent: RawHTTP\r\n" + "Accept: application/json"); Socket socket = new Socket("headers.jsontest.com", 80); request.writeTo(socket.getOutputStream()); // get the response RawHttpResponse<?> response = http.parseResponse(socket.getInputStream()); assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent()); String textBody = response.getBody().get().decodeBodyToString(UTF_8); assertTrue(textBody.contains("\"User-Agent\": \"RawHTTP\"")); }
assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent()); assertEquals("Hello RawHTTP!", response.getBody().get().decodeBodyToString(UTF_8));
@Test public void useHttpServer() throws InterruptedException, IOException { RawHttpServer server = new TcpRawHttpServer(8086); RawHttp http = new RawHttp(); server.start(request -> { System.out.println("Got Request:\n" + request); String body = "Hello RawHTTP!"; String dateString = RFC_1123_DATE_TIME.format(ZonedDateTime.now(ZoneOffset.UTC)); RawHttpResponse<?> response = http.parseResponse("HTTP/1.1 200 OK\r\n" + "Content-Type: plain/text\r\n" + "Content-Length: " + body.length() + "\r\n" + "Server: RawHTTP\r\n" + "Date: " + dateString + "\r\n" + "\r\n" + body); return Optional.of(response); }); // wait for the socket get bound Thread.sleep(150L); RawHttpRequest request = http.parseRequest("GET /\r\nHost: localhost"); Socket socket = new Socket(InetAddress.getLoopbackAddress(), 8086); request.writeTo(socket.getOutputStream()); // get the response RawHttpResponse<?> response = http.parseResponse(socket.getInputStream()).eagerly(); System.out.println("RESPONSE:\n" + response); assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent()); assertEquals("Hello RawHTTP!", response.getBody().get().decodeBodyToString(UTF_8)); server.stop(); }
@Test public void requestWithTcpRawHttpClient() throws IOException { TcpRawHttpClient client = new TcpRawHttpClient(); RawHttp http = new RawHttp(); RawHttpRequest request = http.parseRequest( "GET / HTTP/1.1\r\n" + "Host: headers.jsontest.com\r\n" + "User-Agent: RawHTTP\r\n" + "Accept: application/json"); RawHttpResponse<?> response = client.send(request); assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent()); String textBody = response.getBody().get().decodeBodyToString(UTF_8); assertTrue(textBody.contains("\"User-Agent\": \"RawHTTP\"")); client.close(); }
System.out.println("RESPONSE:\n" + response); assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent());
assertEquals(200, response.getStatusCode()); assertTrue(response.getBody().isPresent()); String textBody = response.getBody().get().decodeBodyToString(UTF_8);