From d7c3dd75193375d54e0b43e3ec667ab7af13815c Mon Sep 17 00:00:00 2001 From: nahem Date: Wed, 31 Jul 2024 14:46:12 +0200 Subject: [PATCH] fix: use Uint256 & Decimal256 to be able to work with 18 decimals --- .../injective-auction-pool/src/contract.rs | 3 +- .../injective-auction-pool/src/executions.rs | 32 ++++--------- .../injective-auction-pool/src/helpers.rs | 4 +- contracts/injective-auction-pool/src/state.rs | 2 +- .../src/tests/unit_tests.rs | 46 +++++++++---------- deploy/02-testnet-auction.txt | 31 +++++++++---- .../injective_auction/src/auction_pool.rs | 2 - 7 files changed, 58 insertions(+), 62 deletions(-) diff --git a/contracts/injective-auction-pool/src/contract.rs b/contracts/injective-auction-pool/src/contract.rs index eacd88e..c59e77d 100644 --- a/contracts/injective-auction-pool/src/contract.rs +++ b/contracts/injective-auction-pool/src/contract.rs @@ -105,8 +105,7 @@ pub fn execute( } => executions::try_bid(deps, env, info, auction_round, basket_value), ExecuteMsg::JoinPool { auction_round, - basket_value, - } => executions::join_pool(deps, env, info, auction_round, basket_value), + } => executions::join_pool(deps, env, info, auction_round), ExecuteMsg::ExitPool {} => executions::exit_pool(deps, env, info), ExecuteMsg::SettleAuction { auction_round, diff --git a/contracts/injective-auction-pool/src/executions.rs b/contracts/injective-auction-pool/src/executions.rs index 73e9d56..29c3bc0 100644 --- a/contracts/injective-auction-pool/src/executions.rs +++ b/contracts/injective-auction-pool/src/executions.rs @@ -1,8 +1,7 @@ use cosmwasm_std::{ - attr, coins, to_json_binary, BankMsg, CosmosMsg, Decimal, DepsMut, Env, MessageInfo, Response, - Uint128, WasmMsg, + attr, coins, BankMsg, CosmosMsg, Decimal, Decimal256, DepsMut, Env, MessageInfo, Response, + Uint128, Uint256, }; -use injective_auction::auction_pool::ExecuteMsg::TryBid; use injective_std::types::cosmos::base::v1beta1::Coin; use injective_std::types::injective::auction::v1beta1::MsgBid; @@ -107,7 +106,6 @@ pub(crate) fn join_pool( env: Env, info: MessageInfo, auction_round: u64, - basket_value: Uint128, ) -> Result { let config = CONFIG.load(deps.storage)?; let amount = cw_utils::must_pay(&info, &config.native_denom)?; @@ -132,7 +130,7 @@ pub(crate) fn join_pool( amount, )); - // send the minted lp token to the user + // send the minted lp token to the user address let lp_denom = format!("factory/{}/auction.{}", env.contract.address, lp_subdenom); messages.push( BankMsg::Send { @@ -146,16 +144,6 @@ pub(crate) fn join_pool( BIDDING_BALANCE .update::<_, ContractError>(deps.storage, |balance| Ok(balance.checked_add(amount)?))?; - // try to bid on the auction if possible - messages.push(CosmosMsg::Wasm(WasmMsg::Execute { - contract_addr: env.contract.address.to_string(), - msg: to_json_binary(&TryBid { - auction_round, - basket_value, - })?, - funds: vec![], - })); - Ok(Response::default().add_messages(messages).add_attributes(vec![ ("action", "join_pool".to_string()), ("auction_round", auction_round.to_string()), @@ -232,7 +220,6 @@ pub(crate) fn try_bid( let current_auction_round_response = query_current_auction(deps.as_ref())?; let current_auction_round = current_auction_round_response.auction_round; - //.ok_or(ContractError::CurrentAuctionQueryError)?; // prevents the contract from bidding on the wrong auction round if auction_round != current_auction_round.u64() { @@ -255,22 +242,23 @@ pub(crate) fn try_bid( let minimum_allowed_bid = current_auction_round_response .highest_bid_amount .to_string() - // .unwrap_or(0.to_string()) - .parse::()? - .checked_mul((Decimal::one().checked_add(config.min_next_bid_increment_rate))?)? + .parse::()? + .checked_mul((Decimal256::one().checked_add(config.min_next_bid_increment_rate.into()))?)? .to_uint_ceil() - .checked_add(Uint128::one())?; + .checked_add(Uint256::one())?; // prevents the contract from bidding if the minimum allowed bid is higher than bidding balance let bidding_balance: Uint128 = BIDDING_BALANCE.load(deps.storage)?; - if minimum_allowed_bid > bidding_balance { + if minimum_allowed_bid > bidding_balance.into() { return Ok(Response::default() .add_attribute("action", "did_not_bid") .add_attribute("reason", "minimum_allowed_bid_is_higher_than_bidding_balance")); } // prevents the contract from bidding if the returns are not high enough - if basket_value * (Decimal::one() - config.min_return) < minimum_allowed_bid { + if Uint256::from(basket_value) * (Decimal256::one() - Decimal256::from(config.min_return)) + < minimum_allowed_bid + { return Ok(Response::default() .add_attribute("action", "did_not_bid") .add_attribute("reason", "basket_value_is_not_worth_bidding_for")); diff --git a/contracts/injective-auction-pool/src/helpers.rs b/contracts/injective-auction-pool/src/helpers.rs index febd696..e3dd71b 100644 --- a/contracts/injective-auction-pool/src/helpers.rs +++ b/contracts/injective-auction-pool/src/helpers.rs @@ -264,8 +264,8 @@ pub(crate) fn validate_percentage(percentage: Decimal) -> Result StdResult { - let current_auction_basket_response: crate::state::QueryCurrentAuctionBasketResponse = +) -> StdResult { + let current_auction_basket_response: crate::state::CurrentAuctionBasketResponse = deps.querier.query(&QueryRequest::Stargate { path: "/injective.auction.v1beta1.Query/CurrentAuctionBasket".to_string(), data: [].into(), diff --git a/contracts/injective-auction-pool/src/state.rs b/contracts/injective-auction-pool/src/state.rs index 56808bc..96945a8 100644 --- a/contracts/injective-auction-pool/src/state.rs +++ b/contracts/injective-auction-pool/src/state.rs @@ -33,7 +33,7 @@ pub const FUNDS_LOCKED: Item = Item::new("funds_locked"); #[cw_serde] #[serde(rename_all = "camelCase")] -pub struct QueryCurrentAuctionBasketResponse { +pub struct CurrentAuctionBasketResponse { pub amount: Vec, pub auction_round: Uint64, pub auction_closing_time: Int64, diff --git a/contracts/injective-auction-pool/src/tests/unit_tests.rs b/contracts/injective-auction-pool/src/tests/unit_tests.rs index 28297a8..40fb11b 100644 --- a/contracts/injective-auction-pool/src/tests/unit_tests.rs +++ b/contracts/injective-auction-pool/src/tests/unit_tests.rs @@ -1,11 +1,11 @@ -use std::marker::PhantomData; +use std::{marker::PhantomData, str::FromStr}; use cosmwasm_std::{ attr, coin, coins, from_json, testing::{mock_env, mock_info, BankQuerier, MockApi, MockStorage, MOCK_CONTRACT_ADDR}, to_json_binary, Addr, BankMsg, Binary, CodeInfoResponse, ContractResult as CwContractResult, - CosmosMsg, Decimal, Empty, Env, HexBinary, Int64, MemoryStorage, MessageInfo, OwnedDeps, - Querier, QuerierResult, QueryRequest, Uint128, Uint64, WasmMsg, WasmQuery, + CosmosMsg, Decimal, Decimal256, Empty, Env, HexBinary, Int64, MemoryStorage, MessageInfo, + OwnedDeps, Querier, QuerierResult, QueryRequest, Uint128, Uint256, Uint64, WasmQuery, }; use cw_ownable::Ownership; use injective_auction::auction_pool::{ @@ -44,7 +44,7 @@ impl Querier for AuctionQuerier { } => match path.as_str() { "/injective.auction.v1beta1.Query/CurrentAuctionBasket" => { Ok(CwContractResult::Ok( - to_json_binary(&crate::state::QueryCurrentAuctionBasketResponse { + to_json_binary(&crate::state::CurrentAuctionBasketResponse { amount: vec![cosmwasm_std::Coin { denom: "uatom".to_string(), amount: Uint128::new(10000u128), @@ -337,7 +337,6 @@ pub fn join_pool_works() { let info = mock_info("robinho", &coins(100, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let res = execute(deps.as_mut().branch(), env.clone(), info, msg).unwrap(); @@ -361,20 +360,6 @@ pub fn join_pool_works() { .into() ); - // contract calls try_bid on itself - assert_eq!( - res.messages[2].msg, - CosmosMsg::Wasm(WasmMsg::Execute { - contract_addr: MOCK_CONTRACT_ADDR.to_string(), - msg: to_json_binary(&ExecuteMsg::TryBid { - auction_round: 1, - basket_value: Uint128::from(10_000u128), - }) - .unwrap(), - funds: vec![], - }) - ); - // checking attributes are fine assert_eq!( res.attributes, @@ -398,7 +383,6 @@ fn join_pool_fails() { let info = mock_info("robinho", &coins(100, "wrong_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let res = execute(deps.as_mut().branch(), env.clone(), info, msg.clone()).unwrap_err(); assert_eq!( @@ -422,7 +406,6 @@ fn join_pool_fails() { let info = mock_info("robinho", &coins(100, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 2, - basket_value: Uint128::from(10_000u128), }; let res = execute(deps.as_mut().branch(), env.clone(), info, msg.clone()).unwrap_err(); assert_eq!( @@ -441,7 +424,6 @@ fn exit_pool_works() { let info = mock_info("robinho", &coins(100, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let _ = execute(deps.as_mut().branch(), env.clone(), info, msg).unwrap(); @@ -482,7 +464,6 @@ fn exit_pool_fails() { let info = mock_info("robinho", &coins(100, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let _ = execute(deps.as_mut().branch(), env.clone(), info.clone(), msg).unwrap(); @@ -554,7 +535,6 @@ fn try_bid_works() { let info = mock_info("robinho", &coins(30_000, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let _ = execute(deps.as_mut().branch(), env.clone(), info, msg).unwrap(); @@ -631,7 +611,6 @@ fn try_bid_fails() { let info = mock_info("robinho", &coins(30_000, "native_denom")); let msg = ExecuteMsg::JoinPool { auction_round: 1, - basket_value: Uint128::from(10_000u128), }; let _ = execute(deps.as_mut().branch(), env.clone(), info, msg).unwrap(); @@ -819,3 +798,20 @@ fn try_bid_fails() { // // funds should be released // assert!(!FUNDS_LOCKED.load(deps.as_ref().storage).unwrap()); // } + +#[test] +fn testing_math() { + let minimum_allowed_bid = 7_212_340_000_000_000_000_000_u128 + .to_string() + .parse::() + .unwrap() + .checked_mul( + Decimal256::one().checked_add(Decimal256::from_str("0.0005").unwrap()).unwrap(), + ) + .unwrap() + .to_uint_ceil() + .checked_add(Uint256::one()) + .unwrap(); + + println!("{:?}", minimum_allowed_bid); +} diff --git a/deploy/02-testnet-auction.txt b/deploy/02-testnet-auction.txt index dc64034..083d5be 100644 --- a/deploy/02-testnet-auction.txt +++ b/deploy/02-testnet-auction.txt @@ -14,13 +14,15 @@ export FROM=auction-test export FROM_ADDR=inj12nn88vtuf893cpfkke23dszpr5uccqj2zqukt6 export TREASURE=8127 +just optimize + injectived tx wasm store ./artifacts/injective_auction_pool.wasm --from ${FROM} --yes --gas-prices "160000000inj" --gas-adjustment 1.3 --gas auto -tx=BF46482DC0C034F186BC554E64A46B01A19F7D5E02DE16389E5AD76F355FA35C +tx=95376ED78346B509E2226649CC1BEBDBFC827E1E4DDB4ADA8D279DD9D0858E14 export AUCTION=$(injectived query tx ${tx} |jq -e -r ' .events[] | select(.type=="cosmwasm.wasm.v1.EventCodeStored").attributes[] | select(.key=="code_id").value ' | tr -d '"') echo $AUCTION -export AUCTION=11699 +export AUCTION=11745 ## create the test denom export FEE_AMT=$(injectived query tokenfactory params|jq -r '.params.denom_creation_fee[0].amount') @@ -37,16 +39,29 @@ injectived tx wasm instantiate $AUCTION ${INIT_MSG} \ --amount ${FEE_AMT}inj \ --from $FROM --yes --gas-prices "160000000inj" --gas-adjustment 1.3 --gas auto -^^ following is failing -#tx_auction=A175DE3FF1F399E79B5BD616046C54BAE9CA5AAACE67A9E453C71189014FE145 -tx_auction=8E651410ACF16145CCB10F99F6C4B9989E3068665DA5C07564A4616E34D84F50 +tx_auction=576DE92111628B290A9E174C31F742B7D5CFB21160A8ECED2320749DCF590BF7 export AUCTION_CONTRACT=$(injectived query tx $tx_auction|jq -r '.events[]| select(.type=="cosmwasm.wasm.v1.EventContractInstantiated").attributes[] |select(.key=="contract_address").value '|tr -d '"') echo $AUCTION_CONTRACT -#export AUCTION_CONTRACT=inj1r467s95lrzf005pw4x6grzhhtnmw9lx93lcpek +# export AUCTION_CONTRACT=inj1r467s95lrzf005pw4x6grzhhtnmw9lx93lcpek # export AUCTION_CONTRACT=inj1s9dzsqrrq09z46ye7ffa9fldg3dt0e2cvx6yla +# export AUCTION_CONTRACT=inj1ghtvh6juxudspvrh9tdlz0p4d4u6k8xxd6jkgx +# export AUCTION_CONTRACT=inj1kar690fes35rm0dx5zcjwt5pjhtvcf572w3ffe -injectived query wasm cs smart $AUCTION_CONTRACT '{"query_current_auction_basket":{}}' +injectived query wasm cs smart $AUCTION_CONTRACT '{"current_auction_basket":{}}' injectived query wasm cs smart $AUCTION_CONTRACT '{"whitelisted_addresses":{}}' injectived query wasm cs smart $AUCTION_CONTRACT '{"funds_locked":{}}' -injectived query wasm cs smart $AUCTION_CONTRACT '{"bidding_balance":{}}' \ No newline at end of file +injectived query wasm cs smart $AUCTION_CONTRACT '{"bidding_balance":{}}' + +# add address to whitelist +injectived tx wasm execute $AUCTION_CONTRACT '{"update_white_listed_addresses":{"add":["inj12nn88vtuf893cpfkke23dszpr5uccqj2zqukt6"], "remove":[]}}' --from inj1cdugmt5t0mgfsmfc99eyhe4fzps0937ae0jgqh --yes --gas-prices "160000000inj" --gas-adjustment 1.3 --gas auto --node https://testnet.sentry.tm.injective.network:443 --output json --chain-id injective-888 | jq + +# join pool with 1inj +injectived tx wasm execute $AUCTION_CONTRACT '{"join_pool":{"auction_round":108, "basket_value":"1000"}}' \ + --from inj1cdugmt5t0mgfsmfc99eyhe4fzps0937ae0jgqh --yes --gas-prices "160000000inj" --gas-adjustment 1.3 --gas auto \ + --node https://testnet.sentry.tm.injective.network:443 --output json --chain-id injective-888 --amount 1000000000000000000inj | jq + +# try bid +injectived tx wasm execute $AUCTION_CONTRACT '{"try_bid":{"auction_round":108, "basket_value":"1000"}}' \ + --from inj1cdugmt5t0mgfsmfc99eyhe4fzps0937ae0jgqh --yes --gas-prices "160000000inj" --gas-adjustment 1.3 --gas auto \ + --node https://testnet.sentry.tm.injective.network:443 --output json --chain-id injective-888 | jq \ No newline at end of file diff --git a/packages/injective_auction/src/auction_pool.rs b/packages/injective_auction/src/auction_pool.rs index f52f4c9..681e4cb 100644 --- a/packages/injective_auction/src/auction_pool.rs +++ b/packages/injective_auction/src/auction_pool.rs @@ -49,8 +49,6 @@ pub enum ExecuteMsg { JoinPool { /// The auction round to join auction_round: u64, - /// The value in native denom of all assets being auctioned - basket_value: Uint128, }, /// Can be called by the user before T-1 day from auction's end to exit the auction. ExitPool {},