burn.rs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. mod setup;
  2. use {
  3. setup::{account, mint, TOKEN_PROGRAM_ID},
  4. solana_program_test::{tokio, ProgramTest},
  5. solana_sdk::{
  6. program_pack::Pack,
  7. pubkey::Pubkey,
  8. signature::{Keypair, Signer},
  9. transaction::Transaction,
  10. },
  11. };
  12. #[tokio::test]
  13. async fn burn() {
  14. let mut context = ProgramTest::new("pinocchio_token_program", TOKEN_PROGRAM_ID, None)
  15. .start_with_context()
  16. .await;
  17. // Given a mint account.
  18. let mint_authority = Keypair::new();
  19. let freeze_authority = Pubkey::new_unique();
  20. let mint = mint::initialize(
  21. &mut context,
  22. mint_authority.pubkey(),
  23. Some(freeze_authority),
  24. &TOKEN_PROGRAM_ID,
  25. )
  26. .await
  27. .unwrap();
  28. // And a token account with 100 tokens.
  29. let owner = Keypair::new();
  30. let account =
  31. account::initialize(&mut context, &mint, &owner.pubkey(), &TOKEN_PROGRAM_ID).await;
  32. mint::mint(
  33. &mut context,
  34. &mint,
  35. &account,
  36. &mint_authority,
  37. 100,
  38. &TOKEN_PROGRAM_ID,
  39. )
  40. .await
  41. .unwrap();
  42. // When we burn 50 tokens.
  43. let burn_ix =
  44. spl_token::instruction::burn(&spl_token::ID, &account, &mint, &owner.pubkey(), &[], 50)
  45. .unwrap();
  46. let tx = Transaction::new_signed_with_payer(
  47. &[burn_ix],
  48. Some(&context.payer.pubkey()),
  49. &[&context.payer, &owner],
  50. context.last_blockhash,
  51. );
  52. context.banks_client.process_transaction(tx).await.unwrap();
  53. // Then the account should have 50 tokens remaining.
  54. let account = context.banks_client.get_account(account).await.unwrap();
  55. assert!(account.is_some());
  56. let account = account.unwrap();
  57. let account = spl_token::state::Account::unpack(&account.data).unwrap();
  58. assert!(account.amount == 50);
  59. }