From be2df69a92eef7d334dff1b805fa49f7ee87250f Mon Sep 17 00:00:00 2001 From: yito88 Date: Fri, 10 Nov 2023 17:59:05 +0100 Subject: [PATCH] workaround for serde_json deserialization of ChainConfig --- Cargo.lock | 5 ++--- crates/relayer-cli/Cargo.toml | 2 +- crates/relayer-rest/Cargo.toml | 2 +- crates/relayer-rest/tests/mock.rs | 5 ++++- crates/relayer/src/chain/namada.rs | 4 ---- crates/relayer/src/config.rs | 11 +++++++++-- e2e/namada-gaia-simple-transfers | 2 +- e2e/namada-simple-transfers | 2 +- tools/test-framework/src/chain/chain_type.rs | 7 ------- 9 files changed, 19 insertions(+), 21 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index c8479f6808..c8b894eedf 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -3147,7 +3147,6 @@ dependencies = [ "ibc-relayer-types", "ibc-telemetry", "itertools 0.10.5", - "namada_sdk", "once_cell", "oneline-eyre", "regex", @@ -5763,9 +5762,9 @@ dependencies = [ [[package]] name = "serde_json" -version = "1.0.107" +version = "1.0.108" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6b420ce6e3d8bd882e9b243c6eed35dbc9a6110c9769e74b584e0d68d1f20c65" +checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b" dependencies = [ "itoa", "ryu", diff --git a/crates/relayer-cli/Cargo.toml b/crates/relayer-cli/Cargo.toml index 1ac68f64cc..be23988a68 100644 --- a/crates/relayer-cli/Cargo.toml +++ b/crates/relayer-cli/Cargo.toml @@ -45,7 +45,6 @@ hdpath = "0.6.3" http = "0.2" humantime = "2.1" itertools = "0.10.5" -namada_sdk = { git = "https://github.com/anoma/namada", rev = "7116b6aa916026e97f3f871f291c6ba1c7b427d2", features = ["std"] } oneline-eyre = "0.1" regex = "1.9.5" serde = { version = "1.0", features = ["serde_derive"] } @@ -56,6 +55,7 @@ tokio = { version = "1.0", features = ["full"] } tracing = "0.1.36" tracing-subscriber = { version = "0.3.14", features = ["fmt", "env-filter", "json"]} time = "0.3" + [dependencies.tendermint] version = "0.34.0" features = ["secp256k1"] diff --git a/crates/relayer-rest/Cargo.toml b/crates/relayer-rest/Cargo.toml index 8f3a3bdb05..e65583a65c 100644 --- a/crates/relayer-rest/Cargo.toml +++ b/crates/relayer-rest/Cargo.toml @@ -25,5 +25,5 @@ tokio = "1.26" [dev-dependencies] reqwest = { version = "0.11.16", features = ["json"], default-features = false } -toml = "0.7.3" serde_json = "1" +toml = "0.7.3" diff --git a/crates/relayer-rest/tests/mock.rs b/crates/relayer-rest/tests/mock.rs index b18a1b4531..1eb950f7d9 100644 --- a/crates/relayer-rest/tests/mock.rs +++ b/crates/relayer-rest/tests/mock.rs @@ -46,9 +46,12 @@ where let response = reqwest::get(&format!("http://127.0.0.1:{port}{path}")) .await .unwrap() - .json::() + .json() .await .unwrap(); + // Workaround for serde_json deserialization failure + // from_str/from_slice() failed for ChainConfig + let response = serde_json::from_value::(response).unwrap(); assert_eq!(response, expected); diff --git a/crates/relayer/src/chain/namada.rs b/crates/relayer/src/chain/namada.rs index e282688a09..3834df34ee 100644 --- a/crates/relayer/src/chain/namada.rs +++ b/crates/relayer/src/chain/namada.rs @@ -267,10 +267,6 @@ impl ChainEndpoint for NamadaChain { ) })?; - // TODO Namada health check - - // TODO version check - Ok(HealthCheck::Healthy) } diff --git a/crates/relayer/src/config.rs b/crates/relayer/src/config.rs index a5d997cc0e..23fc712411 100644 --- a/crates/relayer/src/config.rs +++ b/crates/relayer/src/config.rs @@ -648,8 +648,15 @@ impl ChainConfig { .map(|(key_name, keys)| (key_name, keys.into())) .collect() } - // TODO Namada should use the wallet - ChainConfig::Namada(_) => return Err(keyring::errors::Error::key_not_found()), + ChainConfig::Namada(config) => { + let keyring = + KeyRing::new_namada(Store::Test, &config.id, &config.key_store_folder)?; + keyring + .keys()? + .into_iter() + .map(|(key_name, keys)| (key_name, keys.into())) + .collect() + } }; Ok(keys) } diff --git a/e2e/namada-gaia-simple-transfers b/e2e/namada-gaia-simple-transfers index b31c8af4af..1cca1451e1 100755 --- a/e2e/namada-gaia-simple-transfers +++ b/e2e/namada-gaia-simple-transfers @@ -175,7 +175,7 @@ ${NAMADAC} --base-dir ${base_dir} ibc-transfer \ --node ${NAMADA_LEDGER_ADDR} # wait for relaying -sleep 10 +sleep 15 echo "==== Balances on Namada ====" ${NAMADAC} --base-dir ${base_dir} balance \ diff --git a/e2e/namada-simple-transfers b/e2e/namada-simple-transfers index 1ca51610c7..1737d406d1 100755 --- a/e2e/namada-simple-transfers +++ b/e2e/namada-simple-transfers @@ -190,7 +190,7 @@ ${NAMADAC} --base-dir ${base_dir_b} ibc-transfer \ --node ${LEDGER_ADDR_B} # wait for relaying -sleep 10 +sleep 15 echo "==== Balances on chain A ====" ${NAMADAC} --base-dir ${base_dir_a} balance \ diff --git a/tools/test-framework/src/chain/chain_type.rs b/tools/test-framework/src/chain/chain_type.rs index 0f43a7310c..2d39f8f811 100644 --- a/tools/test-framework/src/chain/chain_type.rs +++ b/tools/test-framework/src/chain/chain_type.rs @@ -7,13 +7,11 @@ use crate::util::random::{random_u32, random_unused_tcp_port}; const COSMOS_HD_PATH: &str = "m/44'/118'/0'/0/0"; const EVMOS_HD_PATH: &str = "m/44'/60'/0'/0/0"; -const NAMADA_HD_PATH: &str = "m/44'/60'/0'/0/0"; #[derive(Clone, Debug)] pub enum ChainType { Cosmos, Evmos, - Namada, } impl ChainType { @@ -21,7 +19,6 @@ impl ChainType { match self { Self::Cosmos => COSMOS_HD_PATH, Self::Evmos => EVMOS_HD_PATH, - Self::Namada => NAMADA_HD_PATH, } } @@ -35,7 +32,6 @@ impl ChainType { } } Self::Evmos => ChainId::from_string(&format!("evmos_9000-{prefix}")), - Self::Namada => ChainId::from_string(prefix), } } @@ -49,7 +45,6 @@ impl ChainType { res.push("--json-rpc.address".to_owned()); res.push(format!("localhost:{json_rpc_port}")); } - Self::Namada => {} } res } @@ -60,7 +55,6 @@ impl ChainType { Self::Evmos => AddressType::Ethermint { pk_type: "/ethermint.crypto.v1.ethsecp256k1.PubKey".to_string(), }, - Self::Namada => AddressType::default(), } } } @@ -75,7 +69,6 @@ impl FromStr for ChainType { name if name.contains("wasmd") => Ok(ChainType::Cosmos), name if name.contains("icad") => Ok(ChainType::Cosmos), name if name.contains("evmosd") => Ok(ChainType::Evmos), - name if name.contains("namada") => Ok(ChainType::Namada), _ => Ok(ChainType::Cosmos), } }