summaryrefslogtreecommitdiffstats
path: root/server/tests
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-10-09 23:44:47 +0300
committerVaadin Code Review <review@vaadin.com>2015-11-12 10:54:33 +0000
commitf3eb1b4383848e28447717502083439d9e0dc0b7 (patch)
treebb81ac60f1b98ef3ea5121a62908b60a14ba4318 /server/tests
parent142f7dcebb249c9c458cdbade014212b1a9ac27d (diff)
downloadvaadin-framework-f3eb1b4383848e28447717502083439d9e0dc0b7.tar.gz
vaadin-framework-f3eb1b4383848e28447717502083439d9e0dc0b7.zip
Do not modify state while serializing (#19090)
Serializing an object should never modify its internal state. It should be possible to serialize an object multiple times and get the same result Change-Id: I983e2eec1b3fb374bf40f150bdb9918ac5791d62
Diffstat (limited to 'server/tests')
-rw-r--r--server/tests/src/com/vaadin/tests/server/ClientMethodSerializationTest.java30
1 files changed, 30 insertions, 0 deletions
diff --git a/server/tests/src/com/vaadin/tests/server/ClientMethodSerializationTest.java b/server/tests/src/com/vaadin/tests/server/ClientMethodSerializationTest.java
index da6bc76a0f..1ec19724d8 100644
--- a/server/tests/src/com/vaadin/tests/server/ClientMethodSerializationTest.java
+++ b/server/tests/src/com/vaadin/tests/server/ClientMethodSerializationTest.java
@@ -24,13 +24,16 @@ import java.lang.reflect.Method;
import junit.framework.TestCase;
+import com.vaadin.server.ClientConnector;
import com.vaadin.server.ClientMethodInvocation;
import com.vaadin.server.JavaScriptCallbackHelper;
+import com.vaadin.server.JsonCodec;
import com.vaadin.ui.JavaScript.JavaScriptCallbackRpc;
import com.vaadin.util.ReflectTools;
import elemental.json.Json;
import elemental.json.JsonArray;
+import elemental.json.JsonValue;
import elemental.json.impl.JsonUtil;
public class ClientMethodSerializationTest extends TestCase {
@@ -112,4 +115,31 @@ public class ClientMethodSerializationTest extends TestCase {
return output;
}
+ public void testSerializeTwice() {
+ String name = "javascriptFunctionName";
+ String[] arguments = { "1", "2", "3" };
+ JsonArray args = (JsonArray) JsonCodec.encode(arguments, null,
+ Object[].class, null).getEncodedValue();
+ ClientConnector connector = null;
+
+ ClientMethodInvocation original = new ClientMethodInvocation(connector,
+ "interfaceName", JAVASCRIPT_CALLBACK_METHOD, new Object[] {
+ name, args });
+
+ ClientMethodInvocation copy = (ClientMethodInvocation) serializeAndDeserialize(original);
+ assertEquals(copy.getMethodName(), original.getMethodName());
+ assertEquals(copy.getParameters().length,
+ original.getParameters().length);
+ for (int i = 0; i < copy.getParameters().length; i++) {
+ Object originalParameter = original.getParameters()[i];
+ Object copyParameter = copy.getParameters()[i];
+ if (originalParameter instanceof JsonValue) {
+ assertEquals(((JsonValue) originalParameter).toJson(),
+ ((JsonValue) copyParameter).toJson());
+ } else {
+ assertEquals(originalParameter, copyParameter);
+ }
+ }
+ }
+
}