summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2014-04-02 22:17:17 +0300
committerArtur Signell <artur@vaadin.com>2014-04-02 22:21:34 +0300
commit637ff4763094f0aac6927dcdfea0355efd310246 (patch)
tree8cb979675fa0a47e272a9dc9ea737394274bfdcd
parent74a635fce281bd7301b7dc942291d2aa1685176b (diff)
downloadvaadin-framework-637ff4763094f0aac6927dcdfea0355efd310246.tar.gz
vaadin-framework-637ff4763094f0aac6927dcdfea0355efd310246.zip
Wait for all messages to be sent before disconnect (#13529)
Change-Id: Ic9d5d4ac3a3f19bb906cba64cf752461d4b16ba5
-rw-r--r--server/src/com/vaadin/server/communication/AtmospherePushConnection.java32
1 files changed, 30 insertions, 2 deletions
diff --git a/server/src/com/vaadin/server/communication/AtmospherePushConnection.java b/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
index 56dd576403..65ea43ddd4 100644
--- a/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
+++ b/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
@@ -22,6 +22,11 @@ import java.io.Serializable;
import java.io.StringReader;
import java.io.StringWriter;
import java.io.Writer;
+import java.util.concurrent.Future;
+import java.util.concurrent.TimeUnit;
+import java.util.concurrent.TimeoutException;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import org.atmosphere.cpr.AtmosphereResource;
import org.atmosphere.cpr.AtmosphereResource.TRANSPORT;
@@ -116,6 +121,7 @@ public class AtmospherePushConnection implements PushConnection {
private UI ui;
private AtmosphereResource resource;
private FragmentedMessage incomingMessage;
+ private Future<Object> outgoingMessage;
public AtmospherePushConnection(UI ui) {
this.ui = ui;
@@ -163,7 +169,8 @@ public class AtmospherePushConnection implements PushConnection {
void sendMessage(String message) {
assert (isConnected());
// "Broadcast" the changes to the single client only
- getResource().getBroadcaster().broadcast(message, getResource());
+ outgoingMessage = getResource().getBroadcaster().broadcast(message,
+ getResource());
}
/**
@@ -253,8 +260,29 @@ public class AtmospherePushConnection implements PushConnection {
@Override
public void disconnect() {
assert isConnected();
- resource.resume();
+ if (outgoingMessage != null) {
+ // Wait for the last message to be sent before closing the
+ // connection (assumes that futures are completed in order)
+ try {
+ outgoingMessage.get(1000, TimeUnit.MILLISECONDS);
+ } catch (TimeoutException e) {
+ getLogger()
+ .log(Level.INFO,
+ "Timeout waiting for messages to be sent to client before disconnect");
+ } catch (Exception e) {
+ getLogger()
+ .log(Level.INFO,
+ "Error waiting for messages to be sent to client before disconnect");
+ }
+ outgoingMessage = null;
+ }
+
resource = null;
state = State.DISCONNECTED;
}
+
+ private static Logger getLogger() {
+ return Logger.getLogger(AtmospherePushConnection.class.getName());
+ }
+
}