Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/jetty-12.0.x' into jetty-12.1.x
Browse files Browse the repository at this point in the history
  • Loading branch information
joakime committed Oct 30, 2024
2 parents c534ac5 + 17e5820 commit d6eb403
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 26 deletions.
5 changes: 5 additions & 0 deletions jetty-core/jetty-server/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,11 @@
<artifactId>jetty-slf4j-impl</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-slf4j-impl</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-util-ajax</artifactId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ public static CompletableFuture<Fields> from(Request request)
public static CompletableFuture<Fields> from(Request request, Charset charset)
{
int maxFields = getContextAttribute(request.getContext(), FormFields.MAX_FIELDS_ATTRIBUTE, FormFields.MAX_FIELDS_DEFAULT);
int maxLength = getContextAttribute(request.getContext(), FormFields.MAX_LENGTH_ATTRIBUTE, FormFields.MAX_FIELDS_DEFAULT);
int maxLength = getContextAttribute(request.getContext(), FormFields.MAX_LENGTH_ATTRIBUTE, FormFields.MAX_LENGTH_DEFAULT);
return from(request, charset, maxFields, maxLength);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,14 +147,15 @@ public void setShowHeaders(boolean showHeaders)
public boolean handle(Request request, Response response, Callback callback) throws Exception
{
Thread thread = Thread.currentThread();
String name = thread.getName() + ":" + request.getHttpURI();
String name = thread.getName() + ":" + request.getHttpURI().getPathQuery();
boolean willHandle = false;
Throwable ex = null;
String rname = findRequestName(request);
HandlingCallback handlingCallback = new HandlingCallback(callback, request, response);

try
{
thread.setName(name);
String headers = _showHeaders ? ("\n" + request.getHeaders().toString()) : "";

log(">> r=%s %s %s %s %s %s",
Expand All @@ -164,7 +165,6 @@ public boolean handle(Request request, Response response, Callback callback) thr
request.getConnectionMetaData().getProtocol(),
request.getConnectionMetaData(),
headers);
thread.setName(name);

willHandle = getHandler().handle(request, response, handlingCallback);
return willHandle;
Expand Down Expand Up @@ -195,10 +195,11 @@ protected void log(String format, Object... arg)

String s = String.format(format, arg);

String threadName = Thread.currentThread().getName();
long now = System.currentTimeMillis();
long ms = now % 1000;
if (_print != null)
_print.printf("%s.%03d:%s%n", __date.format(now), ms, s);
_print.printf("%s.%03d:%s:%s%n", __date.format(now), ms, threadName, s);
}

protected String findRequestName(Request request)
Expand All @@ -218,7 +219,6 @@ protected String findRequestName(Request request)
}
catch (IllegalStateException e)
{
// TODO can we avoid creating and catching this exception? see #8024
// Handle the case when the request has already been completed
return String.format("%s@%x", request.getHttpURI(), request.hashCode());
}
Expand All @@ -234,7 +234,7 @@ protected void doStart() throws Exception
for (Connector connector : getServer().getConnectors())
{
if (connector instanceof AbstractConnector)
((AbstractConnector)connector).addBean(this, false);
connector.addBean(this, false);
}

super.doStart();
Expand All @@ -248,7 +248,7 @@ protected void doStop() throws Exception
for (Connector connector : getServer().getConnectors())
{
if (connector instanceof AbstractConnector)
((AbstractConnector)connector).removeBean(this);
connector.removeBean(this);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import java.net.HttpURLConnection;
import java.net.URI;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.security.KeyStore;
import java.util.concurrent.TimeUnit;
Expand All @@ -28,31 +29,32 @@
import javax.net.ssl.TrustManagerFactory;

import org.eclipse.jetty.io.ArrayByteBufferPool;
import org.eclipse.jetty.io.IOResources;
import org.eclipse.jetty.server.AbstractConnectionFactory;
import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.HttpConnectionFactory;
import org.eclipse.jetty.server.Request;
import org.eclipse.jetty.server.Response;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.server.ServerConnector;
import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
import org.eclipse.jetty.toolchain.test.MavenPaths;
import org.eclipse.jetty.util.Callback;
import org.eclipse.jetty.util.component.LifeCycle;
import org.eclipse.jetty.util.ssl.SslContextFactory;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import static org.awaitility.Awaitility.await;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.is;
import static org.hamcrest.Matchers.not;

public class DebugHandlerTest
{
public static final String INBOUND_STARTS_WITH = ">> r=";
public static final String OUTBOUND_STARTS_WITH = "<< r=";
private static final Logger LOG = LoggerFactory.getLogger(DebugHandlerTest.class);
public static final HostnameVerifier __hostnameverifier = (hostname, session) -> true;

private SSLContext sslContext;
Expand All @@ -75,7 +77,7 @@ public void startServer() throws Exception
httpConnector.setPort(0);
server.addConnector(httpConnector);

Path keystorePath = MavenTestingUtils.getTestResourcePath("keystore.p12");
Path keystorePath = MavenPaths.findTestResourceFile("keystore.p12");
SslContextFactory.Server sslContextFactory = new SslContextFactory.Server();
sslContextFactory.setKeyStorePath(keystorePath.toAbsolutePath().toString());
sslContextFactory.setKeyStorePassword("storepwd");
Expand All @@ -88,17 +90,19 @@ public void startServer() throws Exception
debugHandler = new DebugHandler();
capturedLog = new ByteArrayOutputStream();
debugHandler.setOutputStream(capturedLog);
server.setHandler(new Handler.Abstract()
debugHandler.setHandler(new Handler.Abstract()
{

@Override
public boolean handle(Request request, Response response, Callback callback) throws Exception
{
LOG.info("Abstract handle()");
response.setStatus(200);
callback.succeeded();
return true;
}
});
server.insertHandler(debugHandler);
server.setHandler(debugHandler);

server.start();

Expand All @@ -108,9 +112,15 @@ public boolean handle(Request request, Response response, Callback callback) thr

serverURI = URI.create(String.format("http://%s:%d/", host, httpConnector.getLocalPort()));
secureServerURI = URI.create(String.format("https://%s:%d/", host, sslConnector.getLocalPort()));
}

@BeforeEach
public void trustAllHttpsUrlConnection() throws Exception
{
Path keystorePath = MavenPaths.findTestResourceFile("keystore.p12");

KeyStore keystore = KeyStore.getInstance(KeyStore.getDefaultType());
try (InputStream stream = IOResources.asInputStream(sslContextFactory.getKeyStoreResource()))
try (InputStream stream = Files.newInputStream(keystorePath))
{
keystore.load(stream, "storepwd".toCharArray());
}
Expand Down Expand Up @@ -148,27 +158,30 @@ public void stopServer() throws Exception
}

@Test
public void testDebugInboundOutboundMessages() throws IOException
public void testThreadName() throws IOException
{
HttpURLConnection http = (HttpURLConnection)serverURI.resolve("/foo/bar?a=b").toURL().openConnection();
assertThat("Response Code", http.getResponseCode(), is(200));

String log = capturedLog.toString(StandardCharsets.UTF_8.name());

assertThat("Inbound", log, containsString(INBOUND_STARTS_WITH));
assertThat("Outbound", log, containsString(OUTBOUND_STARTS_WITH));
String log = capturedLog.toString(StandardCharsets.UTF_8);
String expectedThreadName = ":/foo/bar?a=b";
assertThat("ThreadName", log, containsString(expectedThreadName));
// Look for bad/mangled/duplicated schemes
assertThat("ThreadName", log, not(containsString("http:" + expectedThreadName)));
assertThat("ThreadName", log, not(containsString("https:" + expectedThreadName)));
}

@Test
public void testSecureInboundOutboundMessages() throws IOException
public void testSecureThreadName() throws IOException
{
HttpURLConnection http = (HttpURLConnection)secureServerURI.resolve("/foo/bar?a=b").toURL().openConnection();
assertThat("Response Code", http.getResponseCode(), is(200));

String log = capturedLog.toString(StandardCharsets.UTF_8.name());
System.err.println("****" + log + "******");

assertThat("Inbound", log, containsString(INBOUND_STARTS_WITH));
assertThat("Outbound", log, containsString(OUTBOUND_STARTS_WITH));
String log = capturedLog.toString(StandardCharsets.UTF_8);
String expectedThreadName = ":/foo/bar?a=b";
assertThat("ThreadName", log, containsString(expectedThreadName));
// Look for bad/mangled/duplicated schemes
assertThat("ThreadName", log, not(containsString("http:" + expectedThreadName)));
assertThat("ThreadName", log, not(containsString("https:" + expectedThreadName)));
}
}

0 comments on commit d6eb403

Please sign in to comment.