summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorJohannes Dahlström <johannesd@vaadin.com>2014-09-03 16:46:40 +0300
committerSauli Tähkäpää <sauli@vaadin.com>2014-09-12 16:46:28 +0300
commit03097e75ccbbed2b434082f5cf939dec2a387bdf (patch)
tree1ae41aa04e60d3fcd7aa77be50d3245ef373d639 /server
parent0999abd4b3cd0628ab7f22aca765b7e06ca6eb69 (diff)
downloadvaadin-framework-03097e75ccbbed2b434082f5cf939dec2a387bdf.tar.gz
vaadin-framework-03097e75ccbbed2b434082f5cf939dec2a387bdf.zip
Fix potential invalid JSON output in MetadataWriter (#14591)
Change-Id: I90ec428ae11727b9762d53ebb8d94f8c850c425b
Diffstat (limited to 'server')
-rw-r--r--server/src/com/vaadin/server/communication/MetadataWriter.java1
-rw-r--r--server/tests/src/com/vaadin/server/communication/MetadataWriterTest.java14
2 files changed, 15 insertions, 0 deletions
diff --git a/server/src/com/vaadin/server/communication/MetadataWriter.java b/server/src/com/vaadin/server/communication/MetadataWriter.java
index 17c893fe40..9c46e64692 100644
--- a/server/src/com/vaadin/server/communication/MetadataWriter.java
+++ b/server/src/com/vaadin/server/communication/MetadataWriter.java
@@ -70,6 +70,7 @@ public class MetadataWriter implements Serializable {
if (metaOpen) {
writer.write(", ");
}
+ metaOpen = true;
writer.write("\"async\":true");
}
diff --git a/server/tests/src/com/vaadin/server/communication/MetadataWriterTest.java b/server/tests/src/com/vaadin/server/communication/MetadataWriterTest.java
index dee37ddc7f..afae14007e 100644
--- a/server/tests/src/com/vaadin/server/communication/MetadataWriterTest.java
+++ b/server/tests/src/com/vaadin/server/communication/MetadataWriterTest.java
@@ -18,6 +18,7 @@ package com.vaadin.server.communication;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
+import java.io.IOException;
import java.io.StringWriter;
import org.junit.Assert;
@@ -92,4 +93,17 @@ public class MetadataWriterTest {
"{\"timedRedirect\":{\"interval\":15,\"url\":\"\"}}", writer
.getBuffer().toString());
}
+
+ @Test
+ public void writeAsyncWithSystemMessages() throws IOException {
+ WrappedSession wrappedSession = mock(WrappedSession.class);
+ when(session.getSession()).thenReturn(wrappedSession);
+
+ disableSessionExpirationMessages(messages);
+
+ new MetadataWriter().write(ui, writer, false, true, messages);
+ Assert.assertEquals(
+ "{\"async\":true,\"timedRedirect\":{\"interval\":15,\"url\":\"\"}}",
+ writer.getBuffer().toString());
+ }
}