From 3d0ddd70342bee8826997e9a2343a5741e243a0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kjetil=20=C3=98rbekk?= Date: Fri, 27 Jan 2012 13:47:26 +0100 Subject: ClientService supports network discovery. --- .../main/java/com/orbekk/same/ClientServiceImpl.java | 19 ++++++++++++++----- .../com/orbekk/same/NetworkNotificationListener.java | 5 +++++ .../java/com/orbekk/same/ClientServiceImplTest.java | 9 +++++++++ 3 files changed, 28 insertions(+), 5 deletions(-) create mode 100644 same/src/main/java/com/orbekk/same/NetworkNotificationListener.java (limited to 'same') diff --git a/same/src/main/java/com/orbekk/same/ClientServiceImpl.java b/same/src/main/java/com/orbekk/same/ClientServiceImpl.java index 43c8b2f..8aaaa95 100644 --- a/same/src/main/java/com/orbekk/same/ClientServiceImpl.java +++ b/same/src/main/java/com/orbekk/same/ClientServiceImpl.java @@ -9,7 +9,8 @@ public class ClientServiceImpl implements ClientService, UrlReceiver { private ConnectionManager connections; private State state; private String myUrl = null; - private StateChangedListener listener; + private StateChangedListener stateListener; + private NetworkNotificationListener networkListener; public ClientServiceImpl(State state, ConnectionManager connections) { this.state = state; @@ -18,15 +19,19 @@ public class ClientServiceImpl implements ClientService, UrlReceiver { @Override public void notifyNetwork(String networkName, String masterUrl) { - logger.error("NotifyNetwork not yet implemented."); + logger.info("NotifyNetwork(networkName={}, masterUrl={})", + networkName, masterUrl); + if (networkListener != null) { + networkListener.notifyNetwork(networkName, masterUrl); + } } @Override public void setState(String component, String data, long revision) { boolean status = state.update(component, data, revision); if (status) { - if (listener != null) { - listener.stateChanged(component, data); + if (stateListener != null) { + stateListener.stateChanged(component, data); } } else { logger.warn("Ignoring update: {}", @@ -93,6 +98,10 @@ public class ClientServiceImpl implements ClientService, UrlReceiver { } public void setStateChangedListener(StateChangedListener listener) { - this.listener = listener; + this.stateListener = listener; + } + + public void setNetworkListener(NetworkNotificationListener listener) { + this.networkListener = listener; } } diff --git a/same/src/main/java/com/orbekk/same/NetworkNotificationListener.java b/same/src/main/java/com/orbekk/same/NetworkNotificationListener.java new file mode 100644 index 0000000..14c758f --- /dev/null +++ b/same/src/main/java/com/orbekk/same/NetworkNotificationListener.java @@ -0,0 +1,5 @@ +package com.orbekk.same; + +public interface NetworkNotificationListener { + void notifyNetwork(String networkName, String masterUrl); +} diff --git a/same/src/test/java/com/orbekk/same/ClientServiceImplTest.java b/same/src/test/java/com/orbekk/same/ClientServiceImplTest.java index 2baa829..39c0e7c 100644 --- a/same/src/test/java/com/orbekk/same/ClientServiceImplTest.java +++ b/same/src/test/java/com/orbekk/same/ClientServiceImplTest.java @@ -3,6 +3,7 @@ package com.orbekk.same; import static org.junit.Assert.*; import org.junit.Test; +import static org.mockito.Mockito.*; public class ClientServiceImplTest { private State state = new State("ClientNetwork"); @@ -15,4 +16,12 @@ public class ClientServiceImplTest { assertEquals(100, state.getRevision("TestState")); assertEquals("Test data", state.getDataOf("TestState")); } + + @Test public void testNetworkListener() { + NetworkNotificationListener listener = + mock(NetworkNotificationListener.class); + client.setNetworkListener(listener); + client.notifyNetwork("MyNetwork", "MasterUrl"); + verify(listener).notifyNetwork("MyNetwork", "MasterUrl"); + } } -- cgit v1.2.3