use cosmwasm_std::{coins, Coin, Timestamp, Uint128};
use cw_multi_test::Executor;
use open_edition_factory::state::ParamsExtension;
use sg_std::{GENESIS_MINT_START_TIME, NATIVE_DENOM};
use open_edition_minter::msg::ConfigResponse;
use open_edition_minter::msg::{ExecuteMsg, QueryMsg};
use crate::common_setup::setup_accounts_and_block::setup_block_time;
use crate::common_setup::setup_minter::common::constants::DEV_ADDRESS;
use crate::common_setup::setup_minter::open_edition_minter::minter_params::{
default_nft_data, init_msg,
};
use crate::common_setup::templates::open_edition_minter_custom_template;
const MINT_PRICE: u128 = 100_000_000;
#[test]
fn check_per_address_limit() {
let params_extension = ParamsExtension {
max_token_limit: 10_000,
max_per_address_limit: 10,
airdrop_mint_fee_bps: 100,
airdrop_mint_price: Coin {
denom: NATIVE_DENOM.to_string(),
amount: Uint128::new(100_000_000u128),
},
dev_fee_address: DEV_ADDRESS.to_string(),
};
let per_address_limit_minter = Some(2);
let init_msg = init_msg(
default_nft_data(),
per_address_limit_minter,
None,
Some(Timestamp::from_nanos(GENESIS_MINT_START_TIME + 10_000)),
None,
None,
None,
);
let vt = open_edition_minter_custom_template(params_extension, init_msg).unwrap();
let (mut router, creator, buyer) = (vt.router, vt.accts.creator, vt.accts.buyer);
let minter_addr = vt.collection_response_vec[0].minter.clone().unwrap();
setup_block_time(&mut router, GENESIS_MINT_START_TIME + 101, None);
let query_config_msg = QueryMsg::Config {};
let res: ConfigResponse = router
.wrap()
.query_wasm_smart(minter_addr.clone(), &query_config_msg)
.unwrap();
assert_eq!(res.per_address_limit, 2);
let per_address_limit_msg = ExecuteMsg::UpdatePerAddressLimit {
per_address_limit: 5,
};
let res = router.execute_contract(
buyer.clone(), minter_addr.clone(),
&per_address_limit_msg,
&[],
);
assert_eq!(
res.err().unwrap().source().unwrap().to_string(),
"Unauthorized: Sender is not an admin"
);
let per_address_limit_msg = ExecuteMsg::UpdatePerAddressLimit {
per_address_limit: 30,
};
let res = router.execute_contract(
creator.clone(),
minter_addr.clone(),
&per_address_limit_msg,
&[],
);
assert_eq!(
res.err().unwrap().source().unwrap().to_string(),
"Invalid minting limit per address. max: 10, min: 1, got: 30"
);
let per_address_limit_msg = ExecuteMsg::UpdatePerAddressLimit {
per_address_limit: 0,
};
let res = router.execute_contract(creator, minter_addr.clone(), &per_address_limit_msg, &[]);
assert_eq!(
res.err().unwrap().source().unwrap().to_string(),
"Invalid minting limit per address. max: 10, min: 1, got: 0"
);
for _ in 1..=2 {
let mint_msg = ExecuteMsg::Mint {};
let res = router.execute_contract(
buyer.clone(),
minter_addr.clone(),
&mint_msg,
&coins(MINT_PRICE, NATIVE_DENOM),
);
assert!(res.is_ok());
}
let mint_msg = ExecuteMsg::Mint {};
let res = router.execute_contract(
buyer,
minter_addr,
&mint_msg,
&coins(MINT_PRICE, NATIVE_DENOM),
);
assert_eq!(
res.err().unwrap().source().unwrap().to_string(),
"Max minting limit per address exceeded"
);
}