Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Commit

Permalink
sc-client-db: add test for reverting finalized blocks (#14205)
Browse files Browse the repository at this point in the history
  • Loading branch information
andresilva authored May 24, 2023
1 parent e1345e7 commit bf92638
Showing 1 changed file with 32 additions and 0 deletions.
32 changes: 32 additions & 0 deletions client/db/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3913,6 +3913,38 @@ pub(crate) mod tests {
assert_eq!(1, backend.blockchain.leaves.read().highest_leaf().unwrap().0);
}

#[test]
fn revert_finalized_blocks() {
let pruning_modes = [BlocksPruning::Some(10), BlocksPruning::KeepAll];

// we will create a chain with 11 blocks, finalize block #8 and then
// attempt to revert 5 blocks.
for pruning_mode in pruning_modes {
let backend = Backend::<Block>::new_test_with_tx_storage(pruning_mode, 1);

let mut parent = Default::default();
for i in 0..=10 {
parent = insert_block(&backend, i, parent, None, Default::default(), vec![], None)
.unwrap();
}

assert_eq!(backend.blockchain().info().best_number, 10);

let block8 = backend.blockchain().hash(8).unwrap().unwrap();
backend.finalize_block(block8, None).unwrap();
backend.revert(5, true).unwrap();

match pruning_mode {
// we can only revert to blocks for which we have state, if pruning is enabled
// then the last state available will be that of the latest finalized block
BlocksPruning::Some(_) =>
assert_eq!(backend.blockchain().info().finalized_number, 8),
// otherwise if we're not doing state pruning we can revert past finalized blocks
_ => assert_eq!(backend.blockchain().info().finalized_number, 5),
}
}
}

#[test]
fn test_no_duplicated_leaves_allowed() {
let backend: Backend<Block> = Backend::new_test(10, 10);
Expand Down

0 comments on commit bf92638

Please sign in to comment.