Issue #4407 - tests for annotations as default ServerEndpointConfig

Signed-off-by: Lachlan Roberts <lachlan@webtide.com>
This commit is contained in:
Lachlan Roberts 2019-12-09 18:24:32 +11:00
parent 2dbd19f902
commit b400d00f03
2 changed files with 35 additions and 28 deletions

View File

@ -177,12 +177,10 @@ public interface Fuzzer extends AutoCloseable
{ {
String expectedText = expected.getPayloadAsUTF8(); String expectedText = expected.getPayloadAsUTF8();
String actualText = actual.getPayloadAsUTF8(); String actualText = actual.getPayloadAsUTF8();
assertThat(prefix + ".payloadLength", actual.getPayloadLength(), is(expected.getPayloadLength()));
assertThat(prefix + ".text-payload", actualText, is(expectedText)); assertThat(prefix + ".text-payload", actualText, is(expectedText));
} }
else else
{ {
assertThat(prefix + ".payloadLength", actual.getPayloadLength(), is(expected.getPayloadLength()));
ByteBufferAssert.assertEquals(prefix + ".payload", expected.getPayload(), actual.getPayload()); ByteBufferAssert.assertEquals(prefix + ".payload", expected.getPayload(), actual.getPayload());
} }
} }

View File

@ -18,54 +18,49 @@
package org.eclipse.jetty.websocket.javax.tests.server; package org.eclipse.jetty.websocket.javax.tests.server;
import java.nio.file.Path;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import javax.websocket.server.ServerEndpointConfig;
import org.eclipse.jetty.http.HttpHeader; import org.eclipse.jetty.http.HttpHeader;
import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
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;
import org.eclipse.jetty.websocket.core.OpCode; import org.eclipse.jetty.websocket.core.OpCode;
import org.eclipse.jetty.websocket.javax.tests.Fuzzer; import org.eclipse.jetty.websocket.javax.tests.Fuzzer;
import org.eclipse.jetty.websocket.javax.tests.LocalServer;
import org.eclipse.jetty.websocket.javax.tests.UpgradeUtils; import org.eclipse.jetty.websocket.javax.tests.UpgradeUtils;
import org.eclipse.jetty.websocket.javax.tests.WSServer;
import org.eclipse.jetty.websocket.javax.tests.coders.DateDecoder; import org.eclipse.jetty.websocket.javax.tests.coders.DateDecoder;
import org.eclipse.jetty.websocket.javax.tests.coders.TimeEncoder; import org.eclipse.jetty.websocket.javax.tests.coders.TimeEncoder;
import org.eclipse.jetty.websocket.javax.tests.server.configs.EchoSocketConfigurator; import org.eclipse.jetty.websocket.javax.tests.server.configs.EchoSocketConfigurator;
import org.eclipse.jetty.websocket.javax.tests.server.sockets.ConfiguredEchoSocket; import org.eclipse.jetty.websocket.javax.tests.server.sockets.ConfiguredEchoSocket;
import org.junit.jupiter.api.AfterAll; import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
/**
* Example of an annotated echo server discovered via annotation scanning.
*/
public class AnnotatedServerEndpointTest public class AnnotatedServerEndpointTest
{ {
private static WSServer server; private LocalServer server;
private String path = "/echo";
private String subprotocol = "echo";
@BeforeAll @BeforeEach
public static void startServer() throws Exception public void startServer() throws Exception
{ {
Path testdir = MavenTestingUtils.getTargetTestingPath(AnnotatedServerEndpointTest.class.getName()); server = new LocalServer();
server = new WSServer(testdir, "app");
server.createWebInf();
server.copyEndpoint(ConfiguredEchoSocket.class);
server.copyClass(EchoSocketConfigurator.class);
server.copyClass(DateDecoder.class);
server.copyClass(TimeEncoder.class);
server.start(); server.start();
server.getServerContainer().addEndpoint(ConfiguredEchoSocket.class);
WebAppContext webapp = server.createWebAppContext(); ServerEndpointConfig endpointConfig = ServerEndpointConfig.Builder
server.deployWebapp(webapp); .create(ConfiguredEchoSocket.class, "/override")
.subprotocols(Collections.singletonList("override"))
.build();
server.getServerContainer().addEndpoint(endpointConfig);
} }
@AfterAll @AfterEach
public static void stopServer() throws Exception public void stopServer() throws Exception
{ {
server.stop(); server.stop();
} }
@ -73,7 +68,7 @@ public class AnnotatedServerEndpointTest
private void assertResponse(String message, String expectedText) throws Exception private void assertResponse(String message, String expectedText) throws Exception
{ {
Map<String, String> upgradeRequest = UpgradeUtils.newDefaultUpgradeRequestHeaders(); Map<String, String> upgradeRequest = UpgradeUtils.newDefaultUpgradeRequestHeaders();
upgradeRequest.put(HttpHeader.SEC_WEBSOCKET_SUBPROTOCOL.asString(), "echo"); upgradeRequest.put(HttpHeader.SEC_WEBSOCKET_SUBPROTOCOL.asString(), subprotocol);
List<Frame> send = new ArrayList<>(); List<Frame> send = new ArrayList<>();
send.add(new Frame(OpCode.TEXT).setPayload(message)); send.add(new Frame(OpCode.TEXT).setPayload(message));
@ -83,7 +78,7 @@ public class AnnotatedServerEndpointTest
expect.add(new Frame(OpCode.TEXT).setPayload(expectedText)); expect.add(new Frame(OpCode.TEXT).setPayload(expectedText));
expect.add(CloseStatus.toFrame(CloseStatus.NORMAL)); expect.add(CloseStatus.toFrame(CloseStatus.NORMAL));
try (Fuzzer session = server.newNetworkFuzzer("/app/echo", upgradeRequest)) try (Fuzzer session = server.newNetworkFuzzer(path, upgradeRequest))
{ {
session.sendFrames(send); session.sendFrames(send);
session.expect(expect); session.expect(expect);
@ -125,4 +120,18 @@ public class AnnotatedServerEndpointTest
{ {
assertResponse("subprotocols", "chat, echo, test"); assertResponse("subprotocols", "chat, echo, test");
} }
@Test
public void testOverrideEndpointConfig() throws Exception
{
this.path = "/override";
this.subprotocol = "override";
//assertResponse("configurator", EchoSocketConfigurator.class.getName());
assertResponse("text-max", "111,222");
assertResponse("binary-max", "333,444");
//assertResponse("decoders", DateDecoder.class.getName());
//assertResponse("encoders", TimeEncoder.class.getName());
assertResponse("subprotocols", "override");
}
} }