mirror of
https://github.com/hl-archive-node/nanoreth.git
synced 2025-12-06 10:59:55 +00:00
118 lines
4.2 KiB
Rust
118 lines
4.2 KiB
Rust
use futures::StreamExt;
|
|
use jsonrpsee::http_client::HttpClientBuilder;
|
|
use reth_rpc_api::EthApiClient;
|
|
use reth_rpc_api_testing_util::{debug::DebugApiExt, trace::TraceApiExt, utils::parse_env_url};
|
|
use reth_rpc_types::trace::{
|
|
filter::TraceFilter, parity::TraceType, tracerequest::TraceCallRequest,
|
|
};
|
|
use std::{collections::HashSet, time::Instant};
|
|
|
|
/// This is intended to be run locally against a running node.
|
|
///
|
|
/// This is a noop of env var `RETH_RPC_TEST_NODE_URL` is not set.
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn trace_many_blocks() {
|
|
let url = parse_env_url("RETH_RPC_TEST_NODE_URL");
|
|
if url.is_err() {
|
|
return
|
|
}
|
|
let url = url.unwrap();
|
|
|
|
let client = HttpClientBuilder::default().build(url).unwrap();
|
|
let mut stream = client.trace_block_buffered_unordered(15_000_000..=16_000_100, 20);
|
|
let now = Instant::now();
|
|
while let Some((err, block)) = stream.next_err().await {
|
|
eprintln!("Error tracing block {block:?}: {err}");
|
|
}
|
|
println!("Traced all blocks in {:?}", now.elapsed());
|
|
}
|
|
|
|
/// Tests the replaying of transactions on a local Ethereum node.
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
#[ignore]
|
|
async fn replay_transactions() {
|
|
let url = parse_env_url("RETH_RPC_TEST_NODE_URL").unwrap();
|
|
let client = HttpClientBuilder::default().build(url).unwrap();
|
|
|
|
let tx_hashes = vec![
|
|
"0x4e08fe36db723a338e852f89f613e606b0c9a17e649b18b01251f86236a2cef3".parse().unwrap(),
|
|
"0xea2817f1aeeb587b82f4ab87a6dbd3560fc35ed28de1be280cb40b2a24ab48bb".parse().unwrap(),
|
|
];
|
|
|
|
let trace_types = HashSet::from([TraceType::StateDiff, TraceType::VmTrace]);
|
|
|
|
let mut stream = client.replay_transactions(tx_hashes, trace_types);
|
|
let now = Instant::now();
|
|
while let Some(replay_txs) = stream.next().await {
|
|
println!("Transaction: {replay_txs:?}");
|
|
println!("Replayed transactions in {:?}", now.elapsed());
|
|
}
|
|
}
|
|
|
|
/// Tests the tracers filters on a local Ethereum node
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
#[ignore]
|
|
async fn trace_filters() {
|
|
// Parse the node URL from environment variable and create an HTTP client.
|
|
let url = parse_env_url("RETH_RPC_TEST_NODE_URL").unwrap();
|
|
let client = HttpClientBuilder::default().build(url).unwrap();
|
|
|
|
// Set up trace filters.
|
|
let filter = TraceFilter::default();
|
|
let filters = vec![filter];
|
|
|
|
// Initialize a stream for the trace filters.
|
|
let mut stream = client.trace_filter_stream(filters);
|
|
let start_time = Instant::now();
|
|
while let Some(trace) = stream.next().await {
|
|
println!("Transaction Trace: {trace:?}");
|
|
println!("Duration since test start: {:?}", start_time.elapsed());
|
|
}
|
|
}
|
|
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
#[ignore]
|
|
async fn trace_call() {
|
|
let url = parse_env_url("RETH_RPC_TEST_NODE_URL").unwrap();
|
|
let client = HttpClientBuilder::default().build(url).unwrap();
|
|
let trace_call_request = TraceCallRequest::default();
|
|
let mut stream = client.trace_call_stream(trace_call_request);
|
|
let start_time = Instant::now();
|
|
|
|
while let Some(result) = stream.next().await {
|
|
match result {
|
|
Ok(trace_result) => {
|
|
println!("Trace Result: {trace_result:?}");
|
|
}
|
|
Err((error, request)) => {
|
|
eprintln!("Error for request {request:?}: {error:?}");
|
|
}
|
|
}
|
|
}
|
|
|
|
println!("Completed in {:?}", start_time.elapsed());
|
|
}
|
|
|
|
/// This is intended to be run locally against a running node. This traces all blocks for a given
|
|
/// chain.
|
|
///
|
|
/// This is a noop of env var `RETH_RPC_TEST_NODE_URL` is not set.
|
|
#[tokio::test(flavor = "multi_thread")]
|
|
async fn debug_trace_block_entire_chain() {
|
|
let url = parse_env_url("RETH_RPC_TEST_NODE_URL");
|
|
if url.is_err() {
|
|
return
|
|
}
|
|
let url = url.unwrap();
|
|
|
|
let client = HttpClientBuilder::default().build(url).unwrap();
|
|
let current_block: u64 = client.block_number().await.unwrap().try_into().unwrap();
|
|
let range = 0..=current_block;
|
|
let mut stream = client.debug_trace_block_buffered_unordered(range, None, 20);
|
|
let now = Instant::now();
|
|
while let Some((err, block)) = stream.next_err().await {
|
|
eprintln!("Error tracing block {block:?}: {err}");
|
|
}
|
|
println!("Traced all blocks in {:?}", now.elapsed());
|
|
}
|