|
| 1 | +use std::char::REPLACEMENT_CHARACTER; |
| 2 | + |
| 3 | +use cosmwasm_std::{DepsMut, Env, MessageInfo, Response}; |
1 | 4 | use cosmwasm_std::{Addr, Decimal, StdError, StdResult, Storage, Uint128}; |
| 5 | +use crate::ContractError; |
2 | 6 | use schemars::JsonSchema; |
3 | 7 | use serde::{Deserialize, Serialize}; |
| 8 | +use crate::state::ANTI_WHALE_INFO; |
4 | 9 |
|
5 | 10 | use crate::state::TOKEN_INFO; |
6 | 11 |
|
@@ -54,9 +59,44 @@ impl WhaleInfo { |
54 | 59 | } |
55 | 60 | } |
56 | 61 |
|
| 62 | +pub fn execute_set_whale_info( |
| 63 | + deps: DepsMut, |
| 64 | + env: Env, info: MessageInfo, |
| 65 | + whale_info: WhaleInfo |
| 66 | +) -> Result<Response, ContractError> { |
| 67 | + let mut old_whale_info = ANTI_WHALE_INFO.load(deps.storage)?; |
| 68 | + whale_info.validate()?; |
| 69 | + if info.sender != old_whale_info.admin { |
| 70 | + return Err(ContractError::Unauthorized {}); |
| 71 | + } |
| 72 | + ANTI_WHALE_INFO.save(deps.storage, &whale_info)?; |
| 73 | + Ok(Response::new()) |
| 74 | +} |
| 75 | + |
| 76 | +pub fn execute_set_whale_admin( |
| 77 | + deps: DepsMut, |
| 78 | + env: Env, |
| 79 | + info: MessageInfo, |
| 80 | + admin: Addr |
| 81 | +) -> Result<Response, ContractError> { |
| 82 | + let mut old_info = ANTI_WHALE_INFO.load(deps.storage)?; |
| 83 | + if info.sender != old_info.admin { |
| 84 | + return Err(ContractError::Unauthorized{}); |
| 85 | + } |
| 86 | + old_info.admin = admin; |
| 87 | + ANTI_WHALE_INFO.save(deps.storage, &old_info)?; |
| 88 | + Ok(Response::new()) |
| 89 | +} |
| 90 | + |
57 | 91 | #[cfg(test)] |
58 | 92 | mod test { |
59 | | - use cosmwasm_std::{testing::MockStorage, Addr, Decimal, Uint128}; |
| 93 | + use std::ops::Add; |
| 94 | + |
| 95 | + use cosmwasm_std::{ |
| 96 | + testing::{mock_dependencies, mock_env, mock_info, MockStorage}, Addr, Decimal, Uint128 |
| 97 | + }; |
| 98 | + use crate::ContractError; |
| 99 | + use serde::de; |
60 | 100 |
|
61 | 101 | use crate::state::TokenInfo; |
62 | 102 |
|
@@ -132,4 +172,97 @@ mod test { |
132 | 172 | assert!(info.assert_no_whale(storage, &addr3, whale_amount).is_err()); |
133 | 173 | assert!(info.assert_no_whale(storage, &addr3, fish_amount).is_ok()); |
134 | 174 | } |
| 175 | + |
| 176 | + #[test] |
| 177 | + fn test_set_whale_info_works() { |
| 178 | + let mut deps = mock_dependencies(); |
| 179 | + let info = mock_info("admin", &[]); |
| 180 | + let expected_whale_info = super::WhaleInfo { |
| 181 | + threshold: Decimal::percent(10), |
| 182 | + whitelist: vec![Addr::unchecked("whale1"), Addr::unchecked("whale2")], |
| 183 | + admin: Addr::unchecked("admin"), |
| 184 | + }; |
| 185 | + |
| 186 | + // mock info being set by instantiation |
| 187 | + super::ANTI_WHALE_INFO.save(deps.as_mut().storage, &super::WhaleInfo { |
| 188 | + threshold: Decimal::one(), |
| 189 | + whitelist: vec![], |
| 190 | + admin: Addr::unchecked("admin"), |
| 191 | + }).unwrap(); |
| 192 | + |
| 193 | + super::execute_set_whale_info(deps.as_mut(), mock_env(), info, expected_whale_info).unwrap(); |
| 194 | + |
| 195 | + let new_info = super::ANTI_WHALE_INFO.load(deps.as_ref().storage).unwrap(); |
| 196 | + assert_eq!(new_info, new_info); |
| 197 | + |
| 198 | + } |
| 199 | + |
| 200 | + #[test] |
| 201 | + fn test_set_whale_info_rejects_no_admin() { |
| 202 | + let mut deps = mock_dependencies(); |
| 203 | + let info = mock_info("no_admin", &[]); |
| 204 | + let expected_whale_info = super::WhaleInfo { |
| 205 | + threshold: Decimal::percent(10), |
| 206 | + whitelist: vec![Addr::unchecked("whale1"), Addr::unchecked("whale2")], |
| 207 | + admin: Addr::unchecked("admin"), |
| 208 | + }; |
| 209 | + |
| 210 | + // mock info being set by instantiation |
| 211 | + super::ANTI_WHALE_INFO.save(deps.as_mut().storage, &super::WhaleInfo { |
| 212 | + threshold: Decimal::one(), |
| 213 | + whitelist: vec![], |
| 214 | + admin: Addr::unchecked("admin"), |
| 215 | + }).unwrap(); |
| 216 | + |
| 217 | + let err = super::execute_set_whale_info(deps.as_mut(), mock_env(), info, expected_whale_info); |
| 218 | + match err { |
| 219 | + Ok(_) => { panic!("expected failrue"); }, |
| 220 | + Err(e) => { |
| 221 | + assert_eq!( e, ContractError::Unauthorized { } ) |
| 222 | + } |
| 223 | + } |
| 224 | + |
| 225 | + } |
| 226 | + |
| 227 | + #[test] |
| 228 | + fn test_set_whale_admin() { |
| 229 | + let mut deps = mock_dependencies(); |
| 230 | + let info = mock_info("admin", &[]); |
| 231 | + let old_whale_info = super::WhaleInfo { |
| 232 | + threshold: Decimal::percent(10), |
| 233 | + whitelist: vec![Addr::unchecked("whale1"), Addr::unchecked("whale2")], |
| 234 | + admin: Addr::unchecked("admin"), |
| 235 | + }; |
| 236 | + let mut expected_whale_info = old_whale_info.clone(); |
| 237 | + expected_whale_info.admin = Addr::unchecked("admin2"); |
| 238 | + |
| 239 | + // mock info being set by instantiation |
| 240 | + super::ANTI_WHALE_INFO.save(deps.as_mut().storage, &old_whale_info).unwrap(); |
| 241 | + |
| 242 | + super::execute_set_whale_admin(deps.as_mut(), mock_env(), info, Addr::unchecked("admin2")).unwrap(); |
| 243 | + |
| 244 | + let new_info = super::ANTI_WHALE_INFO.load(deps.as_mut().storage).unwrap(); |
| 245 | + assert_eq!(new_info, expected_whale_info) |
| 246 | + } |
| 247 | + |
| 248 | + #[test] |
| 249 | + fn test_set_whale_admin_unauthorized() { |
| 250 | + let mut deps = mock_dependencies(); |
| 251 | + let info = mock_info("no_admin", &[]); |
| 252 | + let old_whale_info = super::WhaleInfo { |
| 253 | + threshold: Decimal::percent(10), |
| 254 | + whitelist: vec![Addr::unchecked("whale1"), Addr::unchecked("whale2")], |
| 255 | + admin: Addr::unchecked("admin"), |
| 256 | + }; |
| 257 | + |
| 258 | + // mock info being set by instantiation |
| 259 | + super::ANTI_WHALE_INFO.save(deps.as_mut().storage, &old_whale_info).unwrap(); |
| 260 | + |
| 261 | + let res = super::execute_set_whale_admin(deps.as_mut(), mock_env(), info, Addr::unchecked("admin2")); |
| 262 | + match res { |
| 263 | + Ok(_) => {panic!("unexpected success of setting admin!")}, |
| 264 | + Err(e) => {assert_eq!(e, ContractError::Unauthorized { })} |
| 265 | + } |
| 266 | + |
| 267 | + } |
135 | 268 | } |
0 commit comments