From c490a10621427d41e5b35edd3b4c72009518b794 Mon Sep 17 00:00:00 2001 From: Lachlan Roberts Date: Wed, 16 Jun 2021 11:11:13 +1000 Subject: [PATCH 1/2] Issue #6383 - Fix flaky test FileBufferedResponseHandlerTest Signed-off-by: Lachlan Roberts --- .../handler/BufferedResponseHandler.java | 2 +- .../handler/FileBufferedResponseHandler.java | 4 +-- .../FileBufferedResponseHandlerTest.java | 33 ++++++++++++++++++- 3 files changed, 35 insertions(+), 4 deletions(-) diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java index 85f3e0ed1a00..f21528ef460f 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java @@ -209,7 +209,7 @@ protected interface BufferedInterceptor extends HttpOutput.Interceptor { } - private class ArrayBufferedInterceptor implements BufferedInterceptor + protected class ArrayBufferedInterceptor implements BufferedInterceptor { private final Interceptor _next; private final HttpChannel _channel; diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java index 85b32492abc4..5b72a82edd18 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java @@ -76,7 +76,7 @@ protected BufferedInterceptor newBufferedInterceptor(HttpChannel httpChannel, In return new FileBufferedInterceptor(httpChannel, interceptor); } - private class FileBufferedInterceptor implements BufferedResponseHandler.BufferedInterceptor + protected class FileBufferedInterceptor implements BufferedResponseHandler.BufferedInterceptor { private static final int MAX_MAPPED_BUFFER_SIZE = Integer.MAX_VALUE / 2; @@ -111,7 +111,7 @@ public void resetBuffer() BufferedInterceptor.super.resetBuffer(); } - private void dispose() + protected void dispose() { IO.close(_fileOutputStream); _fileOutputStream = null; diff --git a/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java b/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java index 3f6fb80306c7..e68ce943930e 100644 --- a/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java +++ b/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java @@ -30,6 +30,7 @@ import java.time.Duration; import java.util.Random; import java.util.concurrent.CompletableFuture; +import java.util.concurrent.CountDownLatch; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicLong; import javax.servlet.ServletException; @@ -63,6 +64,7 @@ public class FileBufferedResponseHandlerTest { private static final Logger LOG = Log.getLogger(FileBufferedResponseHandlerTest.class); + private final CountDownLatch _disposeLatch = new CountDownLatch(1); private Server _server; private LocalConnector _localConnector; private ServerConnector _serverConnector; @@ -86,7 +88,22 @@ public void before() throws Exception _serverConnector = new ServerConnector(_server, new HttpConnectionFactory(config)); _server.addConnector(_serverConnector); - _bufferedHandler = new FileBufferedResponseHandler(); + _bufferedHandler = new FileBufferedResponseHandler() + { + @Override + protected BufferedInterceptor newBufferedInterceptor(HttpChannel httpChannel, HttpOutput.Interceptor interceptor) + { + return new FileBufferedInterceptor(httpChannel, interceptor) + { + @Override + protected void dispose() + { + super.dispose(); + _disposeLatch.countDown(); + } + }; + } + }; _bufferedHandler.setTempDir(_testDir); _bufferedHandler.getPathIncludeExclude().include("/include/*"); _bufferedHandler.getPathIncludeExclude().exclude("*.exclude"); @@ -157,6 +174,8 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(response.getStatus(), is(HttpStatus.OK_200)); assertThat(responseContent, containsString("Committed: false")); assertThat(responseContent, containsString("NumFiles: 1")); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -249,6 +268,8 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(responseContent, containsString("NumFilesBeforeFlush: 0")); assertThat(responseContent, containsString("Committed: false")); assertThat(responseContent, containsString("NumFiles: 1")); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -279,6 +300,8 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(response.getStatus(), is(HttpStatus.OK_200)); assertThat(responseContent, not(containsString("writtenAfterClose"))); assertThat(responseContent, containsString("NumFiles: 1")); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -339,6 +362,8 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques // The flush should not create the file unless there is content to write. assertThat(response.getStatus(), is(HttpStatus.OK_200)); assertThat(responseContent, containsString("NumFiles: 0")); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -378,6 +403,8 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(responseContent, containsString("NumFilesBeforeReset: 1")); assertThat(responseContent, containsString("NumFilesAfterReset: 0")); assertThat(responseContent, containsString("NumFilesAfterWrite: 1")); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -451,6 +478,8 @@ public boolean content(ByteBuffer ref) assertThat(response.get("NumFiles"), is("1")); assertThat(response.get("FileSize"), is(Long.toString(fileSize))); assertThat(received.get(), is(fileSize)); + + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -531,6 +560,7 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(error.getMessage(), containsString("intentionally throwing from interceptor")); // All files were deleted. + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } @@ -579,6 +609,7 @@ public void handle(String target, Request baseRequest, HttpServletRequest reques assertThat(error, instanceOf(NoSuchFileException.class)); // No files were created. + assertTrue(_disposeLatch.await(5, TimeUnit.SECONDS)); assertThat(getNumFiles(), is(0)); } From e14047839d3d48a39f993111a22527b8351a7128 Mon Sep 17 00:00:00 2001 From: Lachlan Roberts Date: Fri, 18 Jun 2021 09:47:35 +1000 Subject: [PATCH 2/2] Issue #6383 - Make FileBufferedInterceptor package private Signed-off-by: Lachlan Roberts --- .../server/handler/BufferedResponseHandler.java | 2 +- .../server/handler/FileBufferedResponseHandler.java | 2 +- .../FileBufferedResponseHandlerTest.java | 13 +++++++++---- 3 files changed, 11 insertions(+), 6 deletions(-) rename jetty-server/src/test/java/org/eclipse/jetty/server/{ => handler}/FileBufferedResponseHandlerTest.java (98%) diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java index f21528ef460f..309f0aa459db 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/BufferedResponseHandler.java @@ -209,7 +209,7 @@ protected interface BufferedInterceptor extends HttpOutput.Interceptor { } - protected class ArrayBufferedInterceptor implements BufferedInterceptor + class ArrayBufferedInterceptor implements BufferedInterceptor { private final Interceptor _next; private final HttpChannel _channel; diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java index 5b72a82edd18..ad82ed53292e 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandler.java @@ -76,7 +76,7 @@ protected BufferedInterceptor newBufferedInterceptor(HttpChannel httpChannel, In return new FileBufferedInterceptor(httpChannel, interceptor); } - protected class FileBufferedInterceptor implements BufferedResponseHandler.BufferedInterceptor + class FileBufferedInterceptor implements BufferedResponseHandler.BufferedInterceptor { private static final int MAX_MAPPED_BUFFER_SIZE = Integer.MAX_VALUE / 2; diff --git a/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java b/jetty-server/src/test/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandlerTest.java similarity index 98% rename from jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java rename to jetty-server/src/test/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandlerTest.java index e68ce943930e..567616379a1b 100644 --- a/jetty-server/src/test/java/org/eclipse/jetty/server/FileBufferedResponseHandlerTest.java +++ b/jetty-server/src/test/java/org/eclipse/jetty/server/handler/FileBufferedResponseHandlerTest.java @@ -16,7 +16,7 @@ // ======================================================================== // -package org.eclipse.jetty.server; +package org.eclipse.jetty.server.handler; import java.io.File; import java.io.IOException; @@ -40,9 +40,14 @@ import org.eclipse.jetty.http.HttpStatus; import org.eclipse.jetty.http.HttpTester; -import org.eclipse.jetty.server.handler.AbstractHandler; -import org.eclipse.jetty.server.handler.FileBufferedResponseHandler; -import org.eclipse.jetty.server.handler.HandlerCollection; +import org.eclipse.jetty.server.HttpChannel; +import org.eclipse.jetty.server.HttpConfiguration; +import org.eclipse.jetty.server.HttpConnectionFactory; +import org.eclipse.jetty.server.HttpOutput; +import org.eclipse.jetty.server.LocalConnector; +import org.eclipse.jetty.server.Request; +import org.eclipse.jetty.server.Server; +import org.eclipse.jetty.server.ServerConnector; import org.eclipse.jetty.toolchain.test.FS; import org.eclipse.jetty.toolchain.test.MavenTestingUtils; import org.eclipse.jetty.util.Callback;