From 5f0221b2d012bb84261756aa95a2a47456418044 Mon Sep 17 00:00:00 2001 From: Ryan Vandersmith Date: Thu, 3 Oct 2024 12:54:56 -0600 Subject: [PATCH] refactor: use `evm_rpc_types` in Rust E2E canister (#295) See https://github.com/internet-computer-protocol/evm-rpc-canister/pull/294#discussion_r1784852481. --- Cargo.lock | 1 + e2e/rust/Cargo.toml | 1 + e2e/rust/build.rs | 16 --------------- e2e/rust/src/main.rs | 48 +++++++++++++++++++++++++++----------------- 4 files changed, 32 insertions(+), 34 deletions(-) delete mode 100644 e2e/rust/build.rs diff --git a/Cargo.lock b/Cargo.lock index 6aaa8c2c..c27b00aa 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -529,6 +529,7 @@ name = "e2e" version = "0.1.0" dependencies = [ "candid", + "evm_rpc_types", "ic-cdk 0.16.0", "ic-cdk-bindgen", "ic-cdk-macros 0.16.0", diff --git a/e2e/rust/Cargo.toml b/e2e/rust/Cargo.toml index 9d819c43..976fed04 100644 --- a/e2e/rust/Cargo.toml +++ b/e2e/rust/Cargo.toml @@ -12,6 +12,7 @@ ic-cdk = { workspace = true } ic-cdk-macros = { workspace = true } serde = { workspace = true } serde_bytes = { workspace = true } +evm_rpc_types = { path = "../../evm_rpc_types" } [build-dependencies] ic-cdk-bindgen = { workspace = true } diff --git a/e2e/rust/build.rs b/e2e/rust/build.rs deleted file mode 100644 index 112bcbaf..00000000 --- a/e2e/rust/build.rs +++ /dev/null @@ -1,16 +0,0 @@ -use ic_cdk_bindgen::{Builder, Config}; - -fn main() { - let mut builder = Builder::new(); - - builder.add({ - // Uppercase canister name is a workaround for using `ic-cdk-bindgen` with `dfx` >= 0.18.0 - let mut config = Config::new("EVM_RPC_STAGING"); - config - .binding - .set_type_attributes("#[derive(CandidType, Clone, Debug, Deserialize)]".to_string()); - config - }); - - builder.build(None); -} diff --git a/e2e/rust/src/main.rs b/e2e/rust/src/main.rs index 0e70e78f..e8a15ca7 100644 --- a/e2e/rust/src/main.rs +++ b/e2e/rust/src/main.rs @@ -1,20 +1,31 @@ -use candid::candid_method; -use ic_cdk_macros::update; +use std::str::FromStr; -mod declarations; +use candid::{candid_method, Principal}; +use ic_cdk_macros::update; -use declarations::EVM_RPC_STAGING::{ - BlockTag, EthMainnetService, GetBlockByNumberResult, MultiGetBlockByNumberResult, - ProviderError, RpcError, RpcService, RpcServices, EVM_RPC_STAGING as evm_rpc, +use evm_rpc_types::{ + Block, BlockTag, EthMainnetService, Hex32, MultiRpcResult, ProviderError, RpcError, RpcService, + RpcServices, }; fn main() {} +#[cfg(target_arch = "wasm32")] +const CANISTER_ID: Option<&str> = Some(std::env!( + "CANISTER_ID_EVM_RPC_STAGING", + "Unspecified canister ID environment variable" +)); +#[cfg(not(target_arch = "wasm32"))] +const CANISTER_ID: Option<&str> = None; + #[update] #[candid_method(update)] pub async fn test() { assert!(ic_cdk::api::is_controller(&ic_cdk::caller())); + let canister_id = Principal::from_str(CANISTER_ID.unwrap()) + .expect("Error parsing canister ID environment variable"); + // Define request parameters let params = ( RpcService::EthMainnet(EthMainnetService::PublicNode), // Ethereum mainnet @@ -24,7 +35,7 @@ pub async fn test() { // Get cycles cost let (cycles_result,): (Result,) = - ic_cdk::api::call::call(evm_rpc.0, "requestCost", params.clone()) + ic_cdk::api::call::call(canister_id, "requestCost", params.clone()) .await .unwrap(); let cycles = cycles_result @@ -32,7 +43,7 @@ pub async fn test() { // Call without sending cycles let (result_without_cycles,): (Result,) = - ic_cdk::api::call::call(evm_rpc.0, "request", params.clone()) + ic_cdk::api::call::call(canister_id, "request", params.clone()) .await .unwrap(); match result_without_cycles { @@ -45,7 +56,7 @@ pub async fn test() { // Call with expected number of cycles let (result,): (Result,) = - ic_cdk::api::call::call_with_payment128(evm_rpc.0, "request", params, cycles) + ic_cdk::api::call::call_with_payment128(canister_id, "request", params, cycles) .await .unwrap(); match result { @@ -61,8 +72,8 @@ pub async fn test() { } // Call a Candid-RPC method - let (results,): (MultiGetBlockByNumberResult,) = ic_cdk::api::call::call_with_payment128( - evm_rpc.0, + let (results,): (MultiRpcResult,) = ic_cdk::api::call::call_with_payment128( + canister_id, "eth_getBlockByNumber", ( RpcServices::EthMainnet(Some(vec![ @@ -79,18 +90,19 @@ pub async fn test() { .await .unwrap(); match results { - MultiGetBlockByNumberResult::Consistent(result) => match result { - GetBlockByNumberResult::Ok(block) => { + MultiRpcResult::Consistent(result) => match result { + Ok(block) => { assert_eq!( block.hash, - "0x114755458f57fe1a81e7b03e038ad00f9a675681c8b94cf102c30a84c5545c76" + Hex32::from_str( + "0x114755458f57fe1a81e7b03e038ad00f9a675681c8b94cf102c30a84c5545c76" + ) + .unwrap() ); } - GetBlockByNumberResult::Err(err) => { - ic_cdk::trap(&format!("error in `eth_getBlockByNumber`: {:?}", err)) - } + Err(err) => ic_cdk::trap(&format!("error in `eth_getBlockByNumber`: {:?}", err)), }, - MultiGetBlockByNumberResult::Inconsistent(results) => ic_cdk::trap(&format!( + MultiRpcResult::Inconsistent(results) => ic_cdk::trap(&format!( "inconsistent results in `eth_getBlockByNumber`: {:?}", results )),