Skip to content

Commit

Permalink
Merge pull request #2342 from subspace/pick-2313
Browse files Browse the repository at this point in the history
Gemini 3g backport: Skip processing the non-canonical consensus block for the operator
  • Loading branch information
NingLin-P authored Dec 18, 2023
2 parents 9bda3d7 + a5f8f67 commit f2143c4
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 17 deletions.
6 changes: 6 additions & 0 deletions domains/client/domain-operator/src/bundle_processor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,12 @@ where
) -> sp_blockchain::Result<()> {
let (consensus_block_hash, consensus_block_number, is_new_best) = consensus_block_info;

// Skip processing the blocks of the non-canonical chain, these blocks will be processed if
// the chain becomes canonical later
if !is_new_best {
return Ok(());
}

tracing::debug!(
"Processing consensus block #{consensus_block_number},{consensus_block_hash}"
);
Expand Down
46 changes: 29 additions & 17 deletions domains/client/domain-operator/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -131,24 +131,41 @@ async fn test_domain_chain_fork_choice() {
.await
.unwrap();

// Fork B produce a consenus block that contains bundles thus derive a domain block
let mut alice_import_notification_stream = alice.client.every_import_notification_stream();

// Fork B produce a consenus block that contains bundles
let (slot, bundle) = ferdie.produce_slot_and_wait_for_bundle_submission().await;
assert!(bundle.is_some());
ferdie
let fork_b_block_hash = ferdie
.produce_block_with_slot_at(slot, common_consensus_hash, None)
.await
.unwrap();

// Because the new domain block is in a stale fork thus we need to use `every_import_notification_stream`
let new_domain_block = alice_import_notification_stream.next().await.unwrap();
assert_eq!(*new_domain_block.header.number(), 4);
// Fork B is still in the non-canonical fork thus the consensus block and bundle
// won't be processed
assert!(alice_import_notification_stream.try_recv().is_err());

// The consensus fork A is still the best fork, because fork A don't derive any new
// domain block thus the best domain block is still #3
assert_eq!(ferdie.client.info().best_hash, fork_a_block_hash);
assert_eq!(alice.client.info().best_number, 3);
assert_eq!(alice.client.info().best_hash, domain_hash_3);

// Produce one more consensus block on fork B to make it the best fork
let (slot, bundle) = ferdie.produce_slot_and_wait_for_bundle_submission().await;
assert!(bundle.is_some());
let fork_b_block_hash = ferdie
.produce_block_with_slot_at(slot, fork_b_block_hash, Some(vec![]))
.await
.unwrap();
assert_eq!(ferdie.client.info().best_hash, fork_b_block_hash);

// It should also trigger the operator to processe consensus blocks at fork B
// thus produce more domain blocks
let domain_block_4 = alice_import_notification_stream.next().await.unwrap();
assert_eq!(*domain_block_4.header.number(), 4);
assert_eq!(alice.client.info().best_number, 4);
assert_eq!(alice.client.info().best_hash, domain_block_4.header.hash());
}

#[tokio::test(flavor = "multi_thread")]
Expand Down Expand Up @@ -2835,6 +2852,13 @@ async fn test_multiple_consensus_blocks_derive_similar_domain_block() {
)
.await
.unwrap();
// Produce one more consensus block to make fork B the best fork and trigger processing
// on fork B
let slot = ferdie.produce_slot();
ferdie
.produce_block_with_slot_at(slot, consensus_block_hash_fork_b, Some(vec![]))
.await
.unwrap();

assert_ne!(consensus_block_hash_fork_a, consensus_block_hash_fork_b);

Expand Down Expand Up @@ -2892,18 +2916,6 @@ async fn test_multiple_consensus_blocks_derive_similar_domain_block() {
domain_block_header_fork_b.state_root()
);

// Produce one more block at fork A to make it the canonical chain and the operator
// should submit the ER of fork A
let (slot, bundle) = ferdie.produce_slot_and_wait_for_bundle_submission().await;
ferdie
.produce_block_with_slot_at(slot, consensus_block_hash_fork_a, None)
.await
.unwrap();
assert_eq!(
bundle.unwrap().into_receipt().consensus_block_hash,
consensus_block_hash_fork_a
);

// Simply produce more block
produce_blocks!(ferdie, alice, 3).await.unwrap();
}
Expand Down

0 comments on commit f2143c4

Please sign in to comment.