From 9cb3dbba9b21af042342a728205afc95238ff934 Mon Sep 17 00:00:00 2001 From: teor Date: Sat, 29 Oct 2022 04:34:52 +1000 Subject: [PATCH] 1. change(rpc): Add a mempool field to GetBlockTemplateRpcImpl, and cleanup tests (#5493) * Add a mempool to GetBlockTemplateRpcImpl, and cleanup tests * Update snapshot file locations * Update snapshot instructions --- zebra-rpc/src/methods.rs | 21 +++-- .../src/methods/get_block_template_rpcs.rs | 62 ++++++++++---- zebra-rpc/src/methods/tests/snapshot.rs | 80 +++++------------- .../tests/snapshot/get_block_template_rpcs.rs | 84 +++++++++++++++++++ .../snapshots/get_block_count@mainnet_10.snap | 5 ++ .../snapshots/get_block_count@testnet_10.snap | 5 ++ .../snapshots/get_block_hash@mainnet_10.snap | 3 +- .../snapshots/get_block_hash@testnet_10.snap | 3 +- .../get_block_template@mainnet_10.snap | 3 +- .../get_block_template@testnet_10.snap | 3 +- .../snapshots/get_block_count@mainnet_10.snap | 6 -- .../snapshots/get_block_count@testnet_10.snap | 6 -- zebra-rpc/src/methods/tests/vectors.rs | 51 +++-------- zebra-rpc/src/server.rs | 9 +- .../disk_format/tests/snapshot.rs | 2 +- .../zebra_db/block/tests/snapshot.rs | 2 +- 16 files changed, 202 insertions(+), 143 deletions(-) create mode 100644 zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs create mode 100644 zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@mainnet_10.snap create mode 100644 zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@testnet_10.snap rename zebra-rpc/src/methods/tests/{ => snapshot}/snapshots/get_block_hash@mainnet_10.snap (57%) rename zebra-rpc/src/methods/tests/{ => snapshot}/snapshots/get_block_hash@testnet_10.snap (57%) rename zebra-rpc/src/methods/tests/{ => snapshot}/snapshots/get_block_template@mainnet_10.snap (87%) rename zebra-rpc/src/methods/tests/{ => snapshot}/snapshots/get_block_template@testnet_10.snap (87%) delete mode 100644 zebra-rpc/src/methods/tests/snapshots/get_block_count@mainnet_10.snap delete mode 100644 zebra-rpc/src/methods/tests/snapshots/get_block_count@testnet_10.snap diff --git a/zebra-rpc/src/methods.rs b/zebra-rpc/src/methods.rs index 7c55c207df3..ddcab2db9a5 100644 --- a/zebra-rpc/src/methods.rs +++ b/zebra-rpc/src/methods.rs @@ -29,7 +29,7 @@ use zebra_chain::{ transparent::{self, Address}, }; use zebra_network::constants::USER_AGENT; -use zebra_node_services::{mempool, BoxError}; +use zebra_node_services::mempool; use zebra_state::{OutputIndex, OutputLocation, TransactionLocation}; use crate::queue::Queue; @@ -241,7 +241,11 @@ pub trait Rpc { /// RPC method implementations. pub struct RpcImpl where - Mempool: Service, + Mempool: Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + >, State: Service< zebra_state::ReadRequest, Response = zebra_state::ReadResponse, @@ -280,7 +284,11 @@ where impl RpcImpl where - Mempool: Service + 'static, + Mempool: Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + > + 'static, State: Service< zebra_state::ReadRequest, Response = zebra_state::ReadResponse, @@ -337,8 +345,11 @@ where impl Rpc for RpcImpl where - Mempool: - tower::Service + 'static, + Mempool: tower::Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + > + 'static, Mempool::Future: Send, State: Service< zebra_state::ReadRequest, diff --git a/zebra-rpc/src/methods/get_block_template_rpcs.rs b/zebra-rpc/src/methods/get_block_template_rpcs.rs index 8af354c12d1..05cf3f0955c 100644 --- a/zebra-rpc/src/methods/get_block_template_rpcs.rs +++ b/zebra-rpc/src/methods/get_block_template_rpcs.rs @@ -1,12 +1,12 @@ //! RPC methods related to mining only available with `getblocktemplate-rpcs` rust feature. -use zebra_chain::{block::Height, chain_tip::ChainTip}; use futures::{FutureExt, TryFutureExt}; use jsonrpc_core::{self, BoxFuture, Error, ErrorCode, Result}; use jsonrpc_derive::rpc; -use tower::{Service, ServiceExt}; +use tower::{buffer::Buffer, Service, ServiceExt}; -pub(crate) mod types; +use zebra_chain::{block::Height, chain_tip::ChainTip}; +use zebra_node_services::mempool; use crate::methods::{ get_block_template_rpcs::types::{ @@ -15,6 +15,8 @@ use crate::methods::{ GetBlockHash, MISSING_BLOCK_ERROR_CODE, }; +pub(crate) mod types; + /// getblocktemplate RPC method signatures. #[rpc(server)] pub trait GetBlockTemplateRpc { @@ -58,26 +60,46 @@ pub trait GetBlockTemplateRpc { } /// RPC method implementations. -pub struct GetBlockTemplateRpcImpl +pub struct GetBlockTemplateRpcImpl where - Tip: ChainTip, + Mempool: Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + >, State: Service< zebra_state::ReadRequest, Response = zebra_state::ReadResponse, Error = zebra_state::BoxError, >, + Tip: ChainTip, { // TODO: Add the other fields from the [`Rpc`] struct as-needed - /// Allows efficient access to the best tip of the blockchain. - latest_chain_tip: Tip, + + // Configuration + // + // TODO: add mining config for getblocktemplate RPC miner address + + // Services + // + /// A handle to the mempool service. + #[allow(dead_code)] + mempool: Buffer, /// A handle to the state service. state: State, + + /// Allows efficient access to the best tip of the blockchain. + latest_chain_tip: Tip, } -impl GetBlockTemplateRpcImpl +impl GetBlockTemplateRpcImpl where - Tip: ChainTip + Clone + Send + Sync + 'static, + Mempool: Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + > + 'static, State: Service< zebra_state::ReadRequest, Response = zebra_state::ReadResponse, @@ -86,19 +108,30 @@ where + Send + Sync + 'static, + Tip: ChainTip + Clone + Send + Sync + 'static, { - /// Create a new instance of the RPC handler. - pub fn new(latest_chain_tip: Tip, state: State) -> Self { + /// Create a new instance of the handler for getblocktemplate RPCs. + pub fn new( + mempool: Buffer, + state: State, + latest_chain_tip: Tip, + ) -> Self { Self { - latest_chain_tip, + mempool, state, + latest_chain_tip, } } } -impl GetBlockTemplateRpc for GetBlockTemplateRpcImpl +impl GetBlockTemplateRpc for GetBlockTemplateRpcImpl where - Tip: ChainTip + Send + Sync + 'static, + Mempool: Service< + mempool::Request, + Response = mempool::Response, + Error = zebra_node_services::BoxError, + > + 'static, + Mempool::Future: Send, State: Service< zebra_state::ReadRequest, Response = zebra_state::ReadResponse, @@ -108,6 +141,7 @@ where + Sync + 'static, >::Future: Send, + Tip: ChainTip + Send + Sync + 'static, { fn get_block_count(&self) -> Result { self.latest_chain_tip diff --git a/zebra-rpc/src/methods/tests/snapshot.rs b/zebra-rpc/src/methods/tests/snapshot.rs index 3211cd9274a..7990698cbda 100644 --- a/zebra-rpc/src/methods/tests/snapshot.rs +++ b/zebra-rpc/src/methods/tests/snapshot.rs @@ -1,4 +1,9 @@ //! Snapshot tests for Zebra JSON-RPC responses. +//! +//! To update these snapshots, run: +//! ```sh +//! cargo insta test --review +//! ``` use std::sync::Arc; @@ -10,11 +15,13 @@ use zebra_chain::{ serialization::ZcashDeserializeInto, }; use zebra_network::constants::USER_AGENT; -use zebra_node_services::BoxError; use zebra_test::mock_service::MockService; use super::super::*; +#[cfg(feature = "getblocktemplate-rpcs")] +mod get_block_template_rpcs; + /// Snapshot test for RPC methods responses. #[tokio::test(flavor = "multi_thread")] async fn test_rpc_response_data() { @@ -36,15 +43,25 @@ async fn test_rpc_response_data_for_network(network: Network) { .map(|(_height, block_bytes)| block_bytes.zcash_deserialize_into().unwrap()) .collect(); - let mut mempool: MockService<_, _, _, BoxError> = MockService::build().for_unit_tests(); + let mut mempool: MockService<_, _, _, zebra_node_services::BoxError> = + MockService::build().for_unit_tests(); // Create a populated state service let (_state, read_state, latest_chain_tip, _chain_tip_change) = zebra_state::populated_state(blocks.clone(), network).await; + // Start snapshots of RPC responses. + let mut settings = insta::Settings::clone_current(); + settings.set_snapshot_suffix(format!("{}_{}", network_string(network), blocks.len() - 1)); + + // Test getblocktemplate-rpcs snapshots #[cfg(feature = "getblocktemplate-rpcs")] - let latest_chain_tip_gbt_clone = latest_chain_tip.clone(); - #[cfg(feature = "getblocktemplate-rpcs")] - let read_state_clone = read_state.clone(); + get_block_template_rpcs::test_responses( + mempool.clone(), + read_state.clone(), + latest_chain_tip.clone(), + settings.clone(), + ) + .await; // Init RPC let (rpc, _rpc_tx_queue_task_handle) = RpcImpl::new( @@ -56,10 +73,6 @@ async fn test_rpc_response_data_for_network(network: Network) { latest_chain_tip, ); - // Start snapshots of RPC responses. - let mut settings = insta::Settings::clone_current(); - settings.set_snapshot_suffix(format!("{}_{}", network_string(network), blocks.len() - 1)); - // `getinfo` let get_info = rpc.get_info().expect("We should have a GetInfo struct"); snapshot_rpc_getinfo(get_info, &settings); @@ -171,34 +184,6 @@ async fn test_rpc_response_data_for_network(network: Network) { .await .expect("We should have a vector of strings"); snapshot_rpc_getaddressutxos(get_address_utxos, &settings); - - #[cfg(feature = "getblocktemplate-rpcs")] - { - let get_block_template_rpc = - GetBlockTemplateRpcImpl::new(latest_chain_tip_gbt_clone, read_state_clone); - - // `getblockcount` - let get_block_count = get_block_template_rpc - .get_block_count() - .expect("We should have a number"); - snapshot_rpc_getblockcount(get_block_count, &settings); - - // `getblockhash` - const BLOCK_HEIGHT10: i32 = 10; - let get_block_hash = get_block_template_rpc - .get_block_hash(BLOCK_HEIGHT10) - .await - .expect("We should have a GetBlockHash struct"); - - snapshot_rpc_getblockhash(get_block_hash, &settings); - - // `getblocktemplate` - let get_block_template = get_block_template_rpc - .get_block_template() - .await - .expect("We should have a GetBlockTemplate struct"); - snapshot_rpc_getblocktemplate(get_block_template, &settings); - } } /// Snapshot `getinfo` response, using `cargo insta` and JSON serialization. @@ -287,27 +272,6 @@ fn snapshot_rpc_getaddressutxos(utxos: Vec, settings: &insta::S settings.bind(|| insta::assert_json_snapshot!("get_address_utxos", utxos)); } -#[cfg(feature = "getblocktemplate-rpcs")] -/// Snapshot `getblockcount` response, using `cargo insta` and JSON serialization. -fn snapshot_rpc_getblockcount(block_count: u32, settings: &insta::Settings) { - settings.bind(|| insta::assert_json_snapshot!("get_block_count", block_count)); -} - -#[cfg(feature = "getblocktemplate-rpcs")] -/// Snapshot `getblockhash` response, using `cargo insta` and JSON serialization. -fn snapshot_rpc_getblockhash(block_hash: GetBlockHash, settings: &insta::Settings) { - settings.bind(|| insta::assert_json_snapshot!("get_block_hash", block_hash)); -} - -#[cfg(feature = "getblocktemplate-rpcs")] -/// Snapshot `getblocktemplate` response, using `cargo insta` and JSON serialization. -fn snapshot_rpc_getblocktemplate( - block_template: crate::methods::get_block_template_rpcs::types::get_block_template::GetBlockTemplate, - settings: &insta::Settings, -) { - settings.bind(|| insta::assert_json_snapshot!("get_block_template", block_template)); -} - /// Utility function to convert a `Network` to a lowercase string. fn network_string(network: Network) -> String { let mut net_suffix = network.to_string(); diff --git a/zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs b/zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs new file mode 100644 index 00000000000..b240c7c489e --- /dev/null +++ b/zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs @@ -0,0 +1,84 @@ +//! Snapshot tests for getblocktemplate RPCs. +//! +//! To update these snapshots, run: +//! ```sh +//! cargo insta test --review --features getblocktemplate-rpcs --delete-unreferenced-snapshots +//! ``` + +use insta::Settings; +use tower::{buffer::Buffer, Service}; + +use zebra_node_services::mempool; +use zebra_state::LatestChainTip; + +use zebra_test::mock_service::{MockService, PanicAssertion}; + +use crate::methods::{GetBlockHash, GetBlockTemplateRpc, GetBlockTemplateRpcImpl}; + +pub async fn test_responses( + mempool: MockService< + mempool::Request, + mempool::Response, + PanicAssertion, + zebra_node_services::BoxError, + >, + read_state: State, + latest_chain_tip: LatestChainTip, + settings: Settings, +) where + State: Service< + zebra_state::ReadRequest, + Response = zebra_state::ReadResponse, + Error = zebra_state::BoxError, + > + Clone + + Send + + Sync + + 'static, + >::Future: Send, +{ + let get_block_template_rpc = GetBlockTemplateRpcImpl::new( + Buffer::new(mempool.clone(), 1), + read_state, + latest_chain_tip, + ); + + // `getblockcount` + let get_block_count = get_block_template_rpc + .get_block_count() + .expect("We should have a number"); + snapshot_rpc_getblockcount(get_block_count, &settings); + + // `getblockhash` + const BLOCK_HEIGHT10: i32 = 10; + let get_block_hash = get_block_template_rpc + .get_block_hash(BLOCK_HEIGHT10) + .await + .expect("We should have a GetBlockHash struct"); + + snapshot_rpc_getblockhash(get_block_hash, &settings); + + // `getblocktemplate` + let get_block_template = get_block_template_rpc + .get_block_template() + .await + .expect("We should have a GetBlockTemplate struct"); + snapshot_rpc_getblocktemplate(get_block_template, &settings); +} + +/// Snapshot `getblockcount` response, using `cargo insta` and JSON serialization. +fn snapshot_rpc_getblockcount(block_count: u32, settings: &insta::Settings) { + settings.bind(|| insta::assert_json_snapshot!("get_block_count", block_count)); +} + +/// Snapshot `getblockhash` response, using `cargo insta` and JSON serialization. +fn snapshot_rpc_getblockhash(block_hash: GetBlockHash, settings: &insta::Settings) { + settings.bind(|| insta::assert_json_snapshot!("get_block_hash", block_hash)); +} + +/// Snapshot `getblocktemplate` response, using `cargo insta` and JSON serialization. +fn snapshot_rpc_getblocktemplate( + block_template: crate::methods::get_block_template_rpcs::types::get_block_template::GetBlockTemplate, + settings: &insta::Settings, +) { + settings.bind(|| insta::assert_json_snapshot!("get_block_template", block_template)); +} diff --git a/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@mainnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@mainnet_10.snap new file mode 100644 index 00000000000..685fdfb96e6 --- /dev/null +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@mainnet_10.snap @@ -0,0 +1,5 @@ +--- +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs +expression: block_count +--- +10 diff --git a/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@testnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@testnet_10.snap new file mode 100644 index 00000000000..685fdfb96e6 --- /dev/null +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_count@testnet_10.snap @@ -0,0 +1,5 @@ +--- +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs +expression: block_count +--- +10 diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_hash@mainnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@mainnet_10.snap similarity index 57% rename from zebra-rpc/src/methods/tests/snapshots/get_block_hash@mainnet_10.snap rename to zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@mainnet_10.snap index 74f56f79631..29179d3e2bb 100644 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_hash@mainnet_10.snap +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@mainnet_10.snap @@ -1,6 +1,5 @@ --- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 270 +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs expression: block_hash --- "00074c46a4aa8172df8ae2ad1848a2e084e1b6989b7d9e6132adc938bf835b36" diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_hash@testnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@testnet_10.snap similarity index 57% rename from zebra-rpc/src/methods/tests/snapshots/get_block_hash@testnet_10.snap rename to zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@testnet_10.snap index 3740afc4078..3f271a65367 100644 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_hash@testnet_10.snap +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_hash@testnet_10.snap @@ -1,6 +1,5 @@ --- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 270 +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs expression: block_hash --- "079f4c752729be63e6341ee9bce42fbbe37236aba22e3deb82405f3c2805c112" diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_template@mainnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@mainnet_10.snap similarity index 87% rename from zebra-rpc/src/methods/tests/snapshots/get_block_template@mainnet_10.snap rename to zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@mainnet_10.snap index e3a0491f471..5d65a33333a 100644 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_template@mainnet_10.snap +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@mainnet_10.snap @@ -1,6 +1,5 @@ --- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 308 +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs expression: block_template --- { diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_template@testnet_10.snap b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@testnet_10.snap similarity index 87% rename from zebra-rpc/src/methods/tests/snapshots/get_block_template@testnet_10.snap rename to zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@testnet_10.snap index e3a0491f471..5d65a33333a 100644 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_template@testnet_10.snap +++ b/zebra-rpc/src/methods/tests/snapshot/snapshots/get_block_template@testnet_10.snap @@ -1,6 +1,5 @@ --- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 308 +source: zebra-rpc/src/methods/tests/snapshot/get_block_template_rpcs.rs expression: block_template --- { diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_count@mainnet_10.snap b/zebra-rpc/src/methods/tests/snapshots/get_block_count@mainnet_10.snap deleted file mode 100644 index e4e1509f866..00000000000 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_count@mainnet_10.snap +++ /dev/null @@ -1,6 +0,0 @@ ---- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 273 -expression: block_count ---- -10 diff --git a/zebra-rpc/src/methods/tests/snapshots/get_block_count@testnet_10.snap b/zebra-rpc/src/methods/tests/snapshots/get_block_count@testnet_10.snap deleted file mode 100644 index e4e1509f866..00000000000 --- a/zebra-rpc/src/methods/tests/snapshots/get_block_count@testnet_10.snap +++ /dev/null @@ -1,6 +0,0 @@ ---- -source: zebra-rpc/src/methods/tests/snapshot.rs -assertion_line: 273 -expression: block_count ---- -10 diff --git a/zebra-rpc/src/methods/tests/vectors.rs b/zebra-rpc/src/methods/tests/vectors.rs index 07b89909fac..6d075711aac 100644 --- a/zebra-rpc/src/methods/tests/vectors.rs +++ b/zebra-rpc/src/methods/tests/vectors.rs @@ -636,19 +636,12 @@ async fn rpc_getblockcount() { zebra_state::populated_state(blocks.clone(), Mainnet).await; // Init RPC - let (_rpc, rpc_tx_queue_task_handle) = RpcImpl::new( - "RPC test", - Mainnet, - false, + let get_block_template_rpc = get_block_template_rpcs::GetBlockTemplateRpcImpl::new( Buffer::new(mempool.clone(), 1), - read_state.clone(), + read_state, latest_chain_tip.clone(), ); - // Init RPC - let get_block_template_rpc = - get_block_template_rpcs::GetBlockTemplateRpcImpl::new(latest_chain_tip.clone(), read_state); - // Get the tip height using RPC method `get_block_count` let get_block_count = get_block_template_rpc .get_block_count() @@ -658,10 +651,6 @@ async fn rpc_getblockcount() { assert_eq!(get_block_count, tip_block_height.0); mempool.expect_no_requests().await; - - // The queue task should continue without errors or panics - let rpc_tx_queue_task_result = rpc_tx_queue_task_handle.now_or_never(); - assert!(matches!(rpc_tx_queue_task_result, None)); } #[cfg(feature = "getblocktemplate-rpcs")] @@ -676,18 +665,12 @@ async fn rpc_getblockcount_empty_state() { zebra_state::init_test_services(Mainnet); // Init RPC - let (_rpc, rpc_tx_queue_task_handle) = RpcImpl::new( - "RPC test", - Mainnet, - false, + let get_block_template_rpc = get_block_template_rpcs::GetBlockTemplateRpcImpl::new( Buffer::new(mempool.clone(), 1), - read_state.clone(), + read_state, latest_chain_tip.clone(), ); - let get_block_template_rpc = - get_block_template_rpcs::GetBlockTemplateRpcImpl::new(latest_chain_tip.clone(), read_state); - // Get the tip height using RPC method `get_block_count let get_block_count = get_block_template_rpc.get_block_count(); @@ -698,10 +681,6 @@ async fn rpc_getblockcount_empty_state() { assert_eq!(get_block_count.err().unwrap().message, "No blocks in state"); mempool.expect_no_requests().await; - - // The queue task should continue without errors or panics - let rpc_tx_queue_task_result = rpc_tx_queue_task_handle.now_or_never(); - assert!(matches!(rpc_tx_queue_task_result, None)); } #[cfg(feature = "getblocktemplate-rpcs")] @@ -720,17 +699,12 @@ async fn rpc_getblockhash() { let (_state, read_state, latest_chain_tip, _chain_tip_change) = zebra_state::populated_state(blocks.clone(), Mainnet).await; - // Init RPCs - let _rpc = RpcImpl::new( - "RPC test", - Mainnet, - false, + // Init RPC + let get_block_template_rpc = get_block_template_rpcs::GetBlockTemplateRpcImpl::new( Buffer::new(mempool.clone(), 1), - Buffer::new(read_state.clone(), 1), + read_state, latest_chain_tip.clone(), ); - let get_block_template_rpc = - get_block_template_rpcs::GetBlockTemplateRpcImpl::new(latest_chain_tip, read_state); // Query the hashes using positive indexes for (i, block) in blocks.iter().enumerate() { @@ -774,17 +748,12 @@ async fn rpc_getblocktemplate() { let (_state, read_state, latest_chain_tip, _chain_tip_change) = zebra_state::populated_state(blocks.clone(), Mainnet).await; - // Init RPCs - let _rpc = RpcImpl::new( - "RPC test", - Mainnet, - false, + // Init RPC + let get_block_template_rpc = get_block_template_rpcs::GetBlockTemplateRpcImpl::new( Buffer::new(mempool.clone(), 1), - Buffer::new(read_state.clone(), 1), + read_state, latest_chain_tip.clone(), ); - let get_block_template_rpc = - get_block_template_rpcs::GetBlockTemplateRpcImpl::new(latest_chain_tip, read_state); let get_block_template = get_block_template_rpc .get_block_template() diff --git a/zebra-rpc/src/server.rs b/zebra-rpc/src/server.rs index 7842c32be7a..0c637428661 100644 --- a/zebra-rpc/src/server.rs +++ b/zebra-rpc/src/server.rs @@ -73,9 +73,12 @@ impl RpcServer { #[cfg(feature = "getblocktemplate-rpcs")] { - // Initialize the getblocktemplate rpc methods - let get_block_template_rpc_impl = - GetBlockTemplateRpcImpl::new(latest_chain_tip.clone(), state.clone()); + // Initialize the getblocktemplate rpc method handler + let get_block_template_rpc_impl = GetBlockTemplateRpcImpl::new( + mempool.clone(), + state.clone(), + latest_chain_tip.clone(), + ); io.extend_with(get_block_template_rpc_impl.to_delegate()); } diff --git a/zebra-state/src/service/finalized_state/disk_format/tests/snapshot.rs b/zebra-state/src/service/finalized_state/disk_format/tests/snapshot.rs index c11a06df406..361aa116f80 100644 --- a/zebra-state/src/service/finalized_state/disk_format/tests/snapshot.rs +++ b/zebra-state/src/service/finalized_state/disk_format/tests/snapshot.rs @@ -11,7 +11,7 @@ //! //! If this test fails, run: //! ```sh -//! cargo insta test --review --delete-unreferenced-snapshots +//! cargo insta test --review //! ``` //! to update the test snapshots, then commit the `test_*.snap` files using git. //! diff --git a/zebra-state/src/service/finalized_state/zebra_db/block/tests/snapshot.rs b/zebra-state/src/service/finalized_state/zebra_db/block/tests/snapshot.rs index 9a09a80b497..c80c57cf8a7 100644 --- a/zebra-state/src/service/finalized_state/zebra_db/block/tests/snapshot.rs +++ b/zebra-state/src/service/finalized_state/zebra_db/block/tests/snapshot.rs @@ -26,7 +26,7 @@ //! //! If this test fails, run: //! ```sh -//! cargo insta test --review --delete-unreferenced-snapshots +//! cargo insta test --review //! ``` //! to update the test snapshots, then commit the `test_*.snap` files using git.