| // |
| // ======================================================================== |
| // Copyright (c) 1995-2016 Mort Bay Consulting Pty. Ltd. |
| // ------------------------------------------------------------------------ |
| // All rights reserved. This program and the accompanying materials |
| // are made available under the terms of the Eclipse Public License v1.0 |
| // and Apache License v2.0 which accompanies this distribution. |
| // |
| // The Eclipse Public License is available at |
| // http://www.eclipse.org/legal/epl-v10.html |
| // |
| // The Apache License v2.0 is available at |
| // http://www.opensource.org/licenses/apache2.0.php |
| // |
| // You may elect to redistribute this code under either of these licenses. |
| // ======================================================================== |
| // |
| |
| package org.eclipse.jetty.websocket.client; |
| |
| import static org.hamcrest.Matchers.*; |
| |
| import java.net.URI; |
| import java.util.concurrent.Future; |
| import java.util.concurrent.TimeUnit; |
| |
| import org.eclipse.jetty.toolchain.test.TestTracker; |
| import org.eclipse.jetty.toolchain.test.annotation.Slow; |
| import org.eclipse.jetty.websocket.api.Session; |
| import org.eclipse.jetty.websocket.api.StatusCode; |
| import org.eclipse.jetty.websocket.common.test.BlockheadServer; |
| import org.eclipse.jetty.websocket.common.test.IBlockheadServerConnection; |
| import org.junit.After; |
| import org.junit.Assert; |
| import org.junit.Before; |
| import org.junit.Rule; |
| import org.junit.Test; |
| |
| public class SlowClientTest |
| { |
| @Rule |
| public TestTracker tt = new TestTracker(); |
| |
| private BlockheadServer server; |
| private WebSocketClient client; |
| |
| @Before |
| public void startClient() throws Exception |
| { |
| client = new WebSocketClient(); |
| client.getPolicy().setIdleTimeout(60000); |
| client.start(); |
| } |
| |
| @Before |
| public void startServer() throws Exception |
| { |
| server = new BlockheadServer(); |
| server.start(); |
| } |
| |
| @After |
| public void stopClient() throws Exception |
| { |
| client.stop(); |
| } |
| |
| @After |
| public void stopServer() throws Exception |
| { |
| server.stop(); |
| } |
| |
| @Test |
| @Slow |
| public void testClientSlowToSend() throws Exception |
| { |
| JettyTrackingSocket tsocket = new JettyTrackingSocket(); |
| client.getPolicy().setIdleTimeout(60000); |
| |
| URI wsUri = server.getWsUri(); |
| Future<Session> future = client.connect(tsocket, wsUri); |
| |
| IBlockheadServerConnection sconnection = server.accept(); |
| sconnection.setSoTimeout(60000); |
| sconnection.upgrade(); |
| |
| // Confirm connected |
| future.get(500, TimeUnit.MILLISECONDS); |
| tsocket.waitForConnected(500, TimeUnit.MILLISECONDS); |
| |
| int messageCount = 10; |
| |
| // Setup server read thread |
| ServerReadThread reader = new ServerReadThread(sconnection, messageCount); |
| reader.start(); |
| |
| // Have client write slowly. |
| ClientWriteThread writer = new ClientWriteThread(tsocket.getSession()); |
| writer.setMessageCount(messageCount); |
| writer.setMessage("Hello"); |
| writer.setSlowness(10); |
| writer.start(); |
| writer.join(); |
| |
| reader.waitForExpectedMessageCount(1, TimeUnit.MINUTES); |
| |
| // Verify receive |
| Assert.assertThat("Frame Receive Count", reader.getFrameCount(), is(messageCount)); |
| |
| // Close |
| tsocket.getSession().close(StatusCode.NORMAL, "Done"); |
| |
| Assert.assertTrue("Client Socket Closed", tsocket.closeLatch.await(3, TimeUnit.MINUTES)); |
| tsocket.assertCloseCode(StatusCode.NORMAL); |
| |
| reader.cancel(); // stop reading |
| } |
| } |