mod setup; use { setup::{account, mint, TOKEN_PROGRAM_ID}, solana_keypair::Keypair, solana_program_pack::Pack, solana_program_test::{tokio, ProgramTest}, solana_signer::Signer, solana_transaction::Transaction, spl_token_interface::state::AccountState, }; #[tokio::test] async fn freeze_account() { let mut context = ProgramTest::new("pinocchio_token_program", TOKEN_PROGRAM_ID, None) .start_with_context() .await; // Given a mint account. let mint_authority = Keypair::new(); let freeze_authority = Keypair::new(); let mint = mint::initialize( &mut context, mint_authority.pubkey(), Some(freeze_authority.pubkey()), &TOKEN_PROGRAM_ID, ) .await .unwrap(); // And a token account. let owner = Keypair::new(); let account = account::initialize(&mut context, &mint, &owner.pubkey(), &TOKEN_PROGRAM_ID).await; let token_account = context.banks_client.get_account(account).await.unwrap(); assert!(token_account.is_some()); // When we freeze the account. let freeze_account_ix = spl_token_interface::instruction::freeze_account( &spl_token_interface::ID, &account, &mint, &freeze_authority.pubkey(), &[], ) .unwrap(); let tx = Transaction::new_signed_with_payer( &[freeze_account_ix], Some(&context.payer.pubkey()), &[&context.payer, &freeze_authority], context.last_blockhash, ); context.banks_client.process_transaction(tx).await.unwrap(); // Then the account is frozen. let token_account = context.banks_client.get_account(account).await.unwrap(); assert!(token_account.is_some()); let token_account = token_account.unwrap(); let token_account = spl_token_interface::state::Account::unpack(&token_account.data).unwrap(); assert_eq!(token_account.state, AccountState::Frozen); }