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()); + } +}