initialize_multisig2.rs 2.1 KB

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