Merge branch 'jetty-10.0.x' into jetty-10.0.x-3167-websocket-mapping
Signed-off-by: Greg Wilkins <gregw@webtide.com>
This commit is contained in:
commit
4a70d1534e
|
@ -100,7 +100,7 @@ abstract public class WriteFlusher
|
||||||
* @param previous the expected current state
|
* @param previous the expected current state
|
||||||
* @param next the desired new state
|
* @param next the desired new state
|
||||||
* @return the previous state or null if the state transition failed
|
* @return the previous state or null if the state transition failed
|
||||||
* @throws WritePendingException if currentState is WRITING and new state is WRITING (api usage error)
|
* @throws IllegalStateException if previous to next is not a legal state transition (api usage error)
|
||||||
*/
|
*/
|
||||||
private boolean updateState(State previous, State next)
|
private boolean updateState(State previous, State next)
|
||||||
{
|
{
|
||||||
|
|
|
@ -32,7 +32,6 @@ import org.eclipse.jetty.client.HttpClient;
|
||||||
import org.eclipse.jetty.client.api.ContentResponse;
|
import org.eclipse.jetty.client.api.ContentResponse;
|
||||||
import org.eclipse.jetty.http.HttpStatus;
|
import org.eclipse.jetty.http.HttpStatus;
|
||||||
import org.eclipse.jetty.server.handler.ContextHandler;
|
import org.eclipse.jetty.server.handler.ContextHandler;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -81,19 +80,14 @@ public class TestJettyOSGiBootContextAsService
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
public void assertAllBundlesActiveOrResolved()
|
|
||||||
{
|
|
||||||
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testContextHandlerAsOSGiService() throws Exception
|
public void testContextHandlerAsOSGiService() throws Exception
|
||||||
{
|
{
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
||||||
|
|
||||||
// now test the context
|
// now test the context
|
||||||
HttpClient client = new HttpClient();
|
HttpClient client = new HttpClient();
|
||||||
try
|
try
|
||||||
|
|
|
@ -40,7 +40,6 @@ import org.eclipse.jetty.http2.client.HTTP2Client;
|
||||||
import org.eclipse.jetty.http2.client.http.HttpClientTransportOverHTTP2;
|
import org.eclipse.jetty.http2.client.http.HttpClientTransportOverHTTP2;
|
||||||
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
||||||
import org.eclipse.jetty.util.thread.QueuedThreadPool;
|
import org.eclipse.jetty.util.thread.QueuedThreadPool;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -117,8 +116,7 @@ public class TestJettyOSGiBootHTTP2Conscrypt
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
@Test
|
|
||||||
public void assertAllBundlesActiveOrResolved() throws Exception
|
public void assertAllBundlesActiveOrResolved() throws Exception
|
||||||
{
|
{
|
||||||
TestOSGiUtil.debugBundles(bundleContext);
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
|
@ -134,6 +132,9 @@ public class TestJettyOSGiBootHTTP2Conscrypt
|
||||||
@Test
|
@Test
|
||||||
public void testHTTP2() throws Exception
|
public void testHTTP2() throws Exception
|
||||||
{
|
{
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
HTTP2Client client = new HTTP2Client();
|
HTTP2Client client = new HTTP2Client();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -39,7 +39,6 @@ import org.eclipse.jetty.http2.client.HTTP2Client;
|
||||||
import org.eclipse.jetty.http2.client.http.HttpClientTransportOverHTTP2;
|
import org.eclipse.jetty.http2.client.http.HttpClientTransportOverHTTP2;
|
||||||
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
||||||
import org.eclipse.jetty.util.thread.QueuedThreadPool;
|
import org.eclipse.jetty.util.thread.QueuedThreadPool;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -108,7 +107,6 @@ public class TestJettyOSGiBootHTTP2JDK9
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
public void assertAllBundlesActiveOrResolved() throws Exception
|
public void assertAllBundlesActiveOrResolved() throws Exception
|
||||||
{
|
{
|
||||||
TestOSGiUtil.debugBundles(bundleContext);
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
|
@ -126,6 +124,9 @@ public class TestJettyOSGiBootHTTP2JDK9
|
||||||
@Test
|
@Test
|
||||||
public void testHTTP2() throws Exception
|
public void testHTTP2() throws Exception
|
||||||
{
|
{
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
HttpClient httpClient = null;
|
HttpClient httpClient = null;
|
||||||
HTTP2Client http2Client = null;
|
HTTP2Client http2Client = null;
|
||||||
try
|
try
|
||||||
|
|
|
@ -33,7 +33,6 @@ import org.eclipse.jetty.client.HttpClient;
|
||||||
import org.eclipse.jetty.client.api.ContentResponse;
|
import org.eclipse.jetty.client.api.ContentResponse;
|
||||||
import org.eclipse.jetty.http.HttpStatus;
|
import org.eclipse.jetty.http.HttpStatus;
|
||||||
import org.eclipse.jetty.webapp.WebAppContext;
|
import org.eclipse.jetty.webapp.WebAppContext;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -97,8 +96,7 @@ public class TestJettyOSGiBootWebAppAsService
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Ignore
|
|
||||||
@Test
|
|
||||||
public void assertAllBundlesActiveOrResolved()
|
public void assertAllBundlesActiveOrResolved()
|
||||||
{
|
{
|
||||||
TestOSGiUtil.debugBundles(bundleContext);
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
|
@ -110,6 +108,11 @@ public class TestJettyOSGiBootWebAppAsService
|
||||||
@Test
|
@Test
|
||||||
public void testBundle() throws Exception
|
public void testBundle() throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
|
|
||||||
// now test getting a static file
|
// now test getting a static file
|
||||||
HttpClient client = new HttpClient();
|
HttpClient client = new HttpClient();
|
||||||
try
|
try
|
||||||
|
|
|
@ -33,7 +33,6 @@ import org.eclipse.jetty.client.HttpClient;
|
||||||
import org.eclipse.jetty.client.api.ContentResponse;
|
import org.eclipse.jetty.client.api.ContentResponse;
|
||||||
import org.eclipse.jetty.client.api.Request;
|
import org.eclipse.jetty.client.api.Request;
|
||||||
import org.eclipse.jetty.http.HttpStatus;
|
import org.eclipse.jetty.http.HttpStatus;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -95,10 +94,9 @@ public class TestJettyOSGiBootWithAnnotations
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
@Test
|
|
||||||
public void assertAllBundlesActiveOrResolved()
|
public void assertAllBundlesActiveOrResolved()
|
||||||
{
|
{
|
||||||
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,6 +105,10 @@ public class TestJettyOSGiBootWithAnnotations
|
||||||
@Test
|
@Test
|
||||||
public void testIndex() throws Exception
|
public void testIndex() throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
HttpClient client = new HttpClient();
|
HttpClient client = new HttpClient();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -35,7 +35,6 @@ import javax.websocket.RemoteEndpoint;
|
||||||
import javax.websocket.Session;
|
import javax.websocket.Session;
|
||||||
import javax.websocket.WebSocketContainer;
|
import javax.websocket.WebSocketContainer;
|
||||||
|
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -91,6 +90,7 @@ public class TestJettyOSGiBootWithJavaxWebSocket
|
||||||
public static List<Option> testJettyWebApp()
|
public static List<Option> testJettyWebApp()
|
||||||
{
|
{
|
||||||
List<Option> res = new ArrayList<>();
|
List<Option> res = new ArrayList<>();
|
||||||
|
//test webapp bundle
|
||||||
res.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("test-jetty-webapp").classifier("webbundle").versionAsInProject().noStart());
|
res.add(mavenBundle().groupId("org.eclipse.jetty").artifactId("test-jetty-webapp").classifier("webbundle").versionAsInProject().noStart());
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -102,16 +102,9 @@ public class TestJettyOSGiBootWithJavaxWebSocket
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Ignore
|
|
||||||
public void assertAllBundlesActiveOrResolved() throws BundleException
|
public void assertAllBundlesActiveOrResolved()
|
||||||
{
|
{
|
||||||
fixJavaxWebSocketApi();
|
|
||||||
|
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.common");
|
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.client");
|
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.server");
|
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.tests.webapp");
|
|
||||||
|
|
||||||
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
||||||
TestOSGiUtil.debugBundles(bundleContext);
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
}
|
}
|
||||||
|
@ -119,6 +112,7 @@ public class TestJettyOSGiBootWithJavaxWebSocket
|
||||||
@Test
|
@Test
|
||||||
public void testWebsocket() throws Exception
|
public void testWebsocket() throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
fixJavaxWebSocketApi();
|
fixJavaxWebSocketApi();
|
||||||
|
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.common");
|
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.common");
|
||||||
|
@ -126,6 +120,9 @@ public class TestJettyOSGiBootWithJavaxWebSocket
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.server");
|
startBundle(bundleContext, "org.eclipse.jetty.websocket.javax.websocket.server");
|
||||||
startBundle(bundleContext, "org.eclipse.jetty.tests.webapp");
|
startBundle(bundleContext, "org.eclipse.jetty.tests.webapp");
|
||||||
|
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
String port = System.getProperty("boot.javax.websocket.port");
|
String port = System.getProperty("boot.javax.websocket.port");
|
||||||
assertNotNull(port);
|
assertNotNull(port);
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ import javax.inject.Inject;
|
||||||
import org.eclipse.jetty.client.HttpClient;
|
import org.eclipse.jetty.client.HttpClient;
|
||||||
import org.eclipse.jetty.client.api.ContentResponse;
|
import org.eclipse.jetty.client.api.ContentResponse;
|
||||||
import org.eclipse.jetty.http.HttpStatus;
|
import org.eclipse.jetty.http.HttpStatus;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -86,8 +85,6 @@ public class TestJettyOSGiBootWithJsp
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
@Test
|
|
||||||
public void assertAllBundlesActiveOrResolved()
|
public void assertAllBundlesActiveOrResolved()
|
||||||
{
|
{
|
||||||
TestOSGiUtil.debugBundles(bundleContext);
|
TestOSGiUtil.debugBundles(bundleContext);
|
||||||
|
@ -98,6 +95,9 @@ public class TestJettyOSGiBootWithJsp
|
||||||
@Test
|
@Test
|
||||||
public void testJspDump() throws Exception
|
public void testJspDump() throws Exception
|
||||||
{
|
{
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
HttpClient client = new HttpClient();
|
HttpClient client = new HttpClient();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -32,7 +32,6 @@ import javax.inject.Inject;
|
||||||
|
|
||||||
import org.eclipse.jetty.websocket.client.ClientUpgradeRequest;
|
import org.eclipse.jetty.websocket.client.ClientUpgradeRequest;
|
||||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.ops4j.pax.exam.Configuration;
|
import org.ops4j.pax.exam.Configuration;
|
||||||
|
@ -85,7 +84,6 @@ public class TestJettyOSGiBootWithWebSocket
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Ignore
|
|
||||||
public void assertAllBundlesActiveOrResolved()
|
public void assertAllBundlesActiveOrResolved()
|
||||||
{
|
{
|
||||||
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
TestOSGiUtil.assertAllBundlesActiveOrResolved(bundleContext);
|
||||||
|
@ -97,6 +95,9 @@ public class TestJettyOSGiBootWithWebSocket
|
||||||
@Test
|
@Test
|
||||||
public void testWebsocket() throws Exception
|
public void testWebsocket() throws Exception
|
||||||
{
|
{
|
||||||
|
if (Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))
|
||||||
|
assertAllBundlesActiveOrResolved();
|
||||||
|
|
||||||
String port = System.getProperty("boot.websocket.port");
|
String port = System.getProperty("boot.websocket.port");
|
||||||
assertNotNull(port);
|
assertNotNull(port);
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,6 @@ import org.eclipse.jetty.osgi.boot.OSGiServerConstants;
|
||||||
import org.eclipse.jetty.toolchain.test.FS;
|
import org.eclipse.jetty.toolchain.test.FS;
|
||||||
import org.eclipse.jetty.util.StringUtil;
|
import org.eclipse.jetty.util.StringUtil;
|
||||||
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
import org.eclipse.jetty.util.ssl.SslContextFactory;
|
||||||
|
|
||||||
import org.ops4j.pax.exam.CoreOptions;
|
import org.ops4j.pax.exam.CoreOptions;
|
||||||
import org.ops4j.pax.exam.Option;
|
import org.ops4j.pax.exam.Option;
|
||||||
import org.osgi.framework.Bundle;
|
import org.osgi.framework.Bundle;
|
||||||
|
@ -58,6 +57,8 @@ import org.osgi.service.http.HttpService;
|
||||||
public class TestOSGiUtil
|
public class TestOSGiUtil
|
||||||
{
|
{
|
||||||
|
|
||||||
|
public static final String BUNDLE_DEBUG = "bundle.debug";
|
||||||
|
|
||||||
public static List<Option> configureJettyHomeAndPort(boolean ssl,String jettySelectorFileName)
|
public static List<Option> configureJettyHomeAndPort(boolean ssl,String jettySelectorFileName)
|
||||||
{
|
{
|
||||||
File etc = new File(FS.separators("src/test/config/etc"));
|
File etc = new File(FS.separators("src/test/config/etc"));
|
||||||
|
@ -103,7 +104,7 @@ public class TestOSGiUtil
|
||||||
public static List<Option> coreJettyDependencies()
|
public static List<Option> coreJettyDependencies()
|
||||||
{
|
{
|
||||||
List<Option> res = new ArrayList<>();
|
List<Option> res = new ArrayList<>();
|
||||||
|
res.add(systemProperty("bundle.debug").value(Boolean.toString(Boolean.getBoolean(TestOSGiUtil.BUNDLE_DEBUG))));
|
||||||
String mavenRepoPath = System.getProperty( "mavenRepoPath" );
|
String mavenRepoPath = System.getProperty( "mavenRepoPath" );
|
||||||
if (!StringUtil.isBlank(mavenRepoPath))
|
if (!StringUtil.isBlank(mavenRepoPath))
|
||||||
res.add( systemProperty( "org.ops4j.pax.url.mvn.localRepository" ).value( mavenRepoPath ) );
|
res.add( systemProperty( "org.ops4j.pax.url.mvn.localRepository" ).value( mavenRepoPath ) );
|
||||||
|
|
|
@ -45,7 +45,7 @@ import org.eclipse.jetty.websocket.core.internal.Generator;
|
||||||
public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseable
|
public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseable
|
||||||
{
|
{
|
||||||
private final LocalServer server;
|
private final LocalServer server;
|
||||||
private final RawWebSocketClient rawClient;
|
private final WebSocketCoreClient client;
|
||||||
private final RawUpgradeRequest upgradeRequest;
|
private final RawUpgradeRequest upgradeRequest;
|
||||||
private final UnitGenerator generator;
|
private final UnitGenerator generator;
|
||||||
private final FrameCapture frameCapture;
|
private final FrameCapture frameCapture;
|
||||||
|
@ -65,9 +65,9 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
this.server = server;
|
this.server = server;
|
||||||
this.rawClient = new RawWebSocketClient();
|
this.client = new WebSocketCoreClient();
|
||||||
CompletableFuture<FrameCapture> futureOnCapture = new CompletableFuture<>();
|
CompletableFuture<FrameCapture> futureOnCapture = new CompletableFuture<>();
|
||||||
this.upgradeRequest = new RawUpgradeRequest(rawClient, wsURI, futureOnCapture);
|
this.upgradeRequest = new RawUpgradeRequest(client, wsURI, futureOnCapture);
|
||||||
if (requestHeaders != null)
|
if (requestHeaders != null)
|
||||||
{
|
{
|
||||||
HttpFields fields = this.upgradeRequest.getHeaders();
|
HttpFields fields = this.upgradeRequest.getHeaders();
|
||||||
|
@ -77,10 +77,10 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
fields.put(name, value);
|
fields.put(name, value);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
this.rawClient.start();
|
this.client.start();
|
||||||
this.generator = new UnitGenerator(Behavior.CLIENT);
|
this.generator = new UnitGenerator(Behavior.CLIENT);
|
||||||
|
|
||||||
CompletableFuture<FrameHandler.CoreSession> futureHandler = this.rawClient.connect(upgradeRequest);
|
CompletableFuture<FrameHandler.CoreSession> futureHandler = this.client.connect(upgradeRequest);
|
||||||
CompletableFuture<FrameCapture> futureCapture = futureHandler.thenCombine(futureOnCapture, (channel, capture) -> capture);
|
CompletableFuture<FrameCapture> futureCapture = futureHandler.thenCombine(futureOnCapture, (channel, capture) -> capture);
|
||||||
this.frameCapture = futureCapture.get(10, TimeUnit.SECONDS);
|
this.frameCapture = futureCapture.get(10, TimeUnit.SECONDS);
|
||||||
}
|
}
|
||||||
|
@ -102,7 +102,7 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
@Override
|
@Override
|
||||||
public void close() throws Exception
|
public void close() throws Exception
|
||||||
{
|
{
|
||||||
this.rawClient.stop();
|
this.client.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -156,7 +156,7 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
{
|
{
|
||||||
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
||||||
{
|
{
|
||||||
frameCapture.channel.sendFrame(f, blocker, false);
|
frameCapture.session.sendFrame(f, blocker, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -168,7 +168,7 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
{
|
{
|
||||||
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
try (SharedBlockingCallback.Blocker blocker = sharedBlockingCallback.acquire())
|
||||||
{
|
{
|
||||||
frameCapture.channel.sendFrame(f, blocker, false);
|
frameCapture.session.sendFrame(f, blocker, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -184,10 +184,6 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class RawWebSocketClient extends WebSocketCoreClient
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class RawUpgradeRequest extends UpgradeRequest
|
public static class RawUpgradeRequest extends UpgradeRequest
|
||||||
{
|
{
|
||||||
private final CompletableFuture<FrameCapture> futureCapture;
|
private final CompletableFuture<FrameCapture> futureCapture;
|
||||||
|
@ -226,7 +222,7 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
private final BlockingQueue<Frame> receivedFrames = new LinkedBlockingQueue<>();
|
private final BlockingQueue<Frame> receivedFrames = new LinkedBlockingQueue<>();
|
||||||
private final EndPoint endPoint;
|
private final EndPoint endPoint;
|
||||||
private final SharedBlockingCallback blockingCallback = new SharedBlockingCallback();
|
private final SharedBlockingCallback blockingCallback = new SharedBlockingCallback();
|
||||||
private CoreSession channel;
|
private CoreSession session;
|
||||||
|
|
||||||
public FrameCapture(EndPoint endPoint)
|
public FrameCapture(EndPoint endPoint)
|
||||||
{
|
{
|
||||||
|
@ -247,16 +243,21 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
public void onFrame(Frame frame, Callback callback)
|
public void onFrame(Frame frame, Callback callback)
|
||||||
{
|
{
|
||||||
receivedFrames.offer(Frame.copy(frame));
|
receivedFrames.offer(Frame.copy(frame));
|
||||||
|
synchronized(this)
|
||||||
|
{
|
||||||
callback.succeeded();
|
callback.succeeded();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onOpen(CoreSession coreSession) throws Exception
|
public void onOpen(CoreSession coreSession) throws Exception
|
||||||
{
|
{
|
||||||
this.channel = coreSession;
|
this.session = coreSession;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeRaw(ByteBuffer buffer) throws IOException
|
public void writeRaw(ByteBuffer buffer) throws IOException
|
||||||
|
{
|
||||||
|
synchronized (this)
|
||||||
{
|
{
|
||||||
try (SharedBlockingCallback.Blocker blocker = blockingCallback.acquire())
|
try (SharedBlockingCallback.Blocker blocker = blockingCallback.acquire())
|
||||||
{
|
{
|
||||||
|
@ -265,3 +266,4 @@ public class NetworkFuzzer extends Fuzzer.Adapter implements Fuzzer, AutoCloseab
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -18,9 +18,6 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.websocket.javax.tests.client;
|
package org.eclipse.jetty.websocket.javax.tests.client;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertFalse;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
|
@ -51,6 +48,9 @@ import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.TestInfo;
|
import org.junit.jupiter.api.TestInfo;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class DecoderReaderManySmallTest
|
public class DecoderReaderManySmallTest
|
||||||
{
|
{
|
||||||
private CoreServer server;
|
private CoreServer server;
|
||||||
|
@ -91,12 +91,14 @@ public class DecoderReaderManySmallTest
|
||||||
{
|
{
|
||||||
URI wsUri = server.getWsUri().resolve("/eventids");
|
URI wsUri = server.getWsUri().resolve("/eventids");
|
||||||
EventIdSocket clientSocket = new EventIdSocket(testInfo.getTestMethod().toString());
|
EventIdSocket clientSocket = new EventIdSocket(testInfo.getTestMethod().toString());
|
||||||
Session clientSession = client.connectToServer(clientSocket, wsUri);
|
|
||||||
|
|
||||||
final int from = 1000;
|
final int from = 1000;
|
||||||
final int to = 2000;
|
final int to = 2000;
|
||||||
|
|
||||||
|
try(Session clientSession = client.connectToServer(clientSocket, wsUri))
|
||||||
|
{
|
||||||
clientSession.getAsyncRemote().sendText("seq|" + from + "|" + to);
|
clientSession.getAsyncRemote().sendText("seq|" + from + "|" + to);
|
||||||
|
}
|
||||||
|
|
||||||
// collect seen ids
|
// collect seen ids
|
||||||
List<Integer> seen = new ArrayList<>();
|
List<Integer> seen = new ArrayList<>();
|
||||||
|
@ -182,6 +184,8 @@ public class DecoderReaderManySmallTest
|
||||||
sendText(Integer.toString(id), Callback.NOOP, false);
|
sendText(Integer.toString(id), Callback.NOOP, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getCoreSession().flush(callback);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,11 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.websocket.javax.tests.server;
|
package org.eclipse.jetty.websocket.javax.tests.server;
|
||||||
|
|
||||||
|
import java.util.concurrent.BlockingQueue;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
|
import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
|
||||||
|
import org.eclipse.jetty.util.log.StacklessLogging;
|
||||||
import org.eclipse.jetty.webapp.WebAppContext;
|
import org.eclipse.jetty.webapp.WebAppContext;
|
||||||
import org.eclipse.jetty.websocket.core.CloseStatus;
|
import org.eclipse.jetty.websocket.core.CloseStatus;
|
||||||
import org.eclipse.jetty.websocket.core.Frame;
|
import org.eclipse.jetty.websocket.core.Frame;
|
||||||
|
@ -31,9 +35,6 @@ import org.junit.jupiter.api.AfterAll;
|
||||||
import org.junit.jupiter.api.BeforeAll;
|
import org.junit.jupiter.api.BeforeAll;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import java.util.concurrent.BlockingQueue;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
import static org.hamcrest.MatcherAssert.assertThat;
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
@ -69,7 +70,8 @@ public class IdleTimeoutTest
|
||||||
|
|
||||||
private void assertConnectionTimeout(String requestPath) throws Exception
|
private void assertConnectionTimeout(String requestPath) throws Exception
|
||||||
{
|
{
|
||||||
try (Fuzzer session = server.newNetworkFuzzer(requestPath))
|
try (Fuzzer session = server.newNetworkFuzzer(requestPath);
|
||||||
|
StacklessLogging stacklessLogging = new StacklessLogging(IdleTimeoutOnOpenSocket.class))
|
||||||
{
|
{
|
||||||
// wait 1 second to allow timeout to fire off
|
// wait 1 second to allow timeout to fire off
|
||||||
TimeUnit.SECONDS.sleep(1);
|
TimeUnit.SECONDS.sleep(1);
|
||||||
|
|
|
@ -18,6 +18,15 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.websocket.core.internal;
|
package org.eclipse.jetty.websocket.core.internal;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.ListIterator;
|
||||||
|
import java.util.Queue;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.eclipse.jetty.io.ByteBufferPool;
|
import org.eclipse.jetty.io.ByteBufferPool;
|
||||||
import org.eclipse.jetty.util.Callback;
|
import org.eclipse.jetty.util.Callback;
|
||||||
import org.eclipse.jetty.util.DecoratedObjectFactory;
|
import org.eclipse.jetty.util.DecoratedObjectFactory;
|
||||||
|
@ -34,15 +43,6 @@ import org.eclipse.jetty.websocket.core.IncomingFrames;
|
||||||
import org.eclipse.jetty.websocket.core.OutgoingFrames;
|
import org.eclipse.jetty.websocket.core.OutgoingFrames;
|
||||||
import org.eclipse.jetty.websocket.core.WebSocketExtensionRegistry;
|
import org.eclipse.jetty.websocket.core.WebSocketExtensionRegistry;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.ArrayDeque;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.ListIterator;
|
|
||||||
import java.util.Queue;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents the stack of Extensions.
|
* Represents the stack of Extensions.
|
||||||
*/
|
*/
|
||||||
|
@ -359,7 +359,7 @@ public class ExtensionStack implements IncomingFrames, OutgoingFrames, Dumpable
|
||||||
// and the failure of a frame may not mean that the whole
|
// and the failure of a frame may not mean that the whole
|
||||||
// connection is now invalid.
|
// connection is now invalid.
|
||||||
notifyCallbackFailure(current.callback, cause);
|
notifyCallbackFailure(current.callback, cause);
|
||||||
super.failed(cause);
|
super.succeeded();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void notifyCallbackSuccess(Callback callback)
|
private void notifyCallbackSuccess(Callback callback)
|
||||||
|
|
Loading…
Reference in New Issue