initialize_multisig2.rs 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #![cfg(feature = "test-sbf")]
  2. use solana_program_test::{tokio, ProgramTest};
  3. use solana_sdk::{
  4. program_pack::Pack,
  5. pubkey::Pubkey,
  6. signature::{Keypair, Signer},
  7. system_instruction,
  8. transaction::Transaction,
  9. };
  10. use spl_token::state::Multisig;
  11. #[test_case::test_case(spl_token::ID ; "spl-token")]
  12. #[test_case::test_case(Pubkey::new_from_array(token_program::ID) ; "p-token")]
  13. #[tokio::test]
  14. async fn initialize_multisig2(token_program: Pubkey) {
  15. let program_id = Pubkey::new_from_array(token_program::ID);
  16. let mut context = ProgramTest::new("token_program", program_id, None)
  17. .start_with_context()
  18. .await;
  19. // Given an account
  20. let multisig = Keypair::new();
  21. let signer1 = Pubkey::new_unique();
  22. let signer2 = Pubkey::new_unique();
  23. let signer3 = Pubkey::new_unique();
  24. let signers = vec![&signer1, &signer2, &signer3];
  25. let rent = context.banks_client.get_rent().await.unwrap();
  26. let mut initialize_ix = spl_token::instruction::initialize_multisig2(
  27. &spl_token::ID,
  28. &multisig.pubkey(),
  29. &signers,
  30. 2,
  31. )
  32. .unwrap();
  33. // Switches the program id to the token program.
  34. initialize_ix.program_id = token_program;
  35. // When a new multisig account is created and initialized.
  36. let instructions = vec![
  37. system_instruction::create_account(
  38. &context.payer.pubkey(),
  39. &multisig.pubkey(),
  40. rent.minimum_balance(Multisig::LEN),
  41. Multisig::LEN as u64,
  42. &token_program,
  43. ),
  44. initialize_ix,
  45. ];
  46. let tx = Transaction::new_signed_with_payer(
  47. &instructions,
  48. Some(&context.payer.pubkey()),
  49. &[&context.payer, &multisig],
  50. context.last_blockhash,
  51. );
  52. context.banks_client.process_transaction(tx).await.unwrap();
  53. // Then the multisig has the correct data.
  54. let account = context
  55. .banks_client
  56. .get_account(multisig.pubkey())
  57. .await
  58. .unwrap();
  59. assert!(account.is_some());
  60. let account = account.unwrap();
  61. let multisig = spl_token::state::Multisig::unpack(&account.data).unwrap();
  62. assert!(multisig.is_initialized);
  63. assert_eq!(multisig.n, 3);
  64. assert_eq!(multisig.m, 2);
  65. }