From ce6807546c8c6876f2e8685f4ebe9dd0379660bc Mon Sep 17 00:00:00 2001 From: "hinto.janai" Date: Tue, 17 Dec 2024 17:45:53 -0500 Subject: [PATCH] fixes --- tests/compat/src/verify.rs | 160 ++++++++++++++++--------------------- 1 file changed, 67 insertions(+), 93 deletions(-) diff --git a/tests/compat/src/verify.rs b/tests/compat/src/verify.rs index 8f1bb37f..6c8a21de 100644 --- a/tests/compat/src/verify.rs +++ b/tests/compat/src/verify.rs @@ -17,7 +17,7 @@ use crate::{ struct Verifier { id: usize, - now: Instant, + start_of_new_pow: Instant, thread_count: NonZeroUsize, update: NonZeroU64, top_height: u64, @@ -33,14 +33,12 @@ pub fn spawn_verify_pool( top_height: u64, rx: Receiver, ) { - let now = Instant::now(); - - for id in 0..thread_count.get() { + for id in 1..=thread_count.get() { let rx = rx.clone(); std::thread::spawn(move || { Verifier { id, - now, + start_of_new_pow: Instant::now(), thread_count, update, top_height, @@ -80,39 +78,14 @@ impl Verifier { } = data; let GetBlockResponse { blob, block_header } = get_block_response; - //----------------------------------------------- Calculate some data. - let calculated_block_reward = block - .miner_transaction - .prefix() - .outputs - .iter() - .map(|o| o.amount.unwrap()) - .sum::(); - let calculated_block_weight = txs - .iter() - .map(|RpcTxData { tx, .. }| tx.weight()) - .sum::(); - let calculated_pow_data = block.serialize_pow_hash(); - let miner_tx_weight = block.miner_transaction.weight(); - //----------------------------------------------- Verify. - Self::verify_block_properties(&blob, &block, calculated_block_reward, &p); - Self::verify_all_transactions_are_unique(&txs, &p); - Self::verify_transaction_properties(txs, &p); - - Self::verify_block_fields( - calculated_block_weight, - calculated_block_reward, - &block, - &p, - block_header, - ); - + Self::verify_blocks(&blob, &block, &txs, &p, block_header); + Self::verify_transactions(txs, &p); let algo = self.verify_pow( block_header.height, seed_hash, block_header.pow_hash, - &calculated_pow_data, + &block.serialize_pow_hash(), &p, ); @@ -120,65 +93,16 @@ impl Verifier { self.print_progress( algo, seed_height, - miner_tx_weight, + block.miner_transaction.weight(), blocks_per_sec, block_header, ); } - fn verify_block_properties( + fn verify_blocks( block_blob: &[u8], block: &Block, - calculated_block_reward: u64, - p: &str, - ) { - // Test block properties. - assert_eq!(block_blob, block.serialize(), "{p}"); - - assert!( - !block.miner_transaction.prefix().outputs.is_empty(), - "miner_tx has no outputs\n{p}" - ); - - assert_ne!(calculated_block_reward, 0, "block reward is 0\n{p}"); - } - - #[expect(clippy::significant_drop_tightening)] - fn verify_all_transactions_are_unique(txs: &[RpcTxData], p: &str) { - static TX_SET: LazyLock>> = - LazyLock::new(|| Mutex::new(HashSet::new())); - - let mut tx_set = TX_SET.lock().unwrap(); - - for tx_hash in txs.iter().map(|RpcTxData { tx_hash, .. }| tx_hash) { - assert!( - tx_set.insert(*tx_hash), - "duplicated tx_hash: {}, {p}", - hex::encode(tx_hash), - ); - } - } - - fn verify_transaction_properties(txs: Vec, p: &str) { - // Test transaction properties. - for RpcTxData { - tx, - tx_blob, - tx_hash, - } in txs - { - assert_eq!(tx_hash, tx.hash(), "{p}, tx: {tx:#?}"); - assert_ne!(tx.weight(), 0, "{p}, tx: {tx:#?}"); - assert!(!tx.prefix().inputs.is_empty(), "{p}, tx: {tx:#?}"); - assert_eq!(tx_blob, tx.serialize(), "{p}, tx: {tx:#?}"); - assert!(matches!(tx.version(), 1 | 2), "{p}, tx: {tx:#?}"); - } - } - - fn verify_block_fields( - calculated_block_weight: usize, - calculated_block_reward: u64, - block: &Block, + txs: &[RpcTxData], p: &str, BlockHeader { block_weight, @@ -195,15 +119,28 @@ impl Verifier { timestamp, }: BlockHeader, ) { - // Test block fields are correct. - assert_eq!(block_weight, calculated_block_weight, "{p}"); + let calculated_block_reward = block + .miner_transaction + .prefix() + .outputs + .iter() + .map(|o| o.amount.unwrap()) + .sum::(); + + let calculated_block_weight = txs + .iter() + .map(|RpcTxData { tx, .. }| tx.weight()) + .sum::(); + + let block_number = u64::try_from(block.number().unwrap()).unwrap(); + + assert!(!block.miner_transaction.prefix().outputs.is_empty(), "{p}"); + assert_ne!(calculated_block_reward, 0, "{p}"); assert_ne!(block.miner_transaction.weight(), 0, "{p}"); + assert_eq!(block_blob, block.serialize(), "{p}"); + assert_eq!(block_weight, calculated_block_weight, "{p}"); assert_eq!(hash, block.hash(), "{p}"); - assert_eq!( - height, - u64::try_from(block.number().unwrap()).unwrap(), - "{p}" - ); + assert_eq!(height, block_number, "{p}"); assert_eq!(major_version, block.header.hardfork_version, "{p}"); assert_eq!(minor_version, block.header.hardfork_signal, "{p}"); assert_eq!(miner_tx_hash, block.miner_transaction.hash(), "{p}"); @@ -214,6 +151,39 @@ impl Verifier { assert_eq!(timestamp, block.header.timestamp, "{p}"); } + fn verify_transactions(txs: Vec, p: &str) { + Self::verify_all_transactions_are_unique(&txs, p); + + for RpcTxData { + tx, + tx_blob, + tx_hash, + } in txs + { + assert_eq!(tx_hash, tx.hash(), "{p}, tx: {tx:#?}"); + assert_ne!(tx.weight(), 0, "{p}, tx: {tx:#?}"); + assert!(!tx.prefix().inputs.is_empty(), "{p}, tx: {tx:#?}"); + assert_eq!(tx_blob, tx.serialize(), "{p}, tx: {tx:#?}"); + assert!(matches!(tx.version(), 1 | 2), "{p}, tx: {tx:#?}"); + } + } + + #[expect(clippy::significant_drop_tightening)] + fn verify_all_transactions_are_unique(txs: &[RpcTxData], p: &str) { + static TX_SET: LazyLock>> = + LazyLock::new(|| Mutex::new(HashSet::new())); + + let mut tx_set = TX_SET.lock().unwrap(); + + for tx_hash in txs.iter().map(|RpcTxData { tx_hash, .. }| tx_hash) { + assert!( + tx_set.insert(*tx_hash), + "duplicated tx_hash: {}, {p}", + hex::encode(tx_hash), + ); + } + } + fn verify_pow( &mut self, height: u64, @@ -222,6 +192,10 @@ impl Verifier { calculated_pow_data: &[u8], p: &str, ) -> &'static str { + if matches!(height, 1546000 | 1685555 | 1788000 | 1978433) { + self.start_of_new_pow = Instant::now(); + } + let (algo, calculated_pow_hash) = if height < RANDOMX_START_HEIGHT { CryptoNightHash::hash(calculated_pow_data, height) } else { @@ -301,7 +275,7 @@ impl Verifier { let relative_count = find_count_relative_to_pow_activation(height); let block_buffer = self.rx.len(); - let elapsed = self.now.elapsed().as_secs_f64(); + let elapsed = self.start_of_new_pow.elapsed().as_secs_f64(); let secs_per_hash = elapsed / relative_count as f64; let verify_bps = relative_count as f64 / elapsed; let remaining_secs = (top_height as f64 - relative_count as f64) * secs_per_hash;