2022-03-17 06:17:28 -07:00
|
|
|
#![cfg(feature = "test-bpf")]
|
|
|
|
|
|
|
|
use solana_program_test::*;
|
2022-05-18 08:16:14 -07:00
|
|
|
use solana_sdk::{signature::Keypair, transport::TransportError};
|
2022-03-17 06:17:28 -07:00
|
|
|
|
|
|
|
use program_test::*;
|
|
|
|
|
|
|
|
mod program_test;
|
|
|
|
|
|
|
|
// Try to reach compute limits in health checks by having many different tokens in an account
|
|
|
|
#[tokio::test]
|
2022-05-18 08:16:14 -07:00
|
|
|
async fn test_health_compute_tokens() -> Result<(), TransportError> {
|
2022-03-21 02:45:55 -07:00
|
|
|
let context = TestContext::new().await;
|
2022-03-17 06:17:28 -07:00
|
|
|
let solana = &context.solana.clone();
|
|
|
|
|
|
|
|
let admin = &Keypair::new();
|
|
|
|
let owner = &context.users[0].key;
|
|
|
|
let payer = &context.users[1].key;
|
|
|
|
let mints = &context.mints[0..10];
|
|
|
|
let payer_mint_accounts = &context.users[1].token_accounts[0..mints.len()];
|
|
|
|
|
|
|
|
//
|
|
|
|
// SETUP: Create a group and an account
|
|
|
|
//
|
|
|
|
|
2022-03-20 23:49:51 -07:00
|
|
|
let mango_setup::GroupWithTokens { group, .. } = mango_setup::GroupWithTokensConfig {
|
|
|
|
admin,
|
|
|
|
payer,
|
|
|
|
mints,
|
|
|
|
}
|
|
|
|
.create(solana)
|
|
|
|
.await;
|
2022-03-17 06:17:28 -07:00
|
|
|
|
|
|
|
let account = send_tx(
|
|
|
|
solana,
|
|
|
|
CreateAccountInstruction {
|
|
|
|
account_num: 0,
|
|
|
|
group,
|
|
|
|
owner,
|
|
|
|
payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap()
|
|
|
|
.account;
|
|
|
|
|
|
|
|
//
|
|
|
|
// TEST: Deposit user funds for all the mints
|
|
|
|
// each deposit will end with a health check
|
|
|
|
//
|
|
|
|
for &token_account in payer_mint_accounts {
|
|
|
|
let deposit_amount = 1000;
|
|
|
|
|
|
|
|
send_tx(
|
|
|
|
solana,
|
|
|
|
DepositInstruction {
|
|
|
|
amount: deposit_amount,
|
|
|
|
account,
|
|
|
|
token_account,
|
|
|
|
token_authority: payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: actual explicit CU comparisons.
|
2022-03-29 00:12:10 -07:00
|
|
|
// On 2022-3-29 the final deposit costs 43900 CU and each new token increases it by roughly 1800 CU
|
2022-03-17 06:17:28 -07:00
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Try to reach compute limits in health checks by having many serum markets in an account
|
|
|
|
#[tokio::test]
|
2022-05-18 08:16:14 -07:00
|
|
|
async fn test_health_compute_serum() -> Result<(), TransportError> {
|
2022-03-21 02:45:55 -07:00
|
|
|
let context = TestContext::new().await;
|
2022-03-17 06:17:28 -07:00
|
|
|
let solana = &context.solana.clone();
|
|
|
|
|
|
|
|
let admin = &Keypair::new();
|
|
|
|
let owner = &context.users[0].key;
|
|
|
|
let payer = &context.users[1].key;
|
|
|
|
let mints = &context.mints[0..8];
|
|
|
|
let payer_mint_accounts = &context.users[1].token_accounts[0..mints.len()];
|
|
|
|
|
|
|
|
//
|
|
|
|
// SETUP: Create a group and an account
|
|
|
|
//
|
|
|
|
|
2022-03-30 03:24:07 -07:00
|
|
|
let mango_setup::GroupWithTokens { group, tokens } = mango_setup::GroupWithTokensConfig {
|
2022-03-20 23:49:51 -07:00
|
|
|
admin,
|
|
|
|
payer,
|
|
|
|
mints,
|
|
|
|
}
|
|
|
|
.create(solana)
|
|
|
|
.await;
|
2022-03-17 06:17:28 -07:00
|
|
|
|
|
|
|
let account = send_tx(
|
|
|
|
solana,
|
|
|
|
CreateAccountInstruction {
|
|
|
|
account_num: 0,
|
|
|
|
group,
|
|
|
|
owner,
|
|
|
|
payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap()
|
|
|
|
.account;
|
|
|
|
|
|
|
|
//
|
|
|
|
// SETUP: Create serum markets and register them
|
|
|
|
//
|
2022-03-30 03:24:07 -07:00
|
|
|
let quote_token = &tokens[0];
|
2022-03-17 06:17:28 -07:00
|
|
|
let mut serum_market_cookies = vec![];
|
2022-03-30 03:24:07 -07:00
|
|
|
for token in tokens[1..].iter() {
|
|
|
|
serum_market_cookies.push((
|
|
|
|
token,
|
|
|
|
context
|
|
|
|
.serum
|
|
|
|
.list_spot_market(&token.mint, "e_token.mint)
|
|
|
|
.await,
|
|
|
|
));
|
2022-03-17 06:17:28 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
let mut serum_markets = vec![];
|
2022-03-30 03:24:07 -07:00
|
|
|
for (base_token, spot) in serum_market_cookies {
|
2022-03-17 06:17:28 -07:00
|
|
|
serum_markets.push(
|
|
|
|
send_tx(
|
|
|
|
solana,
|
2022-03-18 05:42:20 -07:00
|
|
|
Serum3RegisterMarketInstruction {
|
2022-03-17 06:17:28 -07:00
|
|
|
group,
|
|
|
|
admin,
|
|
|
|
serum_program: context.serum.program_id,
|
2022-03-30 03:24:07 -07:00
|
|
|
serum_market_external: spot.market,
|
|
|
|
market_index: spot.coin_mint.index as u16,
|
|
|
|
base_bank: base_token.bank,
|
|
|
|
quote_bank: quote_token.bank,
|
2022-03-17 06:17:28 -07:00
|
|
|
payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap()
|
|
|
|
.serum_market,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// TEST: Create open orders and trigger a Deposit to check health
|
|
|
|
//
|
|
|
|
for (i, &serum_market) in serum_markets.iter().enumerate() {
|
|
|
|
println!("adding market {}", i);
|
|
|
|
send_tx(
|
|
|
|
solana,
|
2022-03-18 05:42:20 -07:00
|
|
|
Serum3CreateOpenOrdersInstruction {
|
2022-03-17 06:17:28 -07:00
|
|
|
account,
|
|
|
|
serum_market,
|
|
|
|
owner,
|
|
|
|
payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
send_tx(
|
|
|
|
solana,
|
|
|
|
DepositInstruction {
|
|
|
|
amount: 10,
|
|
|
|
account,
|
|
|
|
token_account: payer_mint_accounts[i],
|
|
|
|
token_authority: payer,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: actual explicit CU comparisons.
|
2022-03-29 00:12:10 -07:00
|
|
|
// On 2022-3-29 the final deposit costs 60380 CU and each new market increases it by roughly 5000 CU
|
2022-03-17 06:17:28 -07:00
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|