test-utils: compare data against RPC (#115)

* cargo: add `pretty_assertions`

* test-utils: add tests to compare data against RPC data, and fix

* small fixes

* database: fix `cumulative_generated_coins` from test data

block had wrong data which offset all of the asserts
This commit is contained in:
hinto-janai 2024-04-25 14:58:45 -04:00 committed by GitHub
parent bf6c21c71e
commit 32a44a2503
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 96 additions and 18 deletions

2
Cargo.lock generated
View file

@ -650,6 +650,7 @@ dependencies = [
"borsh", "borsh",
"bytes", "bytes",
"bzip2", "bzip2",
"cuprate-helper",
"cuprate-types", "cuprate-types",
"futures", "futures",
"hex", "hex",
@ -657,6 +658,7 @@ dependencies = [
"monero-p2p", "monero-p2p",
"monero-serai", "monero-serai",
"monero-wire", "monero-wire",
"pretty_assertions",
"reqwest", "reqwest",
"serde", "serde",
"serde_json", "serde_json",

View file

@ -76,6 +76,7 @@ tracing = { version = "0.1.40", default-features = false }
## workspace.dev-dependencies ## workspace.dev-dependencies
tempfile = { version = "3" } tempfile = { version = "3" }
reqwest = { version = "0.11.24" } reqwest = { version = "0.11.24" }
pretty_assertions = { version = "1.4.0" }
proptest = { version = "1" } proptest = { version = "1" }
proptest-derive = { version = "0.4.0" } proptest-derive = { version = "0.4.0" }

View file

@ -53,6 +53,6 @@ cuprate-helper = { path = "../helper", features = ["thread"] }
cuprate-test-utils = { path = "../test-utils" } cuprate-test-utils = { path = "../test-utils" }
page_size = { version = "0.6.0" } page_size = { version = "0.6.0" }
tempfile = { version = "3.10.0" } tempfile = { version = "3.10.0" }
pretty_assertions = { version = "1.4.0" } pretty_assertions = { workspace = true }
hex = { workspace = true } hex = { workspace = true }
hex-literal = { workspace = true } hex-literal = { workspace = true }

View file

@ -156,15 +156,15 @@ mod test {
); );
assert_eq!( assert_eq!(
cumulative_generated_coins(&0, tables.block_infos()).unwrap(), cumulative_generated_coins(&0, tables.block_infos()).unwrap(),
13_138_270_467_918, 14_535_350_982_449,
); );
assert_eq!( assert_eq!(
cumulative_generated_coins(&1, tables.block_infos()).unwrap(), cumulative_generated_coins(&1, tables.block_infos()).unwrap(),
16_542_044_490_081, 17_939_125_004_612,
); );
assert_eq!( assert_eq!(
cumulative_generated_coins(&2, tables.block_infos()).unwrap(), cumulative_generated_coins(&2, tables.block_infos()).unwrap(),
17_142_044_490_081, 18_539_125_004_612,
); );
assert!(matches!( assert!(matches!(
cumulative_generated_coins(&3, tables.block_infos()), cumulative_generated_coins(&3, tables.block_infos()),

View file

@ -7,6 +7,7 @@ authors = ["Boog900", "hinto-janai"]
[dependencies] [dependencies]
cuprate-types = { path = "../types" } cuprate-types = { path = "../types" }
cuprate-helper = { path = "../helper", features = ["map"] }
monero-wire = { path = "../net/monero-wire" } monero-wire = { path = "../net/monero-wire" }
monero-p2p = { path = "../p2p/monero-p2p", features = ["borsh"] } monero-p2p = { path = "../p2p/monero-p2p", features = ["borsh"] }
@ -34,3 +35,4 @@ zip = "0.6"
[dev-dependencies] [dev-dependencies]
hex = { workspace = true } hex = { workspace = true }
pretty_assertions = { workspace = true }

View file

@ -11,6 +11,7 @@ use std::sync::{Arc, OnceLock};
use hex_literal::hex; use hex_literal::hex;
use monero_serai::{block::Block, transaction::Transaction}; use monero_serai::{block::Block, transaction::Transaction};
use cuprate_helper::map::combine_low_high_bits_to_u128;
use cuprate_types::{TransactionVerificationData, VerifiedBlockInformation}; use cuprate_types::{TransactionVerificationData, VerifiedBlockInformation};
use crate::data::constants::{ use crate::data::constants::{
@ -34,7 +35,8 @@ struct VerifiedBlockMap {
generated_coins: u64, generated_coins: u64,
weight: usize, weight: usize,
long_term_weight: usize, long_term_weight: usize,
cumulative_difficulty: u128, cumulative_difficulty_low: u64,
cumulative_difficulty_high: u64,
// Vec of `tx_blob`'s, i.e. the data in `/test-utils/src/data/tx/`. // Vec of `tx_blob`'s, i.e. the data in `/test-utils/src/data/tx/`.
// This should the actual `tx_blob`'s of the transactions within this block. // This should the actual `tx_blob`'s of the transactions within this block.
txs: &'static [&'static [u8]], txs: &'static [&'static [u8]],
@ -54,7 +56,8 @@ impl VerifiedBlockMap {
generated_coins, generated_coins,
weight, weight,
long_term_weight, long_term_weight,
cumulative_difficulty, cumulative_difficulty_low,
cumulative_difficulty_high,
txs, txs,
} = self; } = self;
@ -90,7 +93,10 @@ impl VerifiedBlockMap {
generated_coins, generated_coins,
weight, weight,
long_term_weight, long_term_weight,
cumulative_difficulty, cumulative_difficulty: combine_low_high_bits_to_u128(
cumulative_difficulty_low,
cumulative_difficulty_high,
),
} }
} }
} }
@ -131,7 +137,8 @@ macro_rules! verified_block_information_fn {
generated_coins: $generated_coins:literal, // Generated coins in block (minus fees) generated_coins: $generated_coins:literal, // Generated coins in block (minus fees)
weight: $weight:literal, // Block weight weight: $weight:literal, // Block weight
long_term_weight: $long_term_weight:literal, // Block long term weight long_term_weight: $long_term_weight:literal, // Block long term weight
cumulative_difficulty: $cumulative_difficulty:literal, // Block cumulative difficulty cumulative_difficulty_low: $cumulative_difficulty_low:literal, // Least significant 64-bits of block cumulative difficulty
cumulative_difficulty_high: $cumulative_difficulty_high:literal, // Most significant 64-bits of block cumulative difficulty
tx_len: $tx_len:literal, // Amount of transactions in this block tx_len: $tx_len:literal, // Amount of transactions in this block
) => { ) => {
#[doc = concat!( #[doc = concat!(
@ -148,6 +155,8 @@ macro_rules! verified_block_information_fn {
/// ```rust /// ```rust
#[doc = "# use cuprate_test_utils::data::*;"] #[doc = "# use cuprate_test_utils::data::*;"]
#[doc = "# use hex_literal::hex;"] #[doc = "# use hex_literal::hex;"]
#[doc = "use cuprate_helper::map::combine_low_high_bits_to_u128;"]
#[doc = ""]
#[doc = concat!("let block = ", stringify!($fn_name), "();")] #[doc = concat!("let block = ", stringify!($fn_name), "();")]
#[doc = concat!("assert_eq!(&block.block.serialize(), ", stringify!($block_blob), ");")] #[doc = concat!("assert_eq!(&block.block.serialize(), ", stringify!($block_blob), ");")]
#[doc = concat!("assert_eq!(block.pow_hash, hex!(\"", $pow_hash, "\"));")] #[doc = concat!("assert_eq!(block.pow_hash, hex!(\"", $pow_hash, "\"));")]
@ -155,8 +164,16 @@ macro_rules! verified_block_information_fn {
#[doc = concat!("assert_eq!(block.generated_coins, ", $generated_coins, ");")] #[doc = concat!("assert_eq!(block.generated_coins, ", $generated_coins, ");")]
#[doc = concat!("assert_eq!(block.weight, ", $weight, ");")] #[doc = concat!("assert_eq!(block.weight, ", $weight, ");")]
#[doc = concat!("assert_eq!(block.long_term_weight, ", $long_term_weight, ");")] #[doc = concat!("assert_eq!(block.long_term_weight, ", $long_term_weight, ");")]
#[doc = concat!("assert_eq!(block.cumulative_difficulty, ", $cumulative_difficulty, ");")]
#[doc = concat!("assert_eq!(block.txs.len(), ", $tx_len, ");")] #[doc = concat!("assert_eq!(block.txs.len(), ", $tx_len, ");")]
#[doc = ""]
#[doc = concat!(
"assert_eq!(block.cumulative_difficulty, ",
"combine_low_high_bits_to_u128(",
stringify!($cumulative_difficulty_low),
", ",
stringify!($cumulative_difficulty_high),
"));"
)]
/// ``` /// ```
pub fn $fn_name() -> &'static VerifiedBlockInformation { pub fn $fn_name() -> &'static VerifiedBlockInformation {
static BLOCK: OnceLock<VerifiedBlockInformation> = OnceLock::new(); static BLOCK: OnceLock<VerifiedBlockInformation> = OnceLock::new();
@ -168,7 +185,8 @@ macro_rules! verified_block_information_fn {
generated_coins: $generated_coins, generated_coins: $generated_coins,
weight: $weight, weight: $weight,
long_term_weight: $long_term_weight, long_term_weight: $long_term_weight,
cumulative_difficulty: $cumulative_difficulty, cumulative_difficulty_low: $cumulative_difficulty_low,
cumulative_difficulty_high: $cumulative_difficulty_high,
txs: &[$($tx_blob),*], txs: &[$($tx_blob),*],
} }
.into_verified() .into_verified()
@ -181,12 +199,13 @@ verified_block_information_fn! {
fn_name: block_v1_tx2, fn_name: block_v1_tx2,
block_blob: BLOCK_5ECB7E, block_blob: BLOCK_5ECB7E,
tx_blobs: [TX_2180A8, TX_D7FEBD], tx_blobs: [TX_2180A8, TX_D7FEBD],
pow_hash: "84f64766475d51837ac9efbef1926486e58563c95a19fef4aec3254f03000000", pow_hash: "c960d540000459480560b7816de968c7470083e5874e10040bdd4cc501000000",
height: 202_612, height: 202_609,
generated_coins: 13_138_270_467_918, generated_coins: 14_535_350_982_449,
weight: 55_503, weight: 21_905,
long_term_weight: 55_503, long_term_weight: 21_905,
cumulative_difficulty: 126_654_460_829_362, cumulative_difficulty_low: 126_650_740_038_710,
cumulative_difficulty_high: 0,
tx_len: 2, tx_len: 2,
} }
@ -199,7 +218,8 @@ verified_block_information_fn! {
generated_coins: 3_403_774_022_163, generated_coins: 3_403_774_022_163,
weight: 6_597, weight: 6_597,
long_term_weight: 6_597, long_term_weight: 6_597,
cumulative_difficulty: 23_558_910_234_058_343, cumulative_difficulty_low: 23_558_910_234_058_343,
cumulative_difficulty_high: 0,
tx_len: 3, tx_len: 3,
} }
@ -212,7 +232,8 @@ verified_block_information_fn! {
generated_coins: 600_000_000_000, generated_coins: 600_000_000_000,
weight: 106, weight: 106,
long_term_weight: 176_470, long_term_weight: 176_470,
cumulative_difficulty: 236_046_001_376_524_168, cumulative_difficulty_low: 236_046_001_376_524_168,
cumulative_difficulty_high: 0,
tx_len: 0, tx_len: 0,
} }
@ -267,3 +288,55 @@ transaction_verification_data_fn! {
weight: 2743, weight: 2743,
hash: "84d48dc11ec91950f8b70a85af9db91fe0c8abef71ef5db08304f7344b99ea66", hash: "84d48dc11ec91950f8b70a85af9db91fe0c8abef71ef5db08304f7344b99ea66",
} }
//---------------------------------------------------------------------------------------------------- TESTS
#[cfg(test)]
mod tests {
use super::*;
use pretty_assertions::assert_eq;
use crate::rpc::HttpRpcClient;
/// Assert the defined blocks are the same compared to ones received from a local RPC call.
#[ignore] // FIXME: doesn't work in CI, we need a real unrestricted node
#[tokio::test]
async fn block_same_as_rpc() {
let rpc = HttpRpcClient::new(None).await;
for block in [block_v1_tx2(), block_v9_tx3(), block_v16_tx0()] {
println!("block_height: {}", block.height);
let block_rpc = rpc.get_verified_block_information(block.height).await;
assert_eq!(block, &block_rpc);
}
}
/// Same as `block_same_as_rpc` but for transactions.
/// This also tests all the transactions within the defined blocks.
#[ignore] // FIXME: doesn't work in CI, we need a real unrestricted node
#[tokio::test]
async fn tx_same_as_rpc() {
let rpc = HttpRpcClient::new(None).await;
let mut txs = [block_v1_tx2(), block_v9_tx3(), block_v16_tx0()]
.into_iter()
.flat_map(|block| block.txs.iter().map(|arc| (**arc).clone()))
.collect::<Vec<TransactionVerificationData>>();
txs.extend([
tx_v1_sig0().clone(),
tx_v1_sig2().clone(),
tx_v2_rct3().clone(),
]);
for tx in txs {
println!("tx_hash: {:?}", tx.tx_hash);
let tx_rpc = rpc
.get_transaction_verification_data(&[tx.tx_hash])
.await
.collect::<Vec<TransactionVerificationData>>()
.pop()
.unwrap();
assert_eq!(tx, tx_rpc);
}
}
}