Move post-related database functionality into its own class.
[Sone.git] / src / test / java / net / pterodactylus / sone / database / memory / ConfigurationLoaderTest.java
index 47e26b7..41bc593 100644 (file)
@@ -3,11 +3,16 @@ package net.pterodactylus.sone.database.memory;
 import static java.util.Arrays.asList;
 import static org.hamcrest.MatcherAssert.assertThat;
 import static org.hamcrest.Matchers.containsInAnyOrder;
+import static org.hamcrest.Matchers.is;
 import static org.hamcrest.Matchers.nullValue;
+import static org.mockito.Matchers.anyString;
 import static org.mockito.Mockito.mock;
 import static org.mockito.Mockito.when;
 
+import java.util.HashMap;
 import java.util.HashSet;
+import java.util.LinkedHashSet;
+import java.util.Map;
 import java.util.Set;
 
 import net.pterodactylus.sone.TestValue;
@@ -16,6 +21,8 @@ import net.pterodactylus.util.config.ConfigurationException;
 import net.pterodactylus.util.config.Value;
 
 import org.junit.Test;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
 
 /**
  * Unit test for {@link ConfigurationLoader}.
@@ -41,6 +48,29 @@ public class ConfigurationLoaderTest {
        }
 
        @Test
+       public void loaderCanSaveKnownPosts() throws ConfigurationException {
+               Map<String, Value<String>> configurationValues = prepareConfigurationValues();
+               HashSet<String> originalPosts = new LinkedHashSet<String>(asList("Post1", "Post2"));
+               configurationLoader.saveKnownPosts(originalPosts);
+               assertThat(configurationValues.get("KnownPosts/0/ID").getValue(), is("Post1"));
+               assertThat(configurationValues.get("KnownPosts/1/ID").getValue(), is("Post2"));
+               assertThat(configurationValues.get("KnownPosts/2/ID").getValue(), nullValue());
+       }
+
+       private Map<String, Value<String>> prepareConfigurationValues() {
+               final Map<String, Value<String>> configurationValues = new HashMap<String, Value<String>>();
+               when(configuration.getStringValue(anyString())).thenAnswer(new Answer<Value<String>>() {
+                       @Override
+                       public Value<String> answer(InvocationOnMock invocation) throws Throwable {
+                               Value<String> stringValue = TestValue.from(null);
+                               configurationValues.put((String) invocation.getArguments()[0], stringValue);
+                               return stringValue;
+                       }
+               });
+               return configurationValues;
+       }
+
+       @Test
        public void loaderCanLoadKnownPostReplies() {
                when(configuration.getStringValue("KnownReplies/0/ID"))
                                .thenReturn(TestValue.from("PostReply2"));