From 4a4dc574fcb44f5d92b488de1efeba40d1e6469f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kjetil=20=C3=98rbekk?= Date: Fri, 2 Mar 2012 13:58:09 +0100 Subject: Begin implementing discovery service. --- discovery/pom.xml | 110 +++++++++++++++++++++ .../orbekk/same/discovery/DiscoveryService.java | 22 +++++ .../same/discovery/DiscoveryServiceImpl.java | 5 + .../com/orbekk/same/discovery/NetworkEntry.java | 30 ++++++ .../orbekk/same/discovery/NetworkEntryTest.java | 25 +++++ 5 files changed, 192 insertions(+) create mode 100644 discovery/pom.xml create mode 100644 discovery/src/main/java/com/orbekk/same/discovery/DiscoveryService.java create mode 100644 discovery/src/main/java/com/orbekk/same/discovery/DiscoveryServiceImpl.java create mode 100644 discovery/src/main/java/com/orbekk/same/discovery/NetworkEntry.java create mode 100644 discovery/src/test/java/com/orbekk/same/discovery/NetworkEntryTest.java diff --git a/discovery/pom.xml b/discovery/pom.xml new file mode 100644 index 0000000..d3e9cd7 --- /dev/null +++ b/discovery/pom.xml @@ -0,0 +1,110 @@ + + + 4.0.0 + com.orbekk.same.discovery + discovery-server + 1.0-SNAPSHOT + jar + same + http://github.com/orbekk/master + + UTF-8 + + + + jsonrpc3j-webdav-maven-repo + jsonrpc4j maven repository + http://jsonrpc4j.googlecode.com/svn/maven/repo/ + default + + + + + com.googlecode + jsonrpc4j + 0.18 + + + org.codehaus.jackson + jackson-mapper-asl + 1.7.5 + + + junit + junit + 4.10 + test + + + org.mockito + mockito-all + 1.9.0 + test + + + org.slf4j + slf4j-api + 1.6.4 + + + org.slf4j + slf4j-log4j12 + 1.6.4 + + + javax.servlet + servlet-api + 2.5 + + + javax.portlet + portlet-api + 2.0 + + + org.eclipse.jetty + jetty-servlet + 8.0.0.M3 + + + org.eclipse.jetty + jetty-server + 8.0.0.M3 + + + org.jboss.resteasy + tjws + 2.3.1.GA + + + org.apache.httpcomponents + httpclient + 4.1.2 + + + + + + maven-assembly-plugin + + + + com.orbekk.same.App + + + + jar-with-dependencies + + + + + maven-compiler-plugin + 2.3.2 + + 1.6 + 1.6 + + + + + diff --git a/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryService.java b/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryService.java new file mode 100644 index 0000000..04fdab0 --- /dev/null +++ b/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryService.java @@ -0,0 +1,22 @@ +package com.orbekk.same.discovery; + +import java.util.List; + +/** + * Maintains a registry of available networks. + * + * The discovery service is only meant to be used for debugging. + */ +public interface DiscoveryService { + /** + * Returns a list of network names and master urls interleaved, i.e., + * + * [NetworkName1, MasterUrl1, ...] + */ + List getNetworks() throws Exception; + + /** + * Register a network. + */ + void registerNetwork(String networkName, String masterUrl) throws Exception; +} diff --git a/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryServiceImpl.java b/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryServiceImpl.java new file mode 100644 index 0000000..f568213 --- /dev/null +++ b/discovery/src/main/java/com/orbekk/same/discovery/DiscoveryServiceImpl.java @@ -0,0 +1,5 @@ +package com.orbekk.same.discovery; + +public class DiscoveryServiceImpl { + +} diff --git a/discovery/src/main/java/com/orbekk/same/discovery/NetworkEntry.java b/discovery/src/main/java/com/orbekk/same/discovery/NetworkEntry.java new file mode 100644 index 0000000..11c7f90 --- /dev/null +++ b/discovery/src/main/java/com/orbekk/same/discovery/NetworkEntry.java @@ -0,0 +1,30 @@ +package com.orbekk.same.discovery; + +public class NetworkEntry { + public String networkName; + public String masterUrl; + private long lastRegisteredMillis = -1; + + public NetworkEntry(String networkName, String masterUrl) { + this.networkName = networkName; + this.masterUrl = masterUrl; + } + + public void register(long registeredTime) { + lastRegisteredMillis = registeredTime; + } + + public boolean hasExpired(long latestValidTimeMillis) { + return lastRegisteredMillis < latestValidTimeMillis; + } + + @Override + public boolean equals(Object other) { + if (other instanceof NetworkEntry) { + NetworkEntry otherEntry = (NetworkEntry)other; + return networkName.equals(otherEntry.networkName) && + masterUrl.equals(otherEntry.masterUrl); + } + return false; + } +} diff --git a/discovery/src/test/java/com/orbekk/same/discovery/NetworkEntryTest.java b/discovery/src/test/java/com/orbekk/same/discovery/NetworkEntryTest.java new file mode 100644 index 0000000..dacaf9c --- /dev/null +++ b/discovery/src/test/java/com/orbekk/same/discovery/NetworkEntryTest.java @@ -0,0 +1,25 @@ +package com.orbekk.same.discovery; + +import static org.junit.Assert.*; + +import org.junit.Test; + +public class NetworkEntryTest { + @Test + public void testExpiry() { + NetworkEntry entry = new NetworkEntry("NetworkA", "UrlA"); + entry.register(100); + assertFalse(entry.hasExpired(50)); + assertTrue(entry.hasExpired(101)); + } + + @Test + public void testRegister() { + NetworkEntry entry = new NetworkEntry("NetworkB", "UrlB"); + long time = 1000000000000l; + entry.register(time); + assertTrue(entry.hasExpired(time+1)); + entry.register(time + 1000); + assertFalse(entry.hasExpired(time + 500)); + } +} -- cgit v1.2.3