Remove @author tags
[Sone.git] / src / test / java / net / pterodactylus / sone / core / SoneModificationDetectorTest.java
index 388319b..1fd52c8 100644 (file)
@@ -8,27 +8,26 @@ import static org.mockito.Mockito.when;
 
 import java.util.concurrent.atomic.AtomicInteger;
 
-import net.pterodactylus.sone.data.Sone;
+import net.pterodactylus.sone.core.SoneModificationDetector.LockableFingerprintProvider;
 
 import com.google.common.base.Ticker;
+import org.junit.Before;
 import org.junit.Test;
 
 /**
  * Unit test for {@link SoneModificationDetector}.
- *
- * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
  */
 public class SoneModificationDetectorTest {
 
        private final Ticker ticker = mock(Ticker.class);
-       private final Sone sone = mock(Sone.class);
-       private final Core core = mock(Core.class);
        private final AtomicInteger insertionDelay = new AtomicInteger(60);
        private final SoneModificationDetector soneModificationDetector;
+       private final LockableFingerprintProvider lockableFingerprintProvider = mock(LockableFingerprintProvider.class);
 
        public SoneModificationDetectorTest() {
-               when(sone.getFingerprint()).thenReturn("original");
-               soneModificationDetector = new SoneModificationDetector(ticker, core, sone, insertionDelay);
+               when(lockableFingerprintProvider.getFingerprint()).thenReturn("original");
+               when(lockableFingerprintProvider.isLocked()).thenReturn(false);
+               soneModificationDetector = new SoneModificationDetector(ticker, lockableFingerprintProvider, insertionDelay);
        }
 
        private void modifySone() {
@@ -36,7 +35,7 @@ public class SoneModificationDetectorTest {
        }
 
        private void modifySone(String uniqueValue) {
-               when(sone.getFingerprint()).thenReturn("modified" + uniqueValue);
+               when(lockableFingerprintProvider.getFingerprint()).thenReturn("modified" + uniqueValue);
        }
 
        private void passTime(int seconds) {
@@ -44,7 +43,21 @@ public class SoneModificationDetectorTest {
        }
 
        private void lockSone() {
-               when(core.isLocked(sone)).thenReturn(true);
+               when(lockableFingerprintProvider.isLocked()).thenReturn(true);
+       }
+
+       private void unlockSone() {
+               when(lockableFingerprintProvider.isLocked()).thenReturn(false);
+       }
+
+       @Before
+       public void setupOriginalFingerprint() {
+           soneModificationDetector.setFingerprint("original");
+       }
+
+       @Test
+       public void normalConstructorCanBeCalled() {
+               new SoneModificationDetector(lockableFingerprintProvider, insertionDelay);
        }
 
        @Test
@@ -54,6 +67,11 @@ public class SoneModificationDetectorTest {
        }
 
        @Test
+       public void originalFingerprintIsRetained() {
+               assertThat(soneModificationDetector.getLastInsertFingerprint(), is("original"));
+       }
+
+       @Test
        public void modifiedSoneIsEligibleAfter60Seconds() {
                modifySone();
                assertThat(soneModificationDetector.isModified(), is(true));
@@ -98,6 +116,20 @@ public class SoneModificationDetectorTest {
        }
 
        @Test
+       public void lockingAndUnlockingASoneRestartsTheWaitPeriod() {
+               modifySone();
+               lockSone();
+               passTime(30);
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+               unlockSone();
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+               passTime(60);
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+               passTime(90);
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(true));
+       }
+
+       @Test
        public void settingFingerprintWillResetTheEligibility() {
                modifySone();
                assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
@@ -117,4 +149,34 @@ public class SoneModificationDetectorTest {
                assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
        }
 
+       @Test
+       public void soneWithoutOriginalFingerprintIsNotEligibleAfter59Seconds() {
+               SoneModificationDetector soneModificationDetector = createDetectorWithoutOriginalFingerprint();
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+               passTime(59);
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+       }
+
+       private SoneModificationDetector createDetectorWithoutOriginalFingerprint() {
+               return new SoneModificationDetector(ticker, new LockableFingerprintProvider() {
+                       @Override
+                       public boolean isLocked() {
+                               return false;
+                       }
+
+                       @Override
+                       public String getFingerprint() {
+                               return "changed";
+                       }
+               }, insertionDelay);
+       }
+
+       @Test
+       public void soneWithoutOriginalFingerprintIsEligibleAfter60Seconds() {
+               SoneModificationDetector soneModificationDetector = createDetectorWithoutOriginalFingerprint();
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(false));
+               passTime(60);
+               assertThat(soneModificationDetector.isEligibleForInsert(), is(true));
+       }
+
 }