test.rs 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. use litesvm::LiteSVM;
  2. use processing_instructions_program::InstructionData;
  3. use solana_instruction::{AccountMeta, Instruction};
  4. use solana_keypair::{Keypair, Signer};
  5. use solana_native_token::LAMPORTS_PER_SOL;
  6. use solana_pubkey::Pubkey;
  7. use solana_transaction::Transaction;
  8. #[test]
  9. fn test_processing_ixs() {
  10. let mut svm = LiteSVM::new();
  11. let program_id = Pubkey::new_unique();
  12. let program_bytes = include_bytes!("../../tests/fixtures/processing_instructions_program.so");
  13. svm.add_program(program_id, program_bytes).unwrap();
  14. let payer = Keypair::new();
  15. svm.airdrop(&payer.pubkey(), LAMPORTS_PER_SOL * 10).unwrap();
  16. let jimmy = InstructionData {
  17. name: "Jimmy".to_string(),
  18. height: 3,
  19. };
  20. let mary = InstructionData {
  21. name: "Mary".to_string(),
  22. height: 3,
  23. };
  24. let ix1 = Instruction {
  25. program_id,
  26. accounts: vec![AccountMeta::new(payer.pubkey(), true)],
  27. data: borsh::to_vec(&jimmy).unwrap(),
  28. };
  29. let ix2 = Instruction {
  30. program_id,
  31. accounts: vec![AccountMeta::new(payer.pubkey(), true)],
  32. data: borsh::to_vec(&mary).unwrap(),
  33. };
  34. let tx = Transaction::new_signed_with_payer(
  35. &[ix1, ix2],
  36. Some(&payer.pubkey()),
  37. &[&payer],
  38. svm.latest_blockhash(),
  39. );
  40. assert!(svm.send_transaction(tx).is_ok());
  41. }