import static org.mockito.Mockito.reset;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.verifyNoMoreInteractions;
+
import akka.japi.Procedure;
-import com.google.common.base.Supplier;
import java.util.Collections;
import org.hamcrest.BaseMatcher;
import org.hamcrest.Description;
import org.opendaylight.controller.cluster.DataPersistenceProvider;
import org.opendaylight.controller.cluster.raft.MockRaftActorContext.MockPayload;
import org.opendaylight.controller.cluster.raft.MockRaftActorContext.MockReplicatedLogEntry;
-import org.opendaylight.controller.cluster.raft.base.messages.DeleteEntries;
import org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior;
+import org.opendaylight.controller.cluster.raft.persisted.DeleteEntries;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public void testAppendAndPersistExpectingNoCapture() throws Exception {
ReplicatedLog log = ReplicatedLogImpl.newInstance(context);
- MockReplicatedLogEntry logEntry = new MockReplicatedLogEntry(1, 1, new MockPayload("1"));
+ MockReplicatedLogEntry logEntry1 = new MockReplicatedLogEntry(1, 1, new MockPayload("1"));
- log.appendAndPersist(logEntry);
+ log.appendAndPersist(logEntry1);
- verifyPersist(logEntry);
+ verifyPersist(logEntry1);
assertEquals("size", 1, log.size());
reset(mockPersistence);
+ MockReplicatedLogEntry logEntry2 = new MockReplicatedLogEntry(1, 2, new MockPayload("2"));
Procedure<ReplicatedLogEntry> mockCallback = Mockito.mock(Procedure.class);
+ log.appendAndPersist(logEntry2, mockCallback);
+
+ verifyPersist(logEntry2);
+
+ verify(mockCallback).apply(same(logEntry2));
+
+ assertEquals("size", 2, log.size());
+ }
+
+ @SuppressWarnings("unchecked")
+ @Test
+ public void testAppendAndPersisWithDuplicateEntry() throws Exception {
+ ReplicatedLog log = ReplicatedLogImpl.newInstance(context);
+
+ Procedure<ReplicatedLogEntry> mockCallback = Mockito.mock(Procedure.class);
+ MockReplicatedLogEntry logEntry = new MockReplicatedLogEntry(1, 1, new MockPayload("1"));
+
log.appendAndPersist(logEntry, mockCallback);
verifyPersist(logEntry);
- verify(mockCallback).apply(same(logEntry));
+ assertEquals("size", 1, log.size());
- assertEquals("size", 2, log.size());
+ reset(mockPersistence, mockCallback);
+
+ log.appendAndPersist(logEntry, mockCallback);
+
+ verifyNoMoreInteractions(mockPersistence, mockCallback);
+
+ assertEquals("size", 1, log.size());
}
@Test
ReplicatedLog log = ReplicatedLogImpl.newInstance(context);
- MockReplicatedLogEntry logEntry1 = new MockReplicatedLogEntry(1, 2, new MockPayload("2"));
- MockReplicatedLogEntry logEntry2 = new MockReplicatedLogEntry(1, 3, new MockPayload("3"));
+ final MockReplicatedLogEntry logEntry1 = new MockReplicatedLogEntry(1, 2, new MockPayload("2"));
+ final MockReplicatedLogEntry logEntry2 = new MockReplicatedLogEntry(1, 3, new MockPayload("3"));
log.appendAndPersist(logEntry1);
verifyPersist(logEntry1);
public void testAppendAndPersistExpectingCaptureDueToDataSize() throws Exception {
doReturn(1L).when(mockBehavior).getReplicatedToAllIndex();
- context.setTotalMemoryRetriever(new Supplier<Long>() {
- @Override
- public Long get() {
- return 100L;
- }
- });
+ context.setTotalMemoryRetriever(() -> 100);
ReplicatedLog log = ReplicatedLogImpl.newInstance(context);
verifyNoMoreInteractions(mockPersistence);
}
- public Matcher<DeleteEntries> match(final DeleteEntries actual){
+ public Matcher<DeleteEntries> match(final DeleteEntries actual) {
return new BaseMatcher<DeleteEntries>() {
@Override
- public boolean matches(Object o) {
- DeleteEntries other = (DeleteEntries) o;
+ public boolean matches(Object obj) {
+ DeleteEntries other = (DeleteEntries) obj;
return actual.getFromIndex() == other.getFromIndex();
}