Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 7 additions & 9 deletions contracts/vault/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -377,6 +377,12 @@ impl CalloraVault {
.set(&StorageKey::DepositorList, &Vec::<Address>::new(&env));
}

fn require_authorized_deduct_caller(env: Env, caller: &Address) {
let meta = Self::get_meta(env.clone());
let owner = meta.owner.clone();
let auth = match meta.authorized_caller {
Some(ac) => *caller == ac || *caller == owner,
None => *caller == owner,
pub fn pause(env: Env, caller: Address) {
caller.require_auth();
Self::require_admin_or_owner(env.clone(), &caller);
Expand Down Expand Up @@ -761,6 +767,7 @@ impl CalloraVault {
assert!(auth, "unauthorized caller");
}

pub fn get_allowed_depositors(env: Env) -> Vec<Address> {
fn transfer_funds(env: &Env, usdc_token: &Address, to: &Address, amount: i128) {
token::Client::new(env, usdc_token).transfer(&env.current_contract_address(), to, &amount);
}
Expand Down Expand Up @@ -828,12 +835,3 @@ impl CalloraVault {
.unwrap_or(Vec::new(&env))
}
}

#[cfg(test)]
mod test;

#[cfg(test)]
mod test_init_hardening;

#[cfg(test)]
mod test_views;
132 changes: 132 additions & 0 deletions contracts/vault/src/test_setter_validation.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
extern crate std;
use soroban_sdk::testutils::Address as _;
use soroban_sdk::{token, Address, Env};
use super::*;
fn create_usdc(env: &Env, admin: &Address) -> (Address, token::StellarAssetClient) {
let ca = env.register_stellar_asset_contract_v2(admin.clone());
let addr = ca.address();
(addr.clone(), token::StellarAssetClient::new(env, &addr))
}
fn create_vault(env: &Env) -> (Address, CalloraVaultClient) {
let addr = env.register(CalloraVault, ());
(addr, CalloraVaultClient::new(env, &addr))
}
fn setup(env: &Env) -> (Address, CalloraVaultClient, Address, Address) {
env.mock_all_auths();
let admin = Address::generate(env);
let (vault_addr, client) = create_vault(env);
let (usdc, _) = create_usdc(env, &admin);
client.init(&admin, &usdc, &None, &None, &None, &None, &None);
(vault_addr, client, usdc, admin)
}
#[test]
#[should_panic(expected = "settlement cannot be vault address")]
fn set_settlement_vault_address_panics() {
let env = Env::default();
let (vault_addr, client, _, admin) = setup(&env);
client.set_settlement(&admin, &vault_addr);
}
#[test]
fn set_settlement_vault_address_try_returns_err() {
let env = Env::default();
let (vault_addr, client, _, admin) = setup(&env);
assert!(client.try_set_settlement(&admin, &vault_addr).is_err());
}
#[test]
#[should_panic(expected = "settlement cannot be usdc_token address")]
fn set_settlement_usdc_address_panics() {
let env = Env::default();
let (_, client, usdc, admin) = setup(&env);
client.set_settlement(&admin, &usdc);
}
#[test]
fn set_settlement_usdc_address_try_returns_err() {
let env = Env::default();
let (_, client, usdc, admin) = setup(&env);
assert!(client.try_set_settlement(&admin, &usdc).is_err());
}
#[test]
#[should_panic(expected = "settlement cannot equal revenue_pool address")]
fn set_settlement_equals_revenue_pool_panics() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let pool = Address::generate(&env);
client.set_revenue_pool(&admin, &Some(pool.clone()));
client.set_settlement(&admin, &pool);
}
#[test]
fn set_settlement_equals_revenue_pool_try_returns_err() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let pool = Address::generate(&env);
client.set_revenue_pool(&admin, &Some(pool.clone()));
assert!(client.try_set_settlement(&admin, &pool).is_err());
}
#[test]
fn set_settlement_valid_address_succeeds() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let s = Address::generate(&env);
client.set_settlement(&admin, &s);
assert_eq!(client.get_settlement(), s);
}
#[test]
#[should_panic(expected = "revenue_pool cannot be vault address")]
fn set_revenue_pool_vault_address_panics() {
let env = Env::default();
let (vault_addr, client, _, admin) = setup(&env);
client.set_revenue_pool(&admin, &Some(vault_addr));
}
#[test]
fn set_revenue_pool_vault_address_try_returns_err() {
let env = Env::default();
let (vault_addr, client, _, admin) = setup(&env);
assert!(client.try_set_revenue_pool(&admin, &Some(vault_addr)).is_err());
}
#[test]
#[should_panic(expected = "revenue_pool cannot be usdc_token address")]
fn set_revenue_pool_usdc_address_panics() {
let env = Env::default();
let (_, client, usdc, admin) = setup(&env);
client.set_revenue_pool(&admin, &Some(usdc));
}
#[test]
fn set_revenue_pool_usdc_address_try_returns_err() {
let env = Env::default();
let (_, client, usdc, admin) = setup(&env);
assert!(client.try_set_revenue_pool(&admin, &Some(usdc)).is_err());
}
#[test]
#[should_panic(expected = "revenue_pool cannot equal settlement address")]
fn set_revenue_pool_equals_settlement_panics() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let s = Address::generate(&env);
client.set_settlement(&admin, &s);
client.set_revenue_pool(&admin, &Some(s));
}
#[test]
fn set_revenue_pool_equals_settlement_try_returns_err() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let s = Address::generate(&env);
client.set_settlement(&admin, &s);
assert!(client.try_set_revenue_pool(&admin, &Some(s)).is_err());
}
#[test]
fn set_revenue_pool_valid_address_succeeds() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let pool = Address::generate(&env);
client.set_revenue_pool(&admin, &Some(pool.clone()));
assert_eq!(client.get_revenue_pool(), Some(pool));
}
#[test]
fn set_revenue_pool_none_clears_pool() {
let env = Env::default();
let (_, client, _, admin) = setup(&env);
let pool = Address::generate(&env);
client.set_revenue_pool(&admin, &Some(pool));
client.set_revenue_pool(&admin, &None);
assert_eq!(client.get_revenue_pool(), None);
}
1 change: 1 addition & 0 deletions contracts/vault/src/test_settler_validation.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
}