diff options
author | Artur <artur@vaadin.com> | 2017-03-07 09:46:33 +0200 |
---|---|---|
committer | Henri Sara <henri.sara@gmail.com> | 2017-03-16 12:32:19 +0200 |
commit | c299a6bb4803bb132409fa2b9c0d4b45636a7a4c (patch) | |
tree | 86033447576e86ce6ea107840306a86aa7122d2f | |
parent | 330329efcec873314f7aca7e17c1009d401a7bfd (diff) | |
download | vaadin-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.java | 20 | ||||
-rw-r--r-- | server/src/test/java/com/vaadin/server/communication/ServerRpcHandlerTest.java | 49 |
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 + } +} |