aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/src/main/java/com/vaadin/ui/UI.java7
-rw-r--r--uitest/src/main/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingError.java46
-rw-r--r--uitest/src/test/java/com/vaadin/tests/components/ui/MobileHtml5DndEnablingErrorTest.java19
3 files changed, 72 insertions, 0 deletions
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"));
+ }
+}