diff --git a/flow-client/src/main/java/com/vaadin/client/SystemErrorHandler.java b/flow-client/src/main/java/com/vaadin/client/SystemErrorHandler.java
index d4b44b2c89a..5133c99f4c1 100644
--- a/flow-client/src/main/java/com/vaadin/client/SystemErrorHandler.java
+++ b/flow-client/src/main/java/com/vaadin/client/SystemErrorHandler.java
@@ -180,21 +180,21 @@ private Element handleError(String caption, String message, String details,
if (caption != null) {
Element captionDiv = document.createDivElement();
captionDiv.setClassName("caption");
- captionDiv.setInnerHTML(caption);
+ captionDiv.setTextContent(caption);
systemErrorContainer.appendChild(captionDiv);
Console.error(caption);
}
if (message != null) {
Element messageDiv = document.createDivElement();
messageDiv.setClassName("message");
- messageDiv.setInnerHTML(message);
+ messageDiv.setTextContent(message);
systemErrorContainer.appendChild(messageDiv);
Console.error(message);
}
if (details != null) {
Element detailsDiv = document.createDivElement();
detailsDiv.setClassName("details");
- detailsDiv.setInnerHTML(details);
+ detailsDiv.setTextContent(details);
systemErrorContainer.appendChild(detailsDiv);
Console.error(details);
}
diff --git a/flow-client/src/test-gwt/java/com/vaadin/client/GwtSuite.java b/flow-client/src/test-gwt/java/com/vaadin/client/GwtSuite.java
index 52959ca6274..7fb0014b827 100644
--- a/flow-client/src/test-gwt/java/com/vaadin/client/GwtSuite.java
+++ b/flow-client/src/test-gwt/java/com/vaadin/client/GwtSuite.java
@@ -1,13 +1,14 @@
package com.vaadin.client;
-import com.vaadin.client.communication.GwtDefaultConnectionStateHandlerTest;
import junit.framework.Test;
import junit.framework.TestSuite;
import com.google.gwt.junit.tools.GWTTestSuite;
import com.vaadin.client.communication.GwtAtmoshperePushConnectionTest;
+import com.vaadin.client.communication.GwtDefaultConnectionStateHandlerTest;
import com.vaadin.client.flow.GwtBasicElementBinderTest;
+import com.vaadin.client.flow.GwtErrotHandlerTest;
import com.vaadin.client.flow.GwtEventHandlerTest;
import com.vaadin.client.flow.GwtMultipleBindingTest;
import com.vaadin.client.flow.GwtPolymerModelTest;
@@ -53,6 +54,7 @@ public static Test suite() {
suite.addTestSuite(GwtMessageHandlerTest.class);
suite.addTestSuite(GwtMultipleBindingTest.class);
suite.addTestSuite(GwtDefaultConnectionStateHandlerTest.class);
+ suite.addTestSuite(GwtErrotHandlerTest.class);
return suite;
}
}
diff --git a/flow-client/src/test-gwt/java/com/vaadin/client/flow/GwtErrotHandlerTest.java b/flow-client/src/test-gwt/java/com/vaadin/client/flow/GwtErrotHandlerTest.java
new file mode 100644
index 00000000000..476746980e6
--- /dev/null
+++ b/flow-client/src/test-gwt/java/com/vaadin/client/flow/GwtErrotHandlerTest.java
@@ -0,0 +1,64 @@
+/*
+ * Copyright 2000-2021 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.client.flow;
+
+import com.vaadin.client.ApplicationConfiguration;
+import com.vaadin.client.ClientEngineTestBase;
+import com.vaadin.client.Registry;
+import com.vaadin.client.SystemErrorHandler;
+import com.vaadin.client.flow.reactive.Reactive;
+
+import elemental.client.Browser;
+import elemental.dom.Element;
+
+public class GwtErrotHandlerTest extends ClientEngineTestBase {
+
+ private Registry registry;
+
+ @Override
+ protected void gwtSetUp() throws Exception {
+ super.gwtSetUp();
+ Reactive.reset();
+
+ registry = new Registry() {
+ {
+ set(ApplicationConfiguration.class,
+ new ApplicationConfiguration());
+ set(SystemErrorHandler.class, new SystemErrorHandler(this));
+ }
+ };
+
+ }
+
+ public void testhandleUnrecoverableError_textContentIsSetInDivsNotInnerHtml() {
+ registry.getSystemErrorHandler().handleUnrecoverableError("",
+ "", "", null);
+ Element container = Browser.getDocument().getBody()
+ .querySelector(".v-system-error");
+ Element caption = container.querySelector(".caption");
+ Element message = container.querySelector(".message");
+ Element details = container.querySelector(".details");
+
+ assertEquals("<foo></foo>", caption.getInnerHTML());
+ assertEquals("", caption.getTextContent());
+
+ assertEquals("<bar></bar>", message.getInnerHTML());
+ assertEquals("", message.getTextContent());
+
+ assertEquals("<baz></baz>", details.getInnerHTML());
+ assertEquals("", details.getTextContent());
+ }
+}