From 567a43038a64b1acef395cc248bcda31b0a72949 Mon Sep 17 00:00:00 2001 From: Artur Date: Thu, 2 Feb 2017 09:28:33 +0200 Subject: Make it easy to invoke ServerRpc methods as part of unit tests (#8346) Executing RPC methods is useful when testing component interaction with the server. Not only inside the framework but also when creating add-ons and applications. --- .../java/com/vaadin/server/ServerRpcManager.java | 25 ++++++++++++++++++++- .../component/combobox/ComboBoxFilteringTest.java | 4 ++-- .../com/vaadin/ui/AbstractMultiSelectTest.java | 3 ++- .../src/test/java/com/vaadin/ui/CheckBoxTest.java | 9 ++++---- .../src/test/java/com/vaadin/ui/ComboBoxTest.java | 3 ++- .../src/test/java/com/vaadin/ui/ComponentTest.java | 26 ---------------------- .../java/com/vaadin/ui/RadioButtonGroupTest.java | 3 ++- .../test/java/com/vaadin/ui/RichTextAreaTest.java | 8 ++++--- 8 files changed, 42 insertions(+), 39 deletions(-) diff --git a/server/src/main/java/com/vaadin/server/ServerRpcManager.java b/server/src/main/java/com/vaadin/server/ServerRpcManager.java index bb534efee7..d2c8d4d2e9 100644 --- a/server/src/main/java/com/vaadin/server/ServerRpcManager.java +++ b/server/src/main/java/com/vaadin/server/ServerRpcManager.java @@ -24,7 +24,6 @@ import java.util.Map; import java.util.logging.Level; import java.util.logging.Logger; -import com.vaadin.shared.Connector; import com.vaadin.shared.communication.ServerRpc; /** @@ -166,4 +165,28 @@ public class ServerRpcManager implements Serializable { return Logger.getLogger(ServerRpcManager.class.getName()); } + /** + * Returns an RPC proxy for a given client to server RPC interface for the + * given component or extension. + * + * @param connector + * the connector for which to the RPC proxy + * @param rpcInterface + * the RPC interface type + * + * @return a server RPC handler which can be used to invoke RPC methods + * @since 8.0 + */ + public static T getRpcProxy(ClientConnector connector, + final Class rpcInterface) { + + @SuppressWarnings("unchecked") + ServerRpcManager rpcManager = (ServerRpcManager) connector + .getRpcManager(rpcInterface.getName()); + if (rpcManager == null) { + return null; + } + return rpcManager.getImplementation(); + } + } diff --git a/server/src/test/java/com/vaadin/tests/server/component/combobox/ComboBoxFilteringTest.java b/server/src/test/java/com/vaadin/tests/server/component/combobox/ComboBoxFilteringTest.java index 159af4ad0b..f2c4b11689 100644 --- a/server/src/test/java/com/vaadin/tests/server/component/combobox/ComboBoxFilteringTest.java +++ b/server/src/test/java/com/vaadin/tests/server/component/combobox/ComboBoxFilteringTest.java @@ -29,12 +29,12 @@ import com.vaadin.data.provider.DataCommunicator; import com.vaadin.data.provider.DataProvider; import com.vaadin.data.provider.ListDataProvider; import com.vaadin.server.ClientMethodInvocation; +import com.vaadin.server.ServerRpcManager; import com.vaadin.shared.ui.combobox.ComboBoxServerRpc; import com.vaadin.tests.data.bean.Address; import com.vaadin.tests.data.bean.Person; import com.vaadin.tests.data.bean.Sex; import com.vaadin.ui.ComboBox; -import com.vaadin.ui.ComponentTest; /** * Test for ComboBox data providers and filtering. @@ -229,7 +229,7 @@ public class ComboBoxFilteringTest { // Discard any currently pending RPC calls dataCommunicator.retrievePendingRpcCalls(); - ComponentTest.getRpcProxy(comboBox, ComboBoxServerRpc.class) + ServerRpcManager.getRpcProxy(comboBox, ComboBoxServerRpc.class) .setFilter(filter); dataCommunicator.beforeClientResponse(true); diff --git a/server/src/test/java/com/vaadin/ui/AbstractMultiSelectTest.java b/server/src/test/java/com/vaadin/ui/AbstractMultiSelectTest.java index abed1563e5..7c7be05aae 100644 --- a/server/src/test/java/com/vaadin/ui/AbstractMultiSelectTest.java +++ b/server/src/test/java/com/vaadin/ui/AbstractMultiSelectTest.java @@ -41,6 +41,7 @@ import org.mockito.Mockito; import com.vaadin.data.HasValue.ValueChangeEvent; import com.vaadin.event.selection.MultiSelectionEvent; import com.vaadin.event.selection.MultiSelectionListener; +import com.vaadin.server.ServerRpcManager; import com.vaadin.shared.Registration; import com.vaadin.shared.data.selection.MultiSelectServerRpc; @@ -69,7 +70,7 @@ public class AbstractMultiSelectTest> { selectToTest.deselectAll(); // Intentional deviation from upcoming selection order selectToTest.setItems("3", "2", "1", "5", "8", "7", "4", "6"); - rpc = ComponentTest.getRpcProxy(selectToTest, + rpc = ServerRpcManager.getRpcProxy(selectToTest, MultiSelectServerRpc.class); values = new ArrayList<>(); diff --git a/server/src/test/java/com/vaadin/ui/CheckBoxTest.java b/server/src/test/java/com/vaadin/ui/CheckBoxTest.java index eb96656389..539d6fbf63 100644 --- a/server/src/test/java/com/vaadin/ui/CheckBoxTest.java +++ b/server/src/test/java/com/vaadin/ui/CheckBoxTest.java @@ -20,6 +20,7 @@ import java.util.concurrent.atomic.AtomicBoolean; import org.junit.Assert; import org.junit.Test; +import com.vaadin.server.ServerRpcManager; import com.vaadin.shared.MouseEventDetails; import com.vaadin.shared.ui.checkbox.CheckBoxServerRpc; import com.vaadin.tests.util.MockUI; @@ -50,13 +51,13 @@ public class CheckBoxTest { userOriginated.set(e.isUserOriginated()); }); ComponentTest.syncToClient(cb); - ComponentTest.getRpcProxy(cb, CheckBoxServerRpc.class).setChecked(true, - new MouseEventDetails()); + ServerRpcManager.getRpcProxy(cb, CheckBoxServerRpc.class) + .setChecked(true, new MouseEventDetails()); Assert.assertTrue(userOriginated.get()); userOriginated.set(false); ComponentTest.syncToClient(cb); - ComponentTest.getRpcProxy(cb, CheckBoxServerRpc.class).setChecked(false, - new MouseEventDetails()); + ServerRpcManager.getRpcProxy(cb, CheckBoxServerRpc.class) + .setChecked(false, new MouseEventDetails()); Assert.assertTrue(userOriginated.get()); } diff --git a/server/src/test/java/com/vaadin/ui/ComboBoxTest.java b/server/src/test/java/com/vaadin/ui/ComboBoxTest.java index 36b29fdd7a..31ff6fda5a 100644 --- a/server/src/test/java/com/vaadin/ui/ComboBoxTest.java +++ b/server/src/test/java/com/vaadin/ui/ComboBoxTest.java @@ -17,6 +17,7 @@ package com.vaadin.ui; import org.junit.Test; +import com.vaadin.server.ServerRpcManager; import com.vaadin.shared.data.selection.SelectionServerRpc; import com.vaadin.tests.util.MockUI; @@ -38,7 +39,7 @@ public class ComboBoxTest { // Emulate selection of "one" String oneKey = comboBox.getDataCommunicator().getKeyMapper() .key("one"); - ComponentTest.getRpcProxy(comboBox, SelectionServerRpc.class) + ServerRpcManager.getRpcProxy(comboBox, SelectionServerRpc.class) .select(oneKey); ComponentTest.assertEncodedStateProperties(comboBox, diff --git a/server/src/test/java/com/vaadin/ui/ComponentTest.java b/server/src/test/java/com/vaadin/ui/ComponentTest.java index c9ff9c7de4..4907f945ac 100644 --- a/server/src/test/java/com/vaadin/ui/ComponentTest.java +++ b/server/src/test/java/com/vaadin/ui/ComponentTest.java @@ -15,15 +15,12 @@ */ package com.vaadin.ui; -import java.lang.reflect.Method; import java.util.Arrays; import java.util.HashSet; import org.junit.Assert; import com.vaadin.server.ClientConnector; -import com.vaadin.server.ServerRpcManager; -import com.vaadin.shared.communication.ServerRpc; import elemental.json.JsonObject; @@ -70,29 +67,6 @@ public class ComponentTest { } - /** - * Gets the server rpc handler registered for a component. - * - * @param component - * the component which listens to the RPC - * @param serverRpcClass - * the server RPC class - * @return the server RPC handler - */ - public static T getRpcProxy(Component component, - Class serverRpcClass) { - try { - ServerRpcManager rpcManager = component - .getRpcManager(serverRpcClass.getName()); - Method method = ServerRpcManager.class - .getDeclaredMethod("getImplementation"); - method.setAccessible(true); - return serverRpcClass.cast(method.invoke(rpcManager)); - } catch (ReflectiveOperationException e) { - throw new RuntimeException(e); - } - } - /** * Asserts the set of properties that would be sent as state changes for the * given connector. diff --git a/server/src/test/java/com/vaadin/ui/RadioButtonGroupTest.java b/server/src/test/java/com/vaadin/ui/RadioButtonGroupTest.java index 136b23984a..fadbf28507 100644 --- a/server/src/test/java/com/vaadin/ui/RadioButtonGroupTest.java +++ b/server/src/test/java/com/vaadin/ui/RadioButtonGroupTest.java @@ -25,6 +25,7 @@ import org.junit.Test; import com.vaadin.data.SelectionModel.Multi; import com.vaadin.data.provider.DataProvider; +import com.vaadin.server.ServerRpcManager; import com.vaadin.shared.data.selection.SelectionServerRpc; public class RadioButtonGroupTest { @@ -65,7 +66,7 @@ public class RadioButtonGroupTest { Assert.assertTrue(event.isUserOriginated()); }); - SelectionServerRpc rpc = ComponentTest.getRpcProxy(radioButtonGroup, + SelectionServerRpc rpc = ServerRpcManager.getRpcProxy(radioButtonGroup, SelectionServerRpc.class); rpc.select(getItemKey("First")); diff --git a/server/src/test/java/com/vaadin/ui/RichTextAreaTest.java b/server/src/test/java/com/vaadin/ui/RichTextAreaTest.java index 56f1293556..7c042df931 100644 --- a/server/src/test/java/com/vaadin/ui/RichTextAreaTest.java +++ b/server/src/test/java/com/vaadin/ui/RichTextAreaTest.java @@ -15,7 +15,6 @@ */ package com.vaadin.ui; -import static com.vaadin.ui.ComponentTest.getRpcProxy; import static com.vaadin.ui.ComponentTest.isDirty; import static com.vaadin.ui.ComponentTest.syncToClient; import static com.vaadin.ui.ComponentTest.updateDiffState; @@ -24,6 +23,7 @@ import org.junit.Assert; import org.junit.Test; import com.vaadin.server.ClientConnector; +import com.vaadin.server.ServerRpcManager; import com.vaadin.server.ServerRpcManager.RpcInvocationException; import com.vaadin.shared.ui.richtextarea.RichTextAreaServerRpc; import com.vaadin.tests.util.MockUI; @@ -59,7 +59,8 @@ public class RichTextAreaTest { // Client thinks the field says "foo" but it won't be updated because // the field is readonly - getRpcProxy(rta, RichTextAreaServerRpc.class).setText("foo"); + ServerRpcManager.getRpcProxy(rta, RichTextAreaServerRpc.class) + .setText("foo"); // The real value will be sent back as long as the field is marked as // dirty and diffstate contains what the client has @@ -75,7 +76,8 @@ public class RichTextAreaTest { rta.setValue("bar"); updateDiffState(rta); - getRpcProxy(rta, RichTextAreaServerRpc.class).setText("foo"); + ServerRpcManager.getRpcProxy(rta, RichTextAreaServerRpc.class) + .setText("foo"); Assert.assertEquals("foo", getDiffStateString(rta, "value")); } -- cgit v1.2.3