From 49f70390add1655fc5eb846e7700d00cb57b5048 Mon Sep 17 00:00:00 2001 From: Anna Koskinen Date: Mon, 7 Dec 2020 16:40:15 +0200 Subject: Better error handling trying to enable HTML5 DnD for mobile from thread (#12170) - Informative error message - Reset back to disabled state when enabling fails - Incorrect usage also detectable using non-mobile devices Fixes #12152 --- server/src/main/java/com/vaadin/ui/UI.java | 7 ++++ .../components/ui/MobileHtml5DndEnablingError.java | 46 ++++++++++++++++++++++ .../ui/MobileHtml5DndEnablingErrorTest.java | 19 +++++++++ 3 files changed, 72 insertions(+) create mode 100644 uitest/src/main/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingError.java create mode 100644 uitest/src/test/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingErrorTest.java diff --git a/server/src/main/java/com/vaadin/ui/UI.java b/server/src/main/java/com/vaadin/ui/UI.java index 5891addca4..7430c04bb9 100644 --- a/server/src/main/java/com/vaadin/ui/UI.java +++ b/server/src/main/java/com/vaadin/ui/UI.java @@ -1987,6 +1987,13 @@ public abstract class UI extends AbstractSingleComponentContainer getState().enableMobileHTML5DnD = enabled; if (isMobileHtml5DndEnabled()) { + if (VaadinService.getCurrentRequest() == null) { + getState().enableMobileHTML5DnD = false; + throw new IllegalStateException("HTML5 DnD cannot be " + + "enabled for mobile devices when current " + + "VaadinRequest cannot be accessed. Call this " + + "method from init(VaadinRequest) to ensure access."); + } loadMobileHtml5DndPolyfill(); } } diff --git a/uitest/src/main/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingError.java b/uitest/src/main/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingError.java new file mode 100644 index 0000000000..8742d26aeb --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingError.java @@ -0,0 +1,46 @@ +package com.vaadin.tests.components.ui; + +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.Label; + +public class MobileHtml5DndEnablingError extends AbstractTestUI { + + @Override + protected void setup(VaadinRequest request) { + final MobileHtml5DndEnablingError ui = MobileHtml5DndEnablingError.this; + new Thread() { + @Override + public void run() { + try { + Thread.sleep(100); + } catch (InterruptedException e) { + } + ui.access(() -> { + Label label; + try { + ui.setMobileHtml5DndEnabled(true); + label = new Label( + "If you see this, there was no error."); + } catch (Exception e) { + label = new Label("Error message: " + e.getMessage()); + } + label.setId("error"); + label.setSizeFull(); + ui.addComponent(label); + }); + } + }.start(); + } + + @Override + protected String getTestDescription() { + return "Attempting to set HTML5 DnD enabled for mobile devices from " + + "a thread should give an informative error message."; + } + + @Override + protected Integer getTicketNumber() { + return 12152; + } +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingErrorTest.java b/uitest/src/test/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingErrorTest.java new file mode 100644 index 0000000000..b549c63200 --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingErrorTest.java @@ -0,0 +1,19 @@ +package com.vaadin.tests.components.ui; + +import static org.junit.Assert.assertTrue; + +import org.junit.Test; + +import com.vaadin.testbench.elements.LabelElement; +import com.vaadin.tests.tb3.SingleBrowserTest; + +public class MobileHtml5DndEnablingErrorTest extends SingleBrowserTest { + + @Test + public void testErrorMessage() { + openTestURL(); + LabelElement label = $(LabelElement.class).id("error"); + assertTrue("Unexpected Label content: " + label.getText(), + label.getText().startsWith("Error message: HTML5 DnD cannot")); + } +} -- cgit v1.2.3