From 29af67d6d860139b76ebc8c91a1761f572e9812b Mon Sep 17 00:00:00 2001 From: Jacek Malec <145967538+jacek-casper@users.noreply.github.com> Date: Thu, 9 May 2024 15:04:55 +0100 Subject: [PATCH] Remove unwrap in state_get_auction_info --- rpc_sidecar/src/rpcs/state.rs | 54 ++++++++++++++++++++++++++++++----- 1 file changed, 47 insertions(+), 7 deletions(-) diff --git a/rpc_sidecar/src/rpcs/state.rs b/rpc_sidecar/src/rpcs/state.rs index 22055919..40b81352 100644 --- a/rpc_sidecar/src/rpcs/state.rs +++ b/rpc_sidecar/src/rpcs/state.rs @@ -334,11 +334,7 @@ impl RpcWithOptionalParams for GetAuctionInfo { maybe_params: Option, ) -> Result { let block_identifier = maybe_params.map(|params| params.block_identifier); - let block_header = node_client - .read_block_header(block_identifier) - .await - .map_err(|err| Error::NodeRequest("block header", err))? - .unwrap(); + let block_header = common::get_block_header(&*node_client, block_identifier).await?; let state_identifier = block_identifier.map(GlobalStateIdentifier::from); let legacy_bid_stored_values = node_client @@ -1128,8 +1124,8 @@ mod tests { global_state::{TrieMerkleProof, TrieMerkleProofStep}, system::auction::{Bid, BidKind, ValidatorBid}, testing::TestRng, - AccessRights, AddressableEntity, Block, ByteCodeHash, EntityKind, PackageHash, - ProtocolVersion, TestBlockBuilder, TransactionRuntime, + AccessRights, AddressableEntity, AvailableBlockRange, Block, ByteCodeHash, EntityKind, + PackageHash, ProtocolVersion, TestBlockBuilder, TransactionRuntime, }; use pretty_assertions::assert_eq; use rand::Rng; @@ -1351,6 +1347,50 @@ mod tests { ); } + #[tokio::test] + async fn should_fail_auction_info_when_block_not_found() { + struct ClientMock; + + #[async_trait] + impl NodeClient for ClientMock { + async fn send_request( + &self, + req: BinaryRequest, + ) -> Result { + match req { + BinaryRequest::Get(GetRequest::Information { info_type_tag, .. }) + if InformationRequestTag::try_from(info_type_tag) + == Ok(InformationRequestTag::BlockHeader) => + { + Ok(BinaryResponseAndRequest::new( + BinaryResponse::new_empty(SUPPORTED_PROTOCOL_VERSION), + &[], + )) + } + BinaryRequest::Get(GetRequest::Information { info_type_tag, .. }) + if InformationRequestTag::try_from(info_type_tag) + == Ok(InformationRequestTag::AvailableBlockRange) => + { + Ok(BinaryResponseAndRequest::new( + BinaryResponse::from_value( + AvailableBlockRange::RANGE_0_0, + SUPPORTED_PROTOCOL_VERSION, + ), + &[], + )) + } + req => unimplemented!("unexpected request: {:?}", req), + } + } + } + + let err = GetAuctionInfo::do_handle_request(Arc::new(ClientMock), None) + .await + .expect_err("should reject request"); + + assert_eq!(err.code(), ErrorCode::NoSuchBlock as i64); + } + #[tokio::test] async fn should_read_entity() { use casper_types::addressable_entity::{ActionThresholds, AssociatedKeys};