diff options
author | Artur Signell <artur@vaadin.com> | 2014-04-02 22:17:17 +0300 |
---|---|---|
committer | Artur Signell <artur@vaadin.com> | 2014-04-02 22:21:34 +0300 |
commit | 637ff4763094f0aac6927dcdfea0355efd310246 (patch) | |
tree | 8cb979675fa0a47e272a9dc9ea737394274bfdcd | |
parent | 74a635fce281bd7301b7dc942291d2aa1685176b (diff) | |
download | vaadin-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.java | 32 |
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()); + } + } |