Skip to content

Commit

Permalink
update test_has_next_ents_and_next_ents
Browse files Browse the repository at this point in the history
Signed-off-by: gengliqi <[email protected]>
  • Loading branch information
gengliqi committed Nov 23, 2020
1 parent c17288d commit fee8bb6
Show file tree
Hide file tree
Showing 3 changed files with 51 additions and 38 deletions.
4 changes: 2 additions & 2 deletions harness/tests/integration_cases/test_raft.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2702,8 +2702,8 @@ fn test_bcast_beat() {
let last_index = sm.raft_log.last_index();
mut_pr(&mut sm, 3, last_index, last_index + 1);

// Use Raft::step explicitly to bypass persist_entries inside which forwards commit index and sends append msg
Raft::step(&mut sm, new_message(0, 0, MessageType::MsgBeat, 0)).expect("");
sm.step(new_message(0, 0, MessageType::MsgBeat, 0))
.expect("");
let mut msgs = sm.read_messages();
assert_eq!(msgs.len(), 2);

Expand Down
83 changes: 48 additions & 35 deletions src/raft_log.rs
Original file line number Diff line number Diff line change
Expand Up @@ -958,28 +958,67 @@ mod test {
}

#[test]
fn test_next_ents() {
fn test_has_next_ents_and_next_ents() {
let l = default_logger();
let ents = [new_entry(4, 1), new_entry(5, 1), new_entry(6, 1)];
let ents = [
new_entry(4, 1),
new_entry(5, 1),
new_entry(6, 1),
new_entry(7, 1),
];
// applied, persisted, committed, expect_entries
let tests = vec![
(0, Some(&ents[..2])),
(3, Some(&ents[..2])),
(4, Some(&ents[1..2])),
(5, None),
(0, 3, 3, None),
(0, 3, 4, None),
(0, 4, 6, Some(&ents[..1])),
(0, 6, 4, Some(&ents[..1])),
(0, 5, 5, Some(&ents[..2])),
(0, 5, 7, Some(&ents[..2])),
(0, 7, 5, Some(&ents[..2])),
(3, 4, 3, None),
(3, 5, 5, Some(&ents[..2])),
(3, 6, 7, Some(&ents[..3])),
(3, 7, 6, Some(&ents[..3])),
(4, 5, 5, Some(&ents[1..2])),
(4, 5, 7, Some(&ents[1..2])),
(4, 7, 5, Some(&ents[1..2])),
(4, 7, 7, Some(&ents[1..4])),
(5, 5, 5, None),
(5, 7, 7, Some(&ents[2..4])),
(7, 7, 7, None),
];
for (i, &(applied, ref expect_entries)) in tests.iter().enumerate() {
for (i, &(applied, persisted, committed, ref expect_entries)) in tests.iter().enumerate() {
let store = MemStorage::new();
store.wl().apply_snapshot(new_snapshot(3, 1)).expect("");
let mut raft_log = RaftLog::new(store, l.clone());
raft_log.append(&ents);
let unstable = raft_log.unstable_entries().to_vec();
raft_log.stable_entries();
raft_log.mut_store().wl().append(&unstable).expect("");
raft_log.maybe_persist(5, 1);
raft_log.maybe_commit(5, 1);
raft_log.maybe_persist(persisted, 1);
assert_eq!(
persisted, raft_log.persisted,
"#{}: persisted = {}, want {}",
i, raft_log.persisted, persisted
);
raft_log.maybe_commit(committed, 1);
assert_eq!(
committed, raft_log.committed,
"#{}: committed = {}, want {}",
i, raft_log.committed, committed
);
#[allow(deprecated)]
raft_log.applied_to(applied);

let expect_has_next = expect_entries.is_some();
let actual_has_next = raft_log.has_next_entries();
if actual_has_next != expect_has_next {
panic!(
"#{}: hasNext = {}, want {}",
i, actual_has_next, expect_has_next
);
}

let next_entries = raft_log.next_entries();
if next_entries != expect_entries.map(|n| n.to_vec()) {
panic!(
Expand All @@ -990,32 +1029,6 @@ mod test {
}
}

#[test]
fn test_has_next_ents() {
let l = default_logger();
let ents = [new_entry(4, 1), new_entry(5, 1), new_entry(6, 1)];
let tests = vec![(0, true), (3, true), (4, true), (5, false)];

for (i, &(applied, has_next)) in tests.iter().enumerate() {
let store = MemStorage::new();
store.wl().apply_snapshot(new_snapshot(3, 1)).expect("");
let mut raft_log = RaftLog::new(store, l.clone());
raft_log.append(&ents);
let unstable = raft_log.unstable_entries().to_vec();
raft_log.stable_entries();
raft_log.mut_store().wl().append(&unstable).expect("");
raft_log.maybe_persist(5, 1);
raft_log.maybe_commit(5, 1);
#[allow(deprecated)]
raft_log.applied_to(applied);

let actual_has_next = raft_log.has_next_entries();
if actual_has_next != has_next {
panic!("#{}: hasNext = {}, want {}", i, actual_has_next, has_next);
}
}
}

#[test]
fn test_slice() {
let (offset, num) = (100u64, 100u64);
Expand Down
2 changes: 1 addition & 1 deletion src/raw_node.rs
Original file line number Diff line number Diff line change
Expand Up @@ -455,7 +455,7 @@ impl<T: Storage> RawNode<T> {

if let Some(snapshot) = &raft.raft_log.unstable_snapshot() {
rd.snapshot = snapshot.clone();
assert!(self.commit_since_index < rd.snapshot.get_metadata().index);
assert!(self.commit_since_index <= rd.snapshot.get_metadata().index);
self.commit_since_index = rd.snapshot.get_metadata().index;
// If there is a snapshot, the latter entries can not be persisted
// so there is no committed entries.
Expand Down

0 comments on commit fee8bb6

Please sign in to comment.