From 2bb1c1e177a7bf50be917fdbd58f49e866ee580c Mon Sep 17 00:00:00 2001 From: Daniel Karzel Date: Wed, 3 Mar 2021 10:56:49 +1100 Subject: [PATCH] No prefix for wallets in monero harness Prefixing docker-containers and -networks is a necessity to be able to spin up multiple containers and networks. However, there is no reason to prefix the wallet names that live inside a container. One cannot add a wallet with the same name twice, so the prefixing of wallets does not bring any advantage. When re-opening a wallet by name the wallet name prefix is cumbersome and was thus removed. --- monero-harness/src/lib.rs | 35 +++++++++++---------------------- monero-harness/tests/monerod.rs | 2 +- monero-harness/tests/wallet.rs | 9 +++------ swap/tests/testutils/mod.rs | 2 +- 4 files changed, 17 insertions(+), 31 deletions(-) diff --git a/monero-harness/src/lib.rs b/monero-harness/src/lib.rs index ab528564..f635da63 100644 --- a/monero-harness/src/lib.rs +++ b/monero-harness/src/lib.rs @@ -44,52 +44,42 @@ const WAIT_WALLET_SYNC_MILLIS: u64 = 1000; pub struct Monero { monerod: Monerod, wallets: Vec, - prefix: String, } impl<'c> Monero { /// Starts a new regtest monero container setup consisting out of 1 monerod - /// node and n wallets. The containers and network will be prefixed, either - /// randomly generated or as defined in `prefix` if provided. There will - /// be 1 miner wallet started automatically. Default monerod container - /// name will be: `prefix`_`monerod` Default miner wallet container name - /// will be: `prefix`_`miner` Default network will be: `prefix`_`monero` + /// node and n wallets. The docker container and network will be prefixed + /// with a randomly generated `prefix`. One miner wallet is started + /// automatically. + /// monerod container name is: `prefix`_`monerod` + /// network is: `prefix`_`monero` + /// miner wallet container name is: `miner` pub async fn new( cli: &'c Cli, - prefix: Option, additional_wallets: Vec, ) -> Result<(Self, Vec>)> { - let prefix = format!("{}_", prefix.unwrap_or_else(random_prefix)); - + let prefix = format!("{}_", random_prefix()); let monerod_name = format!("{}{}", prefix, MONEROD_DAEMON_CONTAINER_NAME); let network = format!("{}{}", prefix, MONEROD_DEFAULT_NETWORK); - tracing::info!("Starting monerod... {}", monerod_name); + tracing::info!("Starting monerod: {}", monerod_name); let (monerod, monerod_container) = Monerod::new(cli, monerod_name, network)?; let mut containers = vec![monerod_container]; let mut wallets = vec![]; - let miner = format!("{}{}", prefix, "miner"); - tracing::info!("Starting miner wallet... {}", miner); + let miner = "miner"; + tracing::info!("Starting miner wallet: {}", miner); let (miner_wallet, miner_container) = MoneroWalletRpc::new(cli, &miner, &monerod).await?; wallets.push(miner_wallet); containers.push(miner_container); for wallet in additional_wallets.iter() { - tracing::info!("Starting wallet: {}...", wallet); - let wallet = format!("{}{}", prefix, wallet); + tracing::info!("Starting wallet: {}", wallet); let (wallet, container) = MoneroWalletRpc::new(cli, &wallet, &monerod).await?; wallets.push(wallet); containers.push(container); } - Ok(( - Self { - monerod, - wallets, - prefix, - }, - containers, - )) + Ok((Self { monerod, wallets }, containers)) } pub fn monerod(&self) -> &Monerod { @@ -97,7 +87,6 @@ impl<'c> Monero { } pub fn wallet(&self, name: &str) -> Result<&MoneroWalletRpc> { - let name = format!("{}{}", self.prefix, name); let wallet = self .wallets .iter() diff --git a/monero-harness/tests/monerod.rs b/monero-harness/tests/monerod.rs index e48e3b87..7e816264 100644 --- a/monero-harness/tests/monerod.rs +++ b/monero-harness/tests/monerod.rs @@ -12,7 +12,7 @@ async fn init_miner_and_mine_to_miner_address() { let _guard = init_tracing(); let tc = Cli::default(); - let (monero, _monerod_container) = Monero::new(&tc, None, vec![]).await.unwrap(); + let (monero, _monerod_container) = Monero::new(&tc, vec![]).await.unwrap(); monero.init(vec![]).await.unwrap(); diff --git a/monero-harness/tests/wallet.rs b/monero-harness/tests/wallet.rs index a571a35e..3314341a 100644 --- a/monero-harness/tests/wallet.rs +++ b/monero-harness/tests/wallet.rs @@ -16,12 +16,9 @@ async fn fund_transfer_and_check_tx_key() { let send_to_bob = 5_000_000_000; let tc = Cli::default(); - let (monero, _containers) = Monero::new(&tc, Some("test_".to_string()), vec![ - "alice".to_string(), - "bob".to_string(), - ]) - .await - .unwrap(); + let (monero, _containers) = Monero::new(&tc, vec!["alice".to_string(), "bob".to_string()]) + .await + .unwrap(); let alice_wallet = monero.wallet("alice").unwrap(); let bob_wallet = monero.wallet("bob").unwrap(); diff --git a/swap/tests/testutils/mod.rs b/swap/tests/testutils/mod.rs index 61cd01db..a3a27ace 100644 --- a/swap/tests/testutils/mod.rs +++ b/swap/tests/testutils/mod.rs @@ -597,7 +597,7 @@ async fn init_test_wallets( let xmr_wallet = swap::monero::Wallet::new_with_client( monero.wallet(name).unwrap().client(), monero::Network::default(), - "irrelevant_for_tests".to_string(), + name.to_string(), ); let electrum_rpc_url = {