diff options
author | Leif Åstrand <leif@vaadin.com> | 2015-06-03 11:30:06 +0300 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2015-06-03 10:49:03 +0000 |
commit | 24c6da9ee5c5a7c464a7f3aa849356eb9885cead (patch) | |
tree | 5259857f2f464384ecf3046adb4f7859025d700c | |
parent | 5dc4c2e9b5944ac5f5f7e327d180b1d244006b2f (diff) | |
download | vaadin-framework-24c6da9ee5c5a7c464a7f3aa849356eb9885cead.tar.gz vaadin-framework-24c6da9ee5c5a7c464a7f3aa849356eb9885cead.zip |
Reset heartbeat timestamp when reopening UI (#18101)
Change-Id: I288bae95e364277819727a99854d94fbbc98b162
3 files changed, 92 insertions, 0 deletions
diff --git a/server/src/com/vaadin/ui/UI.java b/server/src/com/vaadin/ui/UI.java index b16d7e32d3..2129db614b 100644 --- a/server/src/com/vaadin/ui/UI.java +++ b/server/src/com/vaadin/ui/UI.java @@ -718,6 +718,9 @@ public abstract class UI extends AbstractSingleComponentContainer implements page.init(request); + // Reset heartbeat timeout to avoid surprise if it's almost expired + setLastHeartbeatTimestamp(System.currentTimeMillis()); + refresh(request); URI newLocation = page.getLocation(); diff --git a/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeat.java b/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeat.java new file mode 100644 index 0000000000..de45d2bccb --- /dev/null +++ b/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeat.java @@ -0,0 +1,36 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.application; + +import com.vaadin.annotations.PreserveOnRefresh; +import com.vaadin.launcher.CustomDeploymentConfiguration; +import com.vaadin.launcher.CustomDeploymentConfiguration.Conf; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.Label; + +@PreserveOnRefresh +@CustomDeploymentConfiguration({ @Conf(name = "heartbeatInterval", value = "5") }) +public class PreserveWithExpiredHeartbeat extends AbstractTestUI { + + @Override + protected void setup(VaadinRequest request) { + Label label = new Label("UI with id " + getUIId() + " in session " + + getSession().getSession().getId()); + label.setId("idLabel"); + addComponent(label); + } +} diff --git a/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeatTest.java b/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeatTest.java new file mode 100644 index 0000000000..04dbdca31e --- /dev/null +++ b/uitest/src/com/vaadin/tests/application/PreserveWithExpiredHeartbeatTest.java @@ -0,0 +1,53 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.application; + +import org.junit.Assert; +import org.junit.Test; + +import com.vaadin.testbench.elements.LabelElement; +import com.vaadin.tests.tb3.SingleBrowserTest; + +public class PreserveWithExpiredHeartbeatTest extends SingleBrowserTest { + @Test + public void testNavigateBackAfterMissingHeartbeats() + throws InterruptedException { + final int heartbeatInterval = 5000; + + openTestURL(); + String originalId = getUiIdentification(); + + long startTime = System.currentTimeMillis(); + + while (System.currentTimeMillis() - startTime < heartbeatInterval * 3.1) { + // "Close" the tab + driver.get("about:blank"); + + sleep(heartbeatInterval / 2); + + // "Reopen" tab + openTestURL(); + + // Verify that that we still get the same UI + Assert.assertEquals("Original UI has been closed", originalId, + getUiIdentification()); + } + } + + private String getUiIdentification() { + return $(LabelElement.class).id("idLabel").getText(); + } +} |