summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-02-25 08:06:28 +0000
committerVaadin Code Review <review@vaadin.com>2015-02-25 09:01:49 +0000
commit5fd625a945862e6ceccbeb13cde1ef00e26d9572 (patch)
tree82c6b83efe387a2eb7444675c25ed8c680a3700f
parent7887363965d8a95d2caa80af1ba73e668565b538 (diff)
downloadvaadin-framework-5fd625a945862e6ceccbeb13cde1ef00e26d9572.tar.gz
vaadin-framework-5fd625a945862e6ceccbeb13cde1ef00e26d9572.zip
Breaks PushLargeDataLongPollingTest and also long polling in many ways. See http://dev.vaadin.com/ticket/16919
Revert "Fix handling of disconnection with push (#15330)" This reverts commit 3c07368cbbc4d35534e90c769ea8ec975400c452. Change-Id: I46631b1921fa1c5628952362a93a000df92c5a4a
-rw-r--r--server/src/com/vaadin/server/communication/AtmospherePushConnection.java61
-rw-r--r--server/src/com/vaadin/server/communication/PushHandler.java32
2 files changed, 30 insertions, 63 deletions
diff --git a/server/src/com/vaadin/server/communication/AtmospherePushConnection.java b/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
index aa952b9072..0819a24ee9 100644
--- a/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
+++ b/server/src/com/vaadin/server/communication/AtmospherePushConnection.java
@@ -156,9 +156,9 @@ public class AtmospherePushConnection implements PushConnection {
public void push(boolean async) {
if (!isConnected()) {
if (async && state != State.RESPONSE_PENDING) {
- setState(State.PUSH_PENDING);
+ state = State.PUSH_PENDING;
} else {
- setState(State.RESPONSE_PENDING);
+ state = State.RESPONSE_PENDING;
}
} else {
try {
@@ -229,22 +229,23 @@ public class AtmospherePushConnection implements PushConnection {
/**
* Associates this {@code AtmospherePushConnection} with the given
* {@AtmosphereResource} representing an established
- * push connection.
- * <p>
+ * push connection. If already connected, calls {@link #disconnect()} first.
* If there is a deferred push, carries it out via the new connection.
- * <p>
- * This method must never be called when there is an existing connection
*
* @since 7.2
*/
public void connect(AtmosphereResource resource) {
+
assert resource != null;
assert resource != this.resource;
- assert !isConnected();
+
+ if (isConnected()) {
+ disconnect();
+ }
this.resource = resource;
State oldState = state;
- setState(State.CONNECTED);
+ state = State.CONNECTED;
if (oldState == State.PUSH_PENDING
|| oldState == State.RESPONSE_PENDING) {
@@ -272,17 +273,14 @@ public class AtmospherePushConnection implements PushConnection {
@Override
public void disconnect() {
assert isConnected();
- if (!isConnected() || resource.isResumed()) {
- // Server has asked to push connection to be disconnected but there
- // is no current connection
-
- // This could be a timing issue during session expiration or
- // similar and should not happen in an ideal world. Might require
- // some logic changes in session expiration handling to avoid
- // triggering this
- getLogger().info(
- "Server requested disconnect for inactive push connection");
- connectionLost();
+
+ if (resource.isResumed()) {
+ // Calling disconnect may end up invoking it again via
+ // resource.resume and PushHandler.onResume. Bail out here if
+ // the resource is already resumed; this is a bit hacky and should
+ // be implemented in a better way in 7.2.
+ resource = null;
+ state = State.DISCONNECTED;
return;
}
@@ -304,24 +302,13 @@ public class AtmospherePushConnection implements PushConnection {
}
try {
- // Close the push connection
resource.close();
} catch (IOException e) {
getLogger()
.log(Level.INFO, "Error when closing push connection", e);
}
- connectionLost();
- }
-
- /**
- * Called when the connection to the client has been lost.
- *
- * @since
- */
- public void connectionLost() {
resource = null;
- setState(State.DISCONNECTED);
-
+ state = State.DISCONNECTED;
}
/**
@@ -332,16 +319,6 @@ public class AtmospherePushConnection implements PushConnection {
}
/**
- * Sets the state of this connection
- *
- * @param state
- * the new state
- */
- private void setState(State state) {
- this.state = state;
- }
-
- /**
* Reinitializes this PushConnection after deserialization. The connection
* is initially in disconnected state; the client will handle the
* reconnecting.
@@ -349,7 +326,7 @@ public class AtmospherePushConnection implements PushConnection {
private void readObject(ObjectInputStream stream) throws IOException,
ClassNotFoundException {
stream.defaultReadObject();
- setState(State.DISCONNECTED);
+ state = State.DISCONNECTED;
}
private static Logger getLogger() {
diff --git a/server/src/com/vaadin/server/communication/PushHandler.java b/server/src/com/vaadin/server/communication/PushHandler.java
index 38a5f3017f..7e7183193a 100644
--- a/server/src/com/vaadin/server/communication/PushHandler.java
+++ b/server/src/com/vaadin/server/communication/PushHandler.java
@@ -63,9 +63,8 @@ public class PushHandler extends AtmosphereResourceEventListenerAdapter {
public void onStateChange(AtmosphereResourceEvent event)
throws IOException {
super.onStateChange(event);
-
- if (event.isResumedOnTimeout()) {
- connectionLost(event);
+ if (event.isCancelled() || event.isResumedOnTimeout()) {
+ disconnect(event);
}
}
@@ -330,30 +329,17 @@ public class PushHandler extends AtmosphereResourceEventListenerAdapter {
public void onDisconnect(AtmosphereResourceEvent event) {
// Log event on trace level
super.onDisconnect(event);
-
- // Called no matter if the client closed the connection cleanly
- // (event.isClosedByClient()) or if it was unexpectedly disconnected
- // (event.isCancelled)
- connectionLost(event);
- }
-
- @Override
- public void onResume(AtmosphereResourceEvent event) {
- super.onResume(event);
-
- // If a long polling connection is resumed, we no longer have a
- // connection up and must update the state of AtmospherePushConnection
- connectionLost(event);
+ disconnect(event);
}
@Override
public void onThrowable(AtmosphereResourceEvent event) {
getLogger().log(Level.SEVERE, "Exception in push connection",
event.throwable());
- connectionLost(event);
+ disconnect(event);
}
- private void connectionLost(AtmosphereResourceEvent event) {
+ private void disconnect(AtmosphereResourceEvent event) {
// We don't want to use callWithUi here, as it assumes there's a client
// request active and does requestStart and requestEnd among other
// things.
@@ -439,8 +425,12 @@ public class PushHandler extends AtmosphereResourceEventListenerAdapter {
"Connection unexpectedly closed for resource {0} with transport {1}",
new Object[] { id, resource.transport() });
}
-
- pushConnection.connectionLost();
+ if (pushConnection.isConnected()) {
+ // disconnect() assumes the push connection is connected but
+ // this method can currently be called more than once during
+ // disconnect, depending on the situation
+ pushConnection.disconnect();
+ }
}
} catch (final Exception e) {