AsyncTimeoutTest.java
/*
* Copyright (c) 2013, 2017 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.tyrus.test.standard_config;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import javax.websocket.ClientEndpointConfig;
import javax.websocket.DeploymentException;
import javax.websocket.Endpoint;
import javax.websocket.EndpointConfig;
import javax.websocket.MessageHandler;
import javax.websocket.OnMessage;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;
import org.glassfish.tyrus.client.ClientManager;
import org.glassfish.tyrus.server.Server;
import org.glassfish.tyrus.test.tools.TestContainer;
import org.junit.Test;
import static org.junit.Assert.assertTrue;
/**
* @author Pavel Bucek (pavel.bucek at oracle.com)
*/
public class AsyncTimeoutTest extends TestContainer {
@ServerEndpoint(value = "/asyncTimeoutTest")
public static class AsyncTimeoutEndpoint {
@OnMessage
public String onMessage(String message, Session session) {
int i = 0;
try {
i = Integer.parseInt(message);
} catch (NumberFormatException e) {
// do nothing.
}
if (i > 0) {
session.getContainer().setAsyncSendTimeout(i);
}
return Long.toString(session.getAsyncRemote().getSendTimeout());
}
}
@Test
public void testAsyncTimeout() throws DeploymentException {
Server server = startServer(AsyncTimeoutEndpoint.class);
try {
final ClientEndpointConfig cec = ClientEndpointConfig.Builder.create().build();
final CountDownLatch latch1 = new CountDownLatch(1);
final CountDownLatch latch2 = new CountDownLatch(1);
final ClientManager client = createClient();
Session session = client.connectToServer(new Endpoint() {
@Override
public void onOpen(Session session, EndpointConfig config) {
session.addMessageHandler(
new MessageHandler.Whole<String>() {
@Override
public void onMessage(String message) {
// we don't really care for this one.
latch1.countDown();
}
}
);
}
}, cec, getURI(AsyncTimeoutEndpoint.class));
session.getBasicRemote().sendText("2000");
assertTrue(latch1.await(2, TimeUnit.SECONDS));
session = client.connectToServer(new Endpoint() {
@Override
public void onOpen(Session session, EndpointConfig config) {
session.addMessageHandler(
new MessageHandler.Whole<String>() {
@Override
public void onMessage(String message) {
if (message.equals("2000")) {
latch2.countDown();
}
}
}
);
}
}, cec, getURI(AsyncTimeoutEndpoint.class));
session.getBasicRemote().sendText("GET");
assertTrue(latch2.await(2, TimeUnit.SECONDS));
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException(e.getMessage(), e);
} finally {
stopServer(server);
}
}
}