use solana_program::{
account_info::AccountInfo, program_error::ProgramError, program_pack::Pack, pubkey::Pubkey,
system_program, sysvar,
};
use spl_token::state::Mint;
use crate::{
state::{Bus, Proof, Treasury},
utils::AccountDeserialize,
BUS_ADDRESSES, BUS_COUNT, MINT_ADDRESS, TREASURY_ADDRESS,
};
pub fn load_signer<'a, 'info>(info: &'a AccountInfo<'info>) -> Result<(), ProgramError> {
if !info.is_signer {
return Err(ProgramError::MissingRequiredSignature);
}
Ok(())
}
pub fn load_bus<'a, 'info>(
info: &'a AccountInfo<'info>,
id: u64,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&crate::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.key.ne(&BUS_ADDRESSES[id as usize]) {
return Err(ProgramError::InvalidSeeds);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let bus_data = info.data.borrow();
let bus = Bus::try_from_bytes(&bus_data)?;
if bus.id.ne(&id) {
return Err(ProgramError::InvalidAccountData);
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_any_bus<'a, 'info>(
info: &'a AccountInfo<'info>,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&crate::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let bus_data = info.data.borrow();
let bus = Bus::try_from_bytes(&bus_data)?;
if bus.id.ge(&(BUS_COUNT as u64)) {
return Err(ProgramError::InvalidAccountData);
}
if info.key.ne(&BUS_ADDRESSES[bus.id as usize]) {
return Err(ProgramError::InvalidSeeds);
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_proof<'a, 'info>(
info: &'a AccountInfo<'info>,
authority: &Pubkey,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&crate::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let proof_data = info.data.borrow();
let proof = Proof::try_from_bytes(&proof_data)?;
if proof.authority.ne(&authority) {
return Err(ProgramError::InvalidAccountData);
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_treasury<'a, 'info>(
info: &'a AccountInfo<'info>,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&crate::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.key.ne(&TREASURY_ADDRESS) {
return Err(ProgramError::InvalidSeeds);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let treasury_data = info.data.borrow();
let _ = Treasury::try_from_bytes(&treasury_data)?;
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_mint<'a, 'info>(
info: &'a AccountInfo<'info>,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&spl_token::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.key.ne(&MINT_ADDRESS) {
return Err(ProgramError::InvalidSeeds);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let mint_data = info.data.borrow();
if Mint::unpack_unchecked(&mint_data).is_err() {
return Err(ProgramError::InvalidAccountData);
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_token_account<'a, 'info>(
info: &'a AccountInfo<'info>,
owner: Option<&Pubkey>,
mint: &Pubkey,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.owner.ne(&spl_token::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if info.data_is_empty() {
return Err(ProgramError::UninitializedAccount);
}
let account_data = info.data.borrow();
let account = spl_token::state::Account::unpack_unchecked(&account_data)
.or(Err(ProgramError::InvalidAccountData))?;
if account.mint.ne(&mint) {
return Err(ProgramError::InvalidAccountData);
}
if let Some(owner) = owner {
if account.owner.ne(owner) {
return Err(ProgramError::InvalidAccountData);
}
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_uninitialized_pda<'a, 'info>(
info: &'a AccountInfo<'info>,
seeds: &[&[u8]],
bump: u8,
program_id: &Pubkey,
) -> Result<(), ProgramError> {
let pda = Pubkey::find_program_address(seeds, program_id);
if info.key.ne(&pda.0) {
return Err(ProgramError::InvalidSeeds);
}
if bump.ne(&pda.1) {
return Err(ProgramError::InvalidSeeds);
}
load_uninitialized_account(info)
}
pub fn load_uninitialized_account<'a, 'info>(
info: &'a AccountInfo<'info>,
) -> Result<(), ProgramError> {
if info.owner.ne(&system_program::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
if !info.data_is_empty() {
return Err(ProgramError::AccountAlreadyInitialized);
}
if !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_sysvar<'a, 'info>(
info: &'a AccountInfo<'info>,
key: Pubkey,
) -> Result<(), ProgramError> {
if info.owner.ne(&sysvar::id()) {
return Err(ProgramError::InvalidAccountOwner);
}
load_account(info, key, false)
}
pub fn load_account<'a, 'info>(
info: &'a AccountInfo<'info>,
key: Pubkey,
is_writable: bool,
) -> Result<(), ProgramError> {
if info.key.ne(&key) {
return Err(ProgramError::InvalidAccountData);
}
if is_writable && !info.is_writable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
pub fn load_program<'a, 'info>(
info: &'a AccountInfo<'info>,
key: Pubkey,
) -> Result<(), ProgramError> {
if info.key.ne(&key) {
return Err(ProgramError::IncorrectProgramId);
}
if !info.executable {
return Err(ProgramError::InvalidAccountData);
}
Ok(())
}
#[cfg(test)]
mod tests {
use solana_program::{
account_info::AccountInfo, keccak::Hash as KeccakHash, program_option::COption,
program_pack::Pack, pubkey::Pubkey, system_program,
};
use spl_token::state::{AccountState, Mint};
use crate::{
loaders::{
load_account, load_any_bus, load_bus, load_mint, load_proof, load_signer, load_sysvar,
load_token_account, load_treasury, load_uninitialized_account, load_uninitialized_pda,
},
state::{Bus, Proof, Treasury},
utils::Discriminator,
BUS, BUS_ADDRESSES, BUS_COUNT, MINT_ADDRESS, PROOF, TOKEN_DECIMALS, TREASURY,
TREASURY_ADDRESS,
};
use super::load_program;
#[test]
pub fn test_signer_not_signer() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_signer(&info).is_err());
}
#[test]
pub fn test_load_bus_bad_account_owner() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_bus_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_bus_empty_data() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_bus_bad_data() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Treasury::discriminator() as u64).to_le_bytes(), Bus { id: 0, rewards: 0 }.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_bus_bad_id() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(), Bus { id: 1, rewards: 0 }.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_bus_not_writeable() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(),
Bus { id: 0, rewards: 0 }.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_bus(&info, 0, true).is_err());
}
#[test]
pub fn test_load_any_bus_bad_account_owner() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_empty_data() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_bad_data() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Treasury::discriminator() as u64).to_le_bytes(), Bus { id: 0, rewards: 0 }.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_bad_id() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(),
Bus {
id: (BUS_COUNT + 1) as u64,
rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_mismatch_id() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(),
Bus {
id: 1 as u64,
rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_any_bus_not_writeable() {
let key = BUS_ADDRESSES[0];
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(),
Bus { id: 0, rewards: 0 }.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_any_bus(&info, true).is_err());
}
#[test]
pub fn test_load_proof_bad_account_owner() {
let authority = Pubkey::new_unique();
let pda = Pubkey::find_program_address(&[PROOF, authority.as_ref()], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_proof(&info, &authority, true).is_err());
}
#[test]
pub fn test_load_proof_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_proof(&info, &Pubkey::new_unique(), true).is_err());
}
#[test]
pub fn test_load_proof_empty_data() {
let authority = Pubkey::new_unique();
let pda = Pubkey::find_program_address(&[PROOF, authority.as_ref()], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_proof(&info, &authority, true).is_err());
}
#[test]
pub fn test_load_proof_bad_data() {
let authority = Pubkey::new_unique();
let pda = Pubkey::find_program_address(&[PROOF, authority.as_ref()], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(), Proof {
authority,
claimable_rewards: 0,
hash: KeccakHash::new_from_array([u8::MAX; 32]).into(),
total_hashes: 0,
total_rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_proof(&info, &authority, true).is_err());
}
#[test]
pub fn test_load_proof_not_writeable() {
let authority = Pubkey::new_unique();
let pda = Pubkey::find_program_address(&[PROOF, authority.as_ref()], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [
&(Proof::discriminator() as u64).to_le_bytes(),
Proof {
authority,
claimable_rewards: 0,
hash: KeccakHash::new_from_array([u8::MAX; 32]).into(),
total_hashes: 0,
total_rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&pda.0,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_proof(&info, &authority, true).is_err());
}
#[test]
pub fn test_load_treasury_bad_account_owner() {
let pda = Pubkey::find_program_address(&[TREASURY], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_treasury(&info, true).is_err());
}
#[test]
pub fn test_load_treasury_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_treasury(&info, true).is_err());
}
#[test]
pub fn test_load_treasury_empty_data() {
let key = TREASURY_ADDRESS;
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = crate::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_treasury(&info, true).is_err());
}
#[test]
pub fn test_load_treasury_bad_data() {
let pda = Pubkey::find_program_address(&[TREASURY], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [
&(Bus::discriminator() as u64).to_le_bytes(), Treasury {
bump: pda.1 as u64,
admin: Pubkey::new_unique(),
difficulty: KeccakHash::new_from_array([u8::MAX; 32]).into(),
last_reset_at: 0,
reward_rate: 100,
total_claimed_rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_treasury(&info, true).is_err());
}
#[test]
pub fn test_load_treasury_not_writeable() {
let pda = Pubkey::find_program_address(&[TREASURY], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [
&(Treasury::discriminator() as u64).to_le_bytes(),
Treasury {
bump: pda.1 as u64,
admin: Pubkey::new_unique(),
difficulty: KeccakHash::new_from_array([u8::MAX; 32]).into(),
last_reset_at: 0,
reward_rate: 100,
total_claimed_rewards: 0,
}
.to_bytes(),
]
.concat();
let owner = crate::id();
let info = AccountInfo::new(
&pda.0,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_treasury(&info, true).is_err());
}
#[test]
pub fn test_load_mint_bad_account_owner() {
let key = MINT_ADDRESS;
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_token_account(&info, None, &MINT_ADDRESS, true).is_err());
}
#[test]
pub fn test_load_mint_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_mint(&info, true).is_err());
}
#[test]
pub fn test_load_mint_empty_data() {
let key = MINT_ADDRESS;
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_mint(&info, true).is_err());
}
#[test]
pub fn test_load_mint_bad_data() {
let key = MINT_ADDRESS;
let mut lamports = 1_000_000_000;
let mut data = [1];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_mint(&info, true).is_err());
}
#[test]
pub fn test_load_mint_not_writeable() {
let mut data: [u8; Mint::LEN] = [0; Mint::LEN];
Mint {
mint_authority: COption::Some(TREASURY_ADDRESS),
supply: 0,
decimals: TOKEN_DECIMALS,
is_initialized: true,
freeze_authority: COption::None,
}
.pack_into_slice(&mut data);
let key = MINT_ADDRESS;
let mut lamports = 1_000_000_000;
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_mint(&info, true).is_err());
}
#[test]
pub fn test_load_token_account_bad_account_owner() {
let mut data: [u8; spl_token::state::Account::LEN] = [0; spl_token::state::Account::LEN];
spl_token::state::Account {
mint: MINT_ADDRESS,
owner: TREASURY_ADDRESS,
amount: 2_000_000_000,
delegate: COption::None,
state: AccountState::Initialized,
is_native: COption::None,
delegated_amount: 0,
close_authority: COption::None,
}
.pack_into_slice(&mut data);
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_token_account(&info, None, &MINT_ADDRESS, true).is_err());
}
#[test]
pub fn test_load_token_account_empty_data() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_token_account(&info, None, &MINT_ADDRESS, true).is_err());
}
#[test]
pub fn test_load_token_account_bad_data() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [1];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_token_account(&info, None, &MINT_ADDRESS, true).is_err());
}
#[test]
pub fn test_load_token_account_bad_owner_mint() {
let mut data: [u8; spl_token::state::Account::LEN] = [0; spl_token::state::Account::LEN];
spl_token::state::Account {
mint: MINT_ADDRESS,
owner: TREASURY_ADDRESS,
amount: 2_000_000_000,
delegate: COption::None,
state: AccountState::Initialized,
is_native: COption::None,
delegated_amount: 0,
close_authority: COption::None,
}
.pack_into_slice(&mut data);
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_token_account(&info, Some(&key), &MINT_ADDRESS, false).is_err());
assert!(load_token_account(&info, None, &Pubkey::new_unique(), false).is_err());
assert!(load_token_account(&info, None, &MINT_ADDRESS, true).is_err());
}
#[test]
pub fn test_load_uninitialized_pda_bad_key_bump() {
let pda = Pubkey::find_program_address(&[TREASURY], &crate::id());
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&pda.0,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_uninitialized_pda(&info, &[BUS], pda.1, &crate::id()).is_err());
assert!(load_uninitialized_pda(&info, &[TREASURY], 0, &crate::id()).is_err());
}
#[test]
pub fn test_load_uninitialized_account_bad_owner() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = spl_token::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_uninitialized_account(&info).is_err());
}
#[test]
pub fn test_load_uninitialized_account_data_not_empty() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [0];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
true,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_uninitialized_account(&info).is_err());
}
#[test]
pub fn test_load_uninitialized_account_not_writeable() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_uninitialized_account(&info).is_err());
}
#[test]
pub fn test_load_sysvar_bad_owner() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_sysvar(&info, key).is_err());
}
#[test]
pub fn test_load_account_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_account(&info, Pubkey::new_unique(), false).is_err());
}
#[test]
pub fn test_load_account_not_writeable() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_account(&info, key, true).is_err());
}
#[test]
pub fn test_load_program_bad_key() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
true,
0,
);
assert!(load_program(&info, Pubkey::new_unique()).is_err());
}
#[test]
pub fn test_load_program_not_executable() {
let key = Pubkey::new_unique();
let mut lamports = 1_000_000_000;
let mut data = [];
let owner = system_program::id();
let info = AccountInfo::new(
&key,
false,
false,
&mut lamports,
&mut data,
&owner,
false,
0,
);
assert!(load_program(&info, key).is_err());
}
}