diff options
author | Teemu Suo-Anttila <tsuoanttila@users.noreply.github.com> | 2017-11-27 13:15:56 +0200 |
---|---|---|
committer | Teemu Suo-Anttila <tsuoanttila@users.noreply.github.com> | 2017-12-07 12:19:06 +0200 |
commit | 69a49a1f5e0c9f1a31a15145525f9d47e6617e0e (patch) | |
tree | dd3872864a44d84f88d277b81c1ed379abb5f6db /uitest/src | |
parent | ce843f4247ba940dba27236c075faca7ccf82838 (diff) | |
download | vaadin-framework-69a49a1f5e0c9f1a31a15145525f9d47e6617e0e.tar.gz vaadin-framework-69a49a1f5e0c9f1a31a15145525f9d47e6617e0e.zip |
Prevent killing UI if heartbeats are pending (#10371)
Fixes #9663
Diffstat (limited to 'uitest/src')
-rw-r--r-- | uitest/src/main/java/com/vaadin/tests/core/LockingUI.java | 47 | ||||
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/core/LockingUITest.java | 47 |
2 files changed, 94 insertions, 0 deletions
diff --git a/uitest/src/main/java/com/vaadin/tests/core/LockingUI.java b/uitest/src/main/java/com/vaadin/tests/core/LockingUI.java new file mode 100644 index 0000000000..ba0cf9e008 --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/core/LockingUI.java @@ -0,0 +1,47 @@ +package com.vaadin.tests.core; + +import com.vaadin.launcher.CustomDeploymentConfiguration; +import com.vaadin.launcher.CustomDeploymentConfiguration.Conf; +import com.vaadin.server.VaadinRequest; +import com.vaadin.server.VaadinService; +import com.vaadin.ui.Button; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Notification.Type; +import com.vaadin.ui.UI; +import com.vaadin.ui.VerticalLayout; + +@CustomDeploymentConfiguration({ + @Conf(name = "heartbeatInterval", value = "2") }) +public class LockingUI extends UI { + + public static final String LOCKING_ENDED = "Locking has ended"; + public static final String ALL_OK = "All is fine"; + + @Override + protected void init(VaadinRequest request) { + Button lockButton = new Button("Lock UI for too long", e -> { + int heartbeatInterval = VaadinService.getCurrent() + .getDeploymentConfiguration().getHeartbeatInterval(); + try { + // Wait for 4 heartbeats + long timeout = heartbeatInterval * 1000; + for (int i = 0; i < 4; ++i) { + Thread.sleep(timeout); + } + + } catch (InterruptedException e1) { + throw new RuntimeException( + "Timeout should not get interrupted."); + } + Notification.show(LOCKING_ENDED, Type.TRAY_NOTIFICATION); + }); + Button checkButton = new Button("Test communication", + e -> Notification.show(ALL_OK, Type.TRAY_NOTIFICATION)); + + lockButton.setId("lock"); + checkButton.setId("check"); + + setContent(new VerticalLayout(lockButton, checkButton)); + } + +} diff --git a/uitest/src/test/java/com/vaadin/tests/core/LockingUITest.java b/uitest/src/test/java/com/vaadin/tests/core/LockingUITest.java new file mode 100644 index 0000000000..214adfc94d --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/core/LockingUITest.java @@ -0,0 +1,47 @@ +package com.vaadin.tests.core; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertFalse; +import static org.junit.Assert.assertTrue; + +import org.junit.Test; + +import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.testbench.elements.NotificationElement; +import com.vaadin.tests.tb3.SingleBrowserTest; + +public class LockingUITest extends SingleBrowserTest { + + @Test + public void testLockingTheUIFor4HeartBeats() { + openTestURL(); + + clickButtonAndCheckNotification("check", LockingUI.ALL_OK); + clickButtonAndCheckNotification("lock", LockingUI.LOCKING_ENDED); + clickButtonAndCheckNotification("check", LockingUI.ALL_OK); + } + + private void clickButtonAndCheckNotification(String buttonId, String text) { + checkNoInitialNotification(); + + $(ButtonElement.class).id(buttonId).click(); + testBench().waitForVaadin(); + + checkNotification(text); + } + + private void checkNotification(String text) { + assertTrue("Notification should be displayed", + $(NotificationElement.class).exists()); + + NotificationElement notification = $(NotificationElement.class).first(); + assertEquals("Unexpected text content in Notification", text, + notification.getText()); + notification.close(); + } + + private void checkNoInitialNotification() { + assertFalse("Extra notification displayed", + $(NotificationElement.class).exists()); + } +} |