aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur <artur@vaadin.com>2017-03-07 09:46:33 +0200
committerHenri Sara <henri.sara@gmail.com>2017-03-16 12:32:19 +0200
commitc299a6bb4803bb132409fa2b9c0d4b45636a7a4c (patch)
tree86033447576e86ce6ea107840306a86aa7122d2f
parent330329efcec873314f7aca7e17c1009d401a7bfd (diff)
downloadvaadin-framework-c299a6bb4803bb132409fa2b9c0d4b45636a7a4c.tar.gz
vaadin-framework-c299a6bb4803bb132409fa2b9c0d4b45636a7a4c.zip
Handle unknown connectors consistently and quietly as described in #8111 (#8741)
Fixes #8629
-rw-r--r--server/src/main/java/com/vaadin/server/communication/ServerRpcHandler.java20
-rw-r--r--server/src/test/java/com/vaadin/server/communication/ServerRpcHandlerTest.java49
2 files changed, 63 insertions, 6 deletions
diff --git a/server/src/main/java/com/vaadin/server/communication/ServerRpcHandler.java b/server/src/main/java/com/vaadin/server/communication/ServerRpcHandler.java
index bee4720273..e4783cbf6e 100644
--- a/server/src/main/java/com/vaadin/server/communication/ServerRpcHandler.java
+++ b/server/src/main/java/com/vaadin/server/communication/ServerRpcHandler.java
@@ -350,11 +350,9 @@ public class ServerRpcHandler implements Serializable {
final ClientConnector connector = connectorTracker
.getConnector(invocation.getConnectorId());
if (connector == null) {
- getLogger().log(Level.WARNING,
- "Received RPC call for unknown connector with id {0} (tried to invoke {1}.{2})",
- new Object[] { invocation.getConnectorId(),
- invocation.getInterfaceName(),
- invocation.getMethodName() });
+ logUnknownConnector(invocation.getConnectorId(),
+ invocation.getInterfaceName(),
+ invocation.getMethodName());
continue;
}
@@ -423,6 +421,13 @@ public class ServerRpcHandler implements Serializable {
}
}
+ private void logUnknownConnector(String connectorId, String interfaceName,
+ String methodName) {
+ getLogger().log(Level.FINE,
+ "Received RPC call for unknown connector with id {0} (tried to invoke {1}.{2})",
+ new Object[] { connectorId, interfaceName, methodName });
+ }
+
/**
* Handles the given RPC method invocation for the given connector
*
@@ -575,7 +580,10 @@ public class ServerRpcHandler implements Serializable {
JsonArray parametersJson, ConnectorTracker connectorTracker)
throws JsonException {
ClientConnector connector = connectorTracker.getConnector(connectorId);
-
+ if (connector == null) {
+ logUnknownConnector(connectorId, interfaceName, methodName);
+ return null;
+ }
ServerRpcManager<?> rpcManager = connector.getRpcManager(interfaceName);
if (rpcManager == null) {
/*
diff --git a/server/src/test/java/com/vaadin/server/communication/ServerRpcHandlerTest.java b/server/src/test/java/com/vaadin/server/communication/ServerRpcHandlerTest.java
new file mode 100644
index 0000000000..70ef0f4fb9
--- /dev/null
+++ b/server/src/test/java/com/vaadin/server/communication/ServerRpcHandlerTest.java
@@ -0,0 +1,49 @@
+package com.vaadin.server.communication;
+
+import org.junit.Test;
+import org.mockito.Mockito;
+
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.server.VaadinService;
+import com.vaadin.tests.util.AlwaysLockedVaadinSession;
+import com.vaadin.ui.UI;
+
+import elemental.json.Json;
+import elemental.json.JsonArray;
+
+public class ServerRpcHandlerTest {
+
+ public static class TestUI extends UI {
+
+ @Override
+ protected void init(VaadinRequest request) {
+
+ }
+
+ }
+
+ @Test
+ public void handleUnknownConnector() {
+ ServerRpcHandler rpcHandler = new ServerRpcHandler();
+ JsonArray invocation = Json.createArray();
+ invocation.set(0, "12");
+ invocation.set(1, "someInterface");
+ invocation.set(2, "someMethod");
+ JsonArray params = Json.createArray();
+ invocation.set(3, params);
+
+ JsonArray invocationData = Json.createArray();
+ invocationData.set(0, invocation);
+
+ AlwaysLockedVaadinSession s = new AlwaysLockedVaadinSession(
+ Mockito.mock(VaadinService.class));
+ TestUI ui = new TestUI();
+ ui.doInit(Mockito.mock(VaadinRequest.class), 1, null);
+ ui.setSession(s);
+ s.addUI(ui);
+ rpcHandler.handleInvocations(ui, 1, invocationData);
+
+ // This only tests that an invocation for a non-existant connector does
+ // not cause any exceptions
+ }
+}