mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-08 20:09:41 +00:00
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:
parent
bf6c21c71e
commit
32a44a2503
6 changed files with 96 additions and 18 deletions
2
Cargo.lock
generated
2
Cargo.lock
generated
|
@ -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",
|
||||||
|
|
|
@ -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" }
|
||||||
|
|
||||||
|
|
|
@ -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 }
|
|
@ -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()),
|
||||||
|
|
|
@ -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 }
|
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue