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/src | |
parent | 4decd0f91f7654c55d1d50ef0a73818145b3fe6f (diff) | |
download | nanohttpd-82eff8c288adfe2e8b571a9da92c59a0a74f58b1.tar.gz |
websocket test
Diffstat (limited to 'websocket/src')
-rw-r--r-- | websocket/src/test/java/fi/iki/elonen/samples/echo/EchoWebSocketsTest.java | 92 | ||||
-rw-r--r-- | websocket/src/test/java/fi/iki/elonen/samples/echo/SimpleEchoSocket.java | 109 |
2 files changed, 201 insertions, 0 deletions
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); + } +} |