diff options
author | ritchie <ritchie@gmx.at> | 2015-05-10 08:59:04 +0200 |
---|---|---|
committer | ritchie <ritchie@gmx.at> | 2015-05-10 08:59:04 +0200 |
commit | 82eff8c288adfe2e8b571a9da92c59a0a74f58b1 (patch) | |
tree | b2aa0944d7b50ebc42d98cfd5e46dde8c04fe4e3 /websocket | |
parent | 4decd0f91f7654c55d1d50ef0a73818145b3fe6f (diff) | |
download | nanohttpd-82eff8c288adfe2e8b571a9da92c59a0a74f58b1.tar.gz |
websocket test
Diffstat (limited to 'websocket')
3 files changed, 224 insertions, 17 deletions
diff --git a/websocket/pom.xml b/websocket/pom.xml index 25a964c..dd05a08 100644 --- a/websocket/pom.xml +++ b/websocket/pom.xml @@ -1,23 +1,29 @@ -<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> - <modelVersion>4.0.0</modelVersion> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.nanohttpd</groupId> <artifactId>nanohttpd-project</artifactId> <version>2.2.0-SNAPSHOT</version> </parent> - <artifactId>nanohttpd-websocket</artifactId> - <packaging>jar</packaging> - <name>NanoHttpd-Websocket</name> - <dependencies> - <dependency> - <groupId>org.mockito</groupId> - <artifactId>mockito-all</artifactId> - <version>1.9.5</version> - </dependency> - <dependency> - <groupId>${project.groupId}</groupId> - <artifactId>nanohttpd</artifactId> - <version>${project.version}</version> - </dependency> - </dependencies> + <artifactId>nanohttpd-websocket</artifactId> + <packaging>jar</packaging> + <name>NanoHttpd-Websocket</name> + <dependencies> + <dependency> + <groupId>org.mockito</groupId> + <artifactId>mockito-all</artifactId> + <version>1.9.5</version> + </dependency> + <dependency> + <groupId>${project.groupId}</groupId> + <artifactId>nanohttpd</artifactId> + <version>${project.version}</version> + </dependency> + <dependency> + <groupId>org.eclipse.jetty.websocket</groupId> + <artifactId>websocket-client</artifactId> + <version>9.3.0.M2</version> + </dependency> + </dependencies> </project> diff --git a/websocket/src/test/java/fi/iki/elonen/samples/echo/EchoWebSocketsTest.java b/websocket/src/test/java/fi/iki/elonen/samples/echo/EchoWebSocketsTest.java new file mode 100644 index 0000000..96945f4 --- /dev/null +++ b/websocket/src/test/java/fi/iki/elonen/samples/echo/EchoWebSocketsTest.java @@ -0,0 +1,92 @@ +package fi.iki.elonen.samples.echo; + +/* + * #%L + * NanoHttpd-Websocket + * %% + * Copyright (C) 2012 - 2015 nanohttpd + * %% + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * 3. Neither the name of the nanohttpd nor the names of its contributors + * may be used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + * #L% + */ + +import java.net.URI; +import java.util.concurrent.TimeUnit; + +import org.eclipse.jetty.websocket.client.ClientUpgradeRequest; +import org.eclipse.jetty.websocket.client.WebSocketClient; +import org.junit.AfterClass; +import org.junit.Assert; +import org.junit.BeforeClass; +import org.junit.Test; + +import fi.iki.elonen.NanoWebSocketServer; + +public class EchoWebSocketsTest { + + private static NanoWebSocketServer server; + + @BeforeClass + public static void setUp() throws Exception { + server = new DebugWebSocketServer(9191, true); + server.start(); + } + + @AfterClass + public static void tearDown() throws Exception { + server.stop(); + } + + @Test + public void testWebsocketClient() throws Exception { + String destUri = "ws://localhost:9191"; + + WebSocketClient client = new WebSocketClient(); + SimpleEchoSocket socket = new SimpleEchoSocket(); + socket.getToSendMessages().add("Hello"); + socket.getToSendMessages().add("Thanks for the conversation."); + try { + client.start(); + URI echoUri = new URI(destUri); + ClientUpgradeRequest request = new ClientUpgradeRequest(); + client.connect(socket, echoUri, request); + System.out.printf("Connecting to : %s%n", echoUri); + socket.awaitClose(5, TimeUnit.SECONDS); + } catch (Throwable t) { + t.printStackTrace(); + } finally { + try { + client.stop(); + } catch (Exception e) { + e.printStackTrace(); + } + } + Assert.assertEquals(2, socket.getReceivedMessages().size()); + Assert.assertEquals("Hello", socket.getReceivedMessages().get(0)); + Assert.assertEquals("Thanks for the conversation.", socket.getReceivedMessages().get(1)); + + } +} diff --git a/websocket/src/test/java/fi/iki/elonen/samples/echo/SimpleEchoSocket.java b/websocket/src/test/java/fi/iki/elonen/samples/echo/SimpleEchoSocket.java new file mode 100644 index 0000000..af33f84 --- /dev/null +++ b/websocket/src/test/java/fi/iki/elonen/samples/echo/SimpleEchoSocket.java @@ -0,0 +1,109 @@ +package fi.iki.elonen.samples.echo; + +/* + * #%L + * NanoHttpd-Websocket + * %% + * Copyright (C) 2012 - 2015 nanohttpd + * %% + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * 3. Neither the name of the nanohttpd nor the names of its contributors + * may be used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + * #L% + */ + +import java.util.ArrayList; +import java.util.List; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.Future; +import java.util.concurrent.TimeUnit; + +import org.eclipse.jetty.websocket.api.Session; +import org.eclipse.jetty.websocket.api.StatusCode; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketClose; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketConnect; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketMessage; +import org.eclipse.jetty.websocket.api.annotations.WebSocket; + +/** + * Basic Echo Client Socket + */ +@WebSocket(maxTextMessageSize = 64 * 1024) +public class SimpleEchoSocket { + + private final List<String> receivedMessages = new ArrayList<String>(); + + public List<String> getReceivedMessages() { + return receivedMessages; + } + + public List<String> getToSendMessages() { + return toSendMessages; + } + + private final List<String> toSendMessages = new ArrayList<String>(); + + private final CountDownLatch closeLatch; + + @SuppressWarnings("unused") + private Session session; + + public SimpleEchoSocket() { + this.closeLatch = new CountDownLatch(1); + } + + public boolean awaitClose(int duration, TimeUnit unit) throws InterruptedException { + return this.closeLatch.await(duration, unit); + } + + @OnWebSocketClose + public void onClose(int statusCode, String reason) { + System.out.printf("Connection closed: %d - %s%n", statusCode, reason); + this.session = null; + this.closeLatch.countDown(); + } + + @OnWebSocketConnect + public void onConnect(Session session) { + System.out.printf("Got connect: %s%n", session); + this.session = session; + try { + Future<Void> fut; + + for (String message : toSendMessages) { + fut = session.getRemote().sendStringByFuture(message); + fut.get(5, TimeUnit.SECONDS); + } + session.close(StatusCode.NORMAL, "I'm done"); + } catch (Throwable t) { + t.printStackTrace(); + } + } + + @OnWebSocketMessage + public void onMessage(String msg) { + System.out.printf("Got msg: %s%n", msg); + receivedMessages.add(msg); + } +} |