Add identity manager changes from the refactoring branch.
[Sone.git] / src / test / java / net / pterodactylus / sone / freenet / wot / IdentityManagerTest.java
diff --git a/src/test/java/net/pterodactylus/sone/freenet/wot/IdentityManagerTest.java b/src/test/java/net/pterodactylus/sone/freenet/wot/IdentityManagerTest.java
new file mode 100644 (file)
index 0000000..321f55c
--- /dev/null
@@ -0,0 +1,38 @@
+package net.pterodactylus.sone.freenet.wot;
+
+import static org.hamcrest.MatcherAssert.assertThat;
+import static org.hamcrest.Matchers.is;
+import static org.mockito.Mockito.doThrow;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.verify;
+
+import net.pterodactylus.sone.freenet.plugin.PluginException;
+
+import com.google.common.eventbus.EventBus;
+import org.junit.Test;
+
+/**
+ * Unit test for {@link IdentityManager}.
+ *
+ * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
+ */
+public class IdentityManagerTest {
+
+       private final EventBus eventBus = mock(EventBus.class);
+       private final WebOfTrustConnector webOfTrustConnector = mock(WebOfTrustConnector.class);
+       private final IdentityManager identityManager = new IdentityManager(eventBus, webOfTrustConnector, "Test");
+
+       @Test
+       public void identityManagerPingsWotConnector() throws PluginException {
+               assertThat(identityManager.isConnected(), is(true));
+               verify(webOfTrustConnector).ping();
+       }
+
+       @Test
+       public void disconnectedWotConnectorIsRecognized() throws PluginException {
+               doThrow(PluginException.class).when(webOfTrustConnector).ping();
+               assertThat(identityManager.isConnected(), is(false));
+               verify(webOfTrustConnector).ping();
+       }
+
+}