Memorize all mocked Sones and implement getLocalSones().
[Sone.git] / src / test / java / net / pterodactylus / sone / data / Mocks.java
index 5181f04..00c1522 100644 (file)
@@ -20,12 +20,14 @@ package net.pterodactylus.sone.data;
 import static com.google.common.base.Optional.of;
 import static com.google.common.collect.ArrayListMultimap.create;
 import static com.google.common.collect.Ordering.from;
+import static com.google.common.collect.Sets.newHashSet;
 import static net.pterodactylus.sone.data.Post.TIME_COMPARATOR;
 import static org.mockito.Matchers.anyString;
 import static org.mockito.Matchers.eq;
 import static org.mockito.Mockito.mock;
 import static org.mockito.Mockito.when;
 
+import java.util.Collection;
 import java.util.List;
 
 import net.pterodactylus.sone.core.Core;
@@ -35,6 +37,7 @@ import net.pterodactylus.sone.database.Database;
 import net.pterodactylus.sone.database.PostReplyBuilder;
 
 import com.google.common.base.Optional;
+import com.google.common.collect.FluentIterable;
 import com.google.common.collect.Multimap;
 import org.mockito.Matchers;
 import org.mockito.invocation.InvocationOnMock;
@@ -47,16 +50,30 @@ import org.mockito.stubbing.Answer;
  */
 public class Mocks {
 
-       private static final Multimap<Sone, Post> sonePosts = create();
+       private final Multimap<Sone, Post> sonePosts = create();
+       private final Collection<Sone> sones = newHashSet();
+       public final Database database;
+       public final Core core;
 
-       public static Core mockCore(Database database) {
+       public Mocks() {
+               database = mockDatabase();
+               core = mockCore(database);
+               when(core.getLocalSones()).then(new Answer<Collection<Sone>>() {
+                       @Override
+                       public Collection<Sone> answer(InvocationOnMock invocation) throws Throwable {
+                               return FluentIterable.from(sones).filter(Sone.LOCAL_SONE_FILTER).toList();
+                       }
+               });
+       }
+
+       private static Core mockCore(Database database) {
                Core core = mock(Core.class);
                when(core.getDatabase()).thenReturn(database);
                when(core.getSone(anyString())).thenReturn(Optional.<Sone>absent());
                return core;
        }
 
-       public static Database mockDatabase() {
+       private static Database mockDatabase() {
                Database database = mock(Database.class);
                when(database.getSone(anyString())).thenReturn(Optional.<Sone>absent());
                when(database.getPost(anyString())).thenReturn(Optional.<Post>absent());
@@ -64,12 +81,10 @@ public class Mocks {
                return database;
        }
 
-       public static Sone mockLocalSone(Core core, final String id) {
+       public Sone mockLocalSone(final String id) {
                final Sone sone = mock(Sone.class);
-               when(sone.getId()).thenReturn(id);
                when(sone.isLocal()).thenReturn(true);
-               when(sone.getProfile()).thenReturn(new Profile(sone));
-               final Database database = core.getDatabase();
+               initializeSoneMock(id, sone);
                when(sone.newPostBuilder()).thenReturn(new DefaultPostBuilder(database, id));
                when(sone.newPostReplyBuilder(anyString())).then(new Answer<PostReplyBuilder>() {
                        @Override
@@ -77,25 +92,21 @@ public class Mocks {
                                return new DefaultPostReplyBuilder(database, id, (String) invocation.getArguments()[0]);
                        }
                });
-               when(core.getSone(eq(id))).thenReturn(of(sone));
-               when(database.getSone(eq(id))).thenReturn(of(sone));
-               when(sone.getPosts()).then(new Answer<List<Post>>() {
-                       @Override
-                       public List<Post> answer(InvocationOnMock invocationOnMock) throws Throwable {
-                               return from(TIME_COMPARATOR).sortedCopy(sonePosts.get(sone));
-                       }
-               });
                return sone;
        }
 
-       public static Sone mockRemoteSone(Core core, final String id) {
+       public Sone mockRemoteSone(final String id) {
                final Sone sone = mock(Sone.class);
-               when(sone.getId()).thenReturn(id);
                when(sone.isLocal()).thenReturn(false);
-               when(sone.getProfile()).thenReturn(new Profile(sone));
-               final Database database = core.getDatabase();
+               initializeSoneMock(id, sone);
                when(sone.newPostBuilder()).thenThrow(IllegalStateException.class);
                when(sone.newPostReplyBuilder(Matchers.<String>anyObject())).thenThrow(IllegalStateException.class);
+               return sone;
+       }
+
+       private void initializeSoneMock(String id, final Sone sone) {
+               when(sone.getId()).thenReturn(id);
+               when(sone.getProfile()).thenReturn(new Profile(sone));
                when(core.getSone(eq(id))).thenReturn(of(sone));
                when(database.getSone(eq(id))).thenReturn(of(sone));
                when(sone.getPosts()).then(new Answer<List<Post>>() {
@@ -104,24 +115,23 @@ public class Mocks {
                                return from(TIME_COMPARATOR).sortedCopy(sonePosts.get(sone));
                        }
                });
-               return sone;
+               when(sone.toString()).thenReturn(String.format("Sone[%s]", id));
+               sones.add(sone);
        }
 
-       public static Post mockPost(Core core, Sone sone, String postId) {
+       public Post mockPost(Sone sone, String postId) {
                Post post = mock(Post.class);
                when(post.getId()).thenReturn(postId);
                when(post.getSone()).thenReturn(sone);
-               Database database = core.getDatabase();
                when(database.getPost(eq(postId))).thenReturn(of(post));
                sonePosts.put(sone, post);
                return post;
        }
 
-       public static PostReply mockPostReply(Core core, Sone sone, String replyId) {
+       public PostReply mockPostReply(Sone sone, String replyId) {
                PostReply postReply = mock(PostReply.class);
                when(postReply.getId()).thenReturn(replyId);
                when(postReply.getSone()).thenReturn(sone);
-               Database database = core.getDatabase();
                when(database.getPostReply(eq(replyId))).thenReturn(of(postReply));
                return postReply;
        }