From 64ff7aff2ea0bc173057819268ec5e3bd006bf48 Mon Sep 17 00:00:00 2001 From: Dowland Aiello Date: Fri, 6 Sep 2024 19:14:12 +0000 Subject: [PATCH 1/2] valence: Add with_chain to all valence builders. --- src/utils/setup/valence.rs | 111 ++++++++++++++++++++++++++++++++----- 1 file changed, 98 insertions(+), 13 deletions(-) diff --git a/src/utils/setup/valence.rs b/src/utils/setup/valence.rs index 8833bb8..a004e78 100644 --- a/src/utils/setup/valence.rs +++ b/src/utils/setup/valence.rs @@ -14,6 +14,7 @@ use serde_json::Value; /// A tx creating an auctions manager. pub struct CreateAuctionsManagerTxBuilder<'a> { key: &'a str, + chain: &'a str, min_auction_amount: &'a [(&'a str, MinAmount)], server_addr: &'a str, test_ctx: &'a mut TestContext, @@ -25,6 +26,13 @@ impl<'a> CreateAuctionsManagerTxBuilder<'a> { self } + + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_min_auction_amount( &mut self, min_auction_amount: &'a [(&'a str, MinAmount)], @@ -44,6 +52,7 @@ impl<'a> CreateAuctionsManagerTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_create_auctions_manager( self.key, + self.chain, self.min_auction_amount, self.server_addr, ) @@ -52,6 +61,7 @@ impl<'a> CreateAuctionsManagerTxBuilder<'a> { pub struct CreateAuctionTxBuilder<'a> { key: &'a str, + chain: &'a str, offer_asset: Option<&'a str>, ask_asset: Option<&'a str>, auction_strategy: AuctionStrategy, @@ -69,6 +79,12 @@ impl<'a> CreateAuctionTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_offer_asset(&mut self, asset: &'a str) -> &mut Self { self.offer_asset = Some(asset); @@ -118,6 +134,7 @@ impl<'a> CreateAuctionTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_create_auction( self.key, + self.chain, ( self.offer_asset .ok_or(Error::MissingBuilderParam(String::from("pair")))?, @@ -138,6 +155,7 @@ impl<'a> CreateAuctionTxBuilder<'a> { pub struct FundAuctionTxBuilder<'a> { key: &'a str, + chain: &'a str, offer_asset: Option<&'a str>, ask_asset: Option<&'a str>, amt_offer_asset: Option, @@ -151,6 +169,12 @@ impl<'a> FundAuctionTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_offer_asset(&mut self, asset: &'a str) -> &mut Self { self.offer_asset = Some(asset); @@ -173,6 +197,7 @@ impl<'a> FundAuctionTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_fund_auction( self.key, + self.chain, ( self.offer_asset .ok_or(Error::MissingBuilderParam(String::from("pair")))?, @@ -189,6 +214,7 @@ impl<'a> FundAuctionTxBuilder<'a> { pub struct StartAuctionTxBuilder<'a> { key: &'a str, + chain: &'a str, offer_asset: Option<&'a str>, ask_asset: Option<&'a str>, end_block_delta: Option, @@ -202,6 +228,12 @@ impl<'a> StartAuctionTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_offer_asset(&mut self, asset: &'a str) -> &mut Self { self.offer_asset = Some(asset); @@ -224,6 +256,7 @@ impl<'a> StartAuctionTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_start_auction( self.key, + self.chain, self.end_block_delta .ok_or(Error::MissingBuilderParam(String::from("end_block_delta")))?, ( @@ -238,6 +271,7 @@ impl<'a> StartAuctionTxBuilder<'a> { pub struct MigrateAuctionTxBuilder<'a> { key: &'a str, + chain: &'a str, offer_asset: Option<&'a str>, ask_asset: Option<&'a str>, test_ctx: &'a mut TestContext, @@ -250,6 +284,12 @@ impl<'a> MigrateAuctionTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_offer_asset(&mut self, asset: &'a str) -> &mut Self { self.offer_asset = Some(asset); @@ -266,6 +306,7 @@ impl<'a> MigrateAuctionTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_migrate_auction( self.key, + self.chain, ( self.offer_asset .ok_or(Error::MissingBuilderParam(String::from("pair")))?, @@ -278,6 +319,7 @@ impl<'a> MigrateAuctionTxBuilder<'a> { pub struct CreatePriceOracleTxBuilder<'a> { key: &'a str, + chain: &'a str, seconds_allow_manual_change: u64, seconds_auction_prices_fresh: u64, test_ctx: &'a mut TestContext, @@ -290,6 +332,12 @@ impl<'a> CreatePriceOracleTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_seconds_allow_manual_change(&mut self, sec: u64) -> &mut Self { self.seconds_allow_manual_change = sec; @@ -306,6 +354,7 @@ impl<'a> CreatePriceOracleTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_create_price_oracle( self.key, + self.chain, self.seconds_allow_manual_change, self.seconds_auction_prices_fresh, ) @@ -314,6 +363,7 @@ impl<'a> CreatePriceOracleTxBuilder<'a> { pub struct UpdateAuctionOracleTxBuilder<'a> { key: &'a str, + chain: &'a str, test_ctx: &'a mut TestContext, } @@ -324,14 +374,21 @@ impl<'a> UpdateAuctionOracleTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + /// Sends the transaction. pub fn send(&mut self) -> Result<(), Error> { - self.test_ctx.tx_update_auction_oracle(self.key) + self.test_ctx.tx_update_auction_oracle(self.key, self.chain) } } pub struct ManualOraclePriceUpdateTxBuilder<'a> { key: &'a str, + chain: &'a str, offer_asset: Option<&'a str>, ask_asset: Option<&'a str>, price: Option, @@ -345,6 +402,12 @@ impl<'a> ManualOraclePriceUpdateTxBuilder<'a> { self } + pub fn with_chain(&mut self, chain: &'a str) -> &mut Self { + self.chain = chain; + + self + } + pub fn with_offer_asset(&mut self, asset: &'a str) -> &mut Self { self.offer_asset = Some(asset); @@ -367,6 +430,7 @@ impl<'a> ManualOraclePriceUpdateTxBuilder<'a> { pub fn send(&mut self) -> Result<(), Error> { self.test_ctx.tx_manual_oracle_price_update( self.key, + self.chain, self.offer_asset .ok_or(Error::MissingBuilderParam(String::from("offer_asset")))?, self.ask_asset @@ -381,6 +445,7 @@ impl TestContext { pub fn build_tx_create_auctions_manager(&mut self) -> CreateAuctionsManagerTxBuilder { CreateAuctionsManagerTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, min_auction_amount: &[], server_addr: NEUTRON_CHAIN_ADMIN_ADDR, test_ctx: self, @@ -392,14 +457,16 @@ impl TestContext { fn tx_create_auctions_manager<'a>( &mut self, sender_key: &str, + chain: &str, min_auction_amount: impl AsRef<[(&'a str, MinAmount)]>, server_addr: impl AsRef, ) -> Result<(), Error> { let mut contract_a: CosmWasm = self .get_contract() .contract(AUCTIONS_MANAGER_CONTRACT_NAME) + .src(chain) .get_cw(); - let neutron = self.get_chain(NEUTRON_CHAIN_NAME); + let neutron = self.get_chain(chain); let auction_code_id = neutron @@ -435,6 +502,7 @@ impl TestContext { pub fn build_tx_create_price_oracle(&mut self) -> CreatePriceOracleTxBuilder { CreatePriceOracleTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, seconds_allow_manual_change: 0, seconds_auction_prices_fresh: 100000000000, test_ctx: self, @@ -446,10 +514,11 @@ impl TestContext { fn tx_create_price_oracle( &mut self, sender_key: &str, + chain: &str, seconds_allow_manual_change: u64, seconds_auction_prices_fresh: u64, ) -> Result<(), Error> { - let auctions_manager: CosmWasm = self.get_auctions_manager().get_cw(); + let auctions_manager: CosmWasm = self.get_auctions_manager().src(chain).get_cw(); let auctions_manager_addr = auctions_manager .contract_addr @@ -457,7 +526,11 @@ impl TestContext { "contract_addresses::auctions_manager", )))?; - let mut contract_a = self.get_contract().contract(PRICE_ORACLE_NAME).get_cw(); + let mut contract_a = self + .get_contract() + .contract(PRICE_ORACLE_NAME) + .src(chain) + .get_cw(); let contract = contract_a.instantiate( sender_key, serde_json::json!({ @@ -485,6 +558,7 @@ impl TestContext { pub fn build_tx_create_auction(&mut self) -> CreateAuctionTxBuilder { CreateAuctionTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, offer_asset: Default::default(), ask_asset: Default::default(), auction_strategy: AuctionStrategy { @@ -510,6 +584,7 @@ impl TestContext { fn tx_create_auction, TDenomB: AsRef>( &mut self, sender_key: &str, + chain: &str, pair: (TDenomA, TDenomB), auction_strategy: AuctionStrategy, chain_halt_config: ChainHaltConfig, @@ -518,7 +593,7 @@ impl TestContext { amount_denom_a: u128, ) -> Result<(), Error> { // The auctions manager for this deployment - let contract_a = self.get_auctions_manager().get_cw(); + let contract_a = self.get_auctions_manager().src(chain).get_cw(); let denom_a = pair.0.as_ref(); let receipt = contract_a.execute( @@ -560,6 +635,7 @@ impl TestContext { pub fn build_tx_migrate_auction(&mut self) -> MigrateAuctionTxBuilder { MigrateAuctionTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, offer_asset: Default::default(), ask_asset: Default::default(), test_ctx: self, @@ -570,13 +646,15 @@ impl TestContext { fn tx_migrate_auction, TDenomB: AsRef>( &mut self, sender_key: &str, + chain: &str, pair: (TDenomA, TDenomB), ) -> Result<(), Error> { // The auctions manager for this deployment - let contract_a = self.get_auctions_manager().get_cw(); + let contract_a = self.get_auctions_manager().src(chain).get_cw(); let code_id = self .get_contract() .contract(AUCTION_CONTRACT_NAME) + .src(chain) .get_cw() .code_id .ok_or(Error::MissingContextVariable(String::from( @@ -620,14 +698,15 @@ impl TestContext { pub fn build_tx_update_auction_oracle(&mut self) -> UpdateAuctionOracleTxBuilder { UpdateAuctionOracleTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, test_ctx: self, } } - fn tx_update_auction_oracle(&mut self, sender_key: &str) -> Result<(), Error> { + fn tx_update_auction_oracle(&mut self, sender_key: &str, chain: &str) -> Result<(), Error> { // The auctions manager for this deployment - let contract_a = self.get_auctions_manager().get_cw(); - let neutron = self.get_chain(NEUTRON_CHAIN_NAME); + let contract_a = self.get_auctions_manager().src(chain).get_cw(); + let neutron = self.get_chain(chain); let oracle = neutron .contract_addrs @@ -662,6 +741,7 @@ impl TestContext { pub fn build_tx_manual_oracle_price_update(&mut self) -> ManualOraclePriceUpdateTxBuilder { ManualOraclePriceUpdateTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, offer_asset: Default::default(), ask_asset: Default::default(), price: Default::default(), @@ -672,12 +752,13 @@ impl TestContext { fn tx_manual_oracle_price_update( &mut self, sender_key: &str, + chain: &str, offer_asset: &str, ask_asset: &str, price: Decimal, ) -> Result<(), Error> { // The auctions manager for this deployment - let oracle = self.get_price_oracle().get_cw(); + let oracle = self.get_price_oracle().src(chain).get_cw(); let receipt = oracle.execute( sender_key, @@ -705,6 +786,7 @@ impl TestContext { pub fn build_tx_fund_auction(&mut self) -> FundAuctionTxBuilder { FundAuctionTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, offer_asset: Default::default(), ask_asset: Default::default(), amt_offer_asset: Default::default(), @@ -716,10 +798,11 @@ impl TestContext { fn tx_fund_auction, TDenomB: AsRef>( &mut self, sender_key: &str, + chain: &str, pair: (TDenomA, TDenomB), amt_offer_asset: u128, ) -> Result<(), Error> { - let manager = self.get_auctions_manager().get_cw(); + let manager = self.get_auctions_manager().src(chain).get_cw(); let denom_a = pair.0.as_ref(); @@ -747,6 +830,7 @@ impl TestContext { pub fn build_tx_start_auction(&mut self) -> StartAuctionTxBuilder { StartAuctionTxBuilder { key: DEFAULT_KEY, + chain: NEUTRON_CHAIN_NAME, offer_asset: Default::default(), ask_asset: Default::default(), end_block_delta: Default::default(), @@ -758,11 +842,12 @@ impl TestContext { fn tx_start_auction, TDenomB: AsRef>( &mut self, sender_key: &str, + chain: &str, end_blocks: u128, pair: (TDenomA, TDenomB), ) -> Result<(), Error> { - let manager = self.get_auctions_manager().get_cw(); - let neutron = self.get_chain(NEUTRON_CHAIN_NAME); + let manager = self.get_auctions_manager().src(chain).get_cw(); + let neutron = self.get_chain(chain); let start_block_resp = neutron .rb From 2eb91470fb0e56d7416f85649ebfa6a5e6d94dfe Mon Sep 17 00:00:00 2001 From: Dowland Aiello Date: Fri, 6 Sep 2024 20:51:33 +0000 Subject: [PATCH 2/2] valence: Rename chain vars for consistency with chain agnosticism. --- src/utils/setup/valence.rs | 69 +++++++++++++------------------------- 1 file changed, 23 insertions(+), 46 deletions(-) diff --git a/src/utils/setup/valence.rs b/src/utils/setup/valence.rs index a004e78..b2ab406 100644 --- a/src/utils/setup/valence.rs +++ b/src/utils/setup/valence.rs @@ -466,15 +466,14 @@ impl TestContext { .contract(AUCTIONS_MANAGER_CONTRACT_NAME) .src(chain) .get_cw(); - let neutron = self.get_chain(chain); - - let auction_code_id = - neutron - .contract_codes - .get(AUCTION_CONTRACT_NAME) - .ok_or(Error::Misc(format!( - "contract '{AUCTION_CONTRACT_NAME}' is missing" - )))?; + let local_chain = self.get_chain(chain); + + let auction_code_id = local_chain + .contract_codes + .get(AUCTION_CONTRACT_NAME) + .ok_or(Error::Misc(format!( + "contract '{AUCTION_CONTRACT_NAME}' is missing" + )))?; let contract = contract_a.instantiate( sender_key, @@ -490,9 +489,9 @@ impl TestContext { "", )?; - let chain = self.get_mut_chain(NEUTRON_CHAIN_NAME); + let local_chain = self.get_mut_chain(chain); - chain + local_chain .contract_addrs .insert(AUCTIONS_MANAGER_CONTRACT_NAME.to_owned(), contract.address); @@ -545,7 +544,7 @@ impl TestContext { "", )?; - let chain = self.get_mut_chain(NEUTRON_CHAIN_NAME); + let chain = self.get_mut_chain(chain); chain .contract_addrs @@ -623,10 +622,7 @@ impl TestContext { receipt ); - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) } @@ -686,10 +682,7 @@ impl TestContext { receipt ); - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) } @@ -706,14 +699,10 @@ impl TestContext { fn tx_update_auction_oracle(&mut self, sender_key: &str, chain: &str) -> Result<(), Error> { // The auctions manager for this deployment let contract_a = self.get_auctions_manager().src(chain).get_cw(); - let neutron = self.get_chain(chain); - let oracle = - neutron - .contract_addrs - .get(PRICE_ORACLE_NAME) - .ok_or(Error::MissingContextVariable(String::from( - "contract_addrs::price_oracle", - )))?; + let local_chain = self.get_chain(chain); + let oracle = local_chain.contract_addrs.get(PRICE_ORACLE_NAME).ok_or( + Error::MissingContextVariable(String::from("contract_addrs::price_oracle")), + )?; let receipt = contract_a.execute( sender_key, @@ -729,10 +718,7 @@ impl TestContext { "--gas 2000000", )?; - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) } @@ -774,10 +760,7 @@ impl TestContext { "--gas 2000000", )?; - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) } @@ -818,10 +801,7 @@ impl TestContext { format!("--amount {amt_offer_asset}{denom_a} --gas 1000000").as_str(), )?; - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) } @@ -847,9 +827,9 @@ impl TestContext { pair: (TDenomA, TDenomB), ) -> Result<(), Error> { let manager = self.get_auctions_manager().src(chain).get_cw(); - let neutron = self.get_chain(chain); + let local_chain = self.get_chain(chain); - let start_block_resp = neutron + let start_block_resp = local_chain .rb .bin("q block --node=%RPC% --chain-id=%CHAIN_ID%", true); let maybe_start_block_data: Value = start_block_resp @@ -885,10 +865,7 @@ impl TestContext { "--gas 1000000", )?; - self.guard_tx_errors( - NEUTRON_CHAIN_NAME, - receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str(), - )?; + self.guard_tx_errors(chain, receipt.tx_hash.ok_or(Error::TxMissingLogs)?.as_str())?; Ok(()) }