1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- 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);
- }
|