Skip to content

Commit

Permalink
#8069 handled review comments again
Browse files Browse the repository at this point in the history
Signed-off-by: Ludovic Orban <[email protected]>
  • Loading branch information
lorban committed Jan 18, 2023
1 parent 8ab53b9 commit 451ead8
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,6 @@

package org.eclipse.jetty.server.handler;

import java.util.function.Function;

import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.HttpStream;
import org.eclipse.jetty.server.Request;
Expand All @@ -34,31 +32,37 @@ public abstract class AbstractLatencyRecordingHandler extends Handler.Wrapper
{
private static final Logger LOG = LoggerFactory.getLogger(AbstractLatencyRecordingHandler.class);

private final Function<HttpStream, HttpStream> recordingWrapper;

public AbstractLatencyRecordingHandler()
{
this.recordingWrapper = httpStream -> new HttpStream.Wrapper(httpStream)
}

private HttpStream recordingWrapper(HttpStream httpStream)
{
return new HttpStream.Wrapper(httpStream)
{
@Override
public void succeeded()
{
// Take the httpStream nano timestamp before calling super.
long begin = httpStream.getNanoTime();
super.succeeded();
fireOnRequestComplete();
fireOnRequestComplete(begin);
}

@Override
public void failed(Throwable x)
{
// Take the httpStream nano timestamp before calling super.
long begin = httpStream.getNanoTime();
super.failed(x);
fireOnRequestComplete();
fireOnRequestComplete(begin);
}

private void fireOnRequestComplete()
private void fireOnRequestComplete(long begin)
{
try
{
onRequestComplete(NanoTime.since(httpStream.getNanoTime()));
onRequestComplete(NanoTime.since(begin));
}
catch (Throwable t)
{
Expand All @@ -72,7 +76,7 @@ private void fireOnRequestComplete()
@Override
public boolean process(Request request, Response response, Callback callback) throws Exception
{
request.addHttpStreamWrapper(recordingWrapper);
request.addHttpStreamWrapper(this::recordingWrapper);
return super.process(request, response, callback);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@

import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.greaterThan;
import static org.hamcrest.Matchers.is;

public class LatencyRecordingHandlerTest
Expand Down Expand Up @@ -99,6 +100,10 @@ public void testLatenciesRecodingUponSuccess() throws Exception
assertThat(response, containsString(" 200 OK"));
}
Awaitility.await().atMost(5, TimeUnit.SECONDS).until(_latencies::size, is(100));
for (Long latency : _latencies)
{
assertThat(latency, greaterThan(0L));
}
}

@Test
Expand All @@ -110,5 +115,9 @@ public void testLatenciesRecodingUponFailure() throws Exception
assertThat(response, containsString(" 500 Server Error"));
}
Awaitility.await().atMost(5, TimeUnit.SECONDS).until(_latencies::size, is(100));
for (Long latency : _latencies)
{
assertThat(latency, greaterThan(0L));
}
}
}

0 comments on commit 451ead8

Please sign in to comment.