diff options
author | Leif Ã…strand <leif@vaadin.com> | 2015-06-03 11:30:06 +0300 |
---|---|---|
committer | Johannes Dahlström <johannesd@vaadin.com> | 2015-06-08 17:47:43 +0300 |
commit | af215380ffa86960c3780fe4bc699b879c1cec68 (patch) | |
tree | 693988cd1220d24c64adc2a13c3c60f0e84e49c9 | |
parent | 5d33446d05972f3aea18675a346ad50edf289194 (diff) | |
download | vaadin-framework-af215380ffa86960c3780fe4bc699b879c1cec68.tar.gz vaadin-framework-af215380ffa86960c3780fe4bc699b879c1cec68.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 8dd600ddd0..2c04e587c9 100644 --- a/server/src/com/vaadin/ui/UI.java +++ b/server/src/com/vaadin/ui/UI.java @@ -689,6 +689,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(); + } +} |