diff --git a/Cargo.lock b/Cargo.lock index 1275e977e..41968466a 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2165,7 +2165,13 @@ version = "0.1.0" dependencies = [ "borsh 1.5.7", "borsh-derive 1.5.7", + "litesvm", + "solana-instruction 3.0.0", + "solana-keypair", + "solana-native-token 3.0.0", "solana-program 3.0.0", + "solana-pubkey 3.0.0", + "solana-transaction", ] [[package]] diff --git a/basics/processing-instructions/native/program/Cargo.toml b/basics/processing-instructions/native/program/Cargo.toml index 3633bda56..2855d519d 100644 --- a/basics/processing-instructions/native/program/Cargo.toml +++ b/basics/processing-instructions/native/program/Cargo.toml @@ -12,9 +12,16 @@ solana-program.workspace = true crate-type = ["cdylib", "lib"] [features] -anchor-debug = [] custom-heap = [] custom-panic = [] [lints.rust] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(target_os, values("solana"))'] } + +[dev-dependencies] +litesvm = "0.8.1" +solana-instruction = "3.0.0" +solana-keypair = "3.0.1" +solana-pubkey = "3.0.0" +solana-transaction = "3.0.1" +solana-native-token = "3.0.0" diff --git a/basics/processing-instructions/native/program/src/lib.rs b/basics/processing-instructions/native/program/src/lib.rs index def4dcce2..76ebcd0b1 100644 --- a/basics/processing-instructions/native/program/src/lib.rs +++ b/basics/processing-instructions/native/program/src/lib.rs @@ -27,6 +27,6 @@ fn process_instruction( #[derive(BorshSerialize, BorshDeserialize, Debug)] pub struct InstructionData { - name: String, - height: u32, + pub name: String, + pub height: u32, } diff --git a/basics/processing-instructions/native/program/tests/test.rs b/basics/processing-instructions/native/program/tests/test.rs new file mode 100644 index 000000000..1b1e97e53 --- /dev/null +++ b/basics/processing-instructions/native/program/tests/test.rs @@ -0,0 +1,52 @@ +use litesvm::LiteSVM; +use processing_instructions_program::InstructionData; +use solana_instruction::{AccountMeta, Instruction}; +use solana_keypair::{Keypair, Signer}; +use solana_native_token::LAMPORTS_PER_SOL; +use solana_pubkey::Pubkey; +use solana_transaction::Transaction; + +#[test] +fn test_processing_ixs() { + let mut svm = LiteSVM::new(); + + let program_id = Pubkey::new_unique(); + let program_bytes = + include_bytes!("../../../../../target/deploy/processing_instructions_program.so"); + + svm.add_program(program_id, program_bytes).unwrap(); + + let payer = Keypair::new(); + svm.airdrop(&payer.pubkey(), LAMPORTS_PER_SOL * 10).unwrap(); + + let jimmy = InstructionData { + name: "Jimmy".to_string(), + height: 3, + }; + + let mary = InstructionData { + name: "Mary".to_string(), + height: 3, + }; + + let ix1 = Instruction { + program_id, + accounts: vec![AccountMeta::new(payer.pubkey(), true)], + data: borsh::to_vec(&jimmy).unwrap(), + }; + + let ix2 = Instruction { + program_id, + accounts: vec![AccountMeta::new(payer.pubkey(), true)], + data: borsh::to_vec(&mary).unwrap(), + }; + + let tx = Transaction::new_signed_with_payer( + &[ix1, ix2], + Some(&payer.pubkey()), + &[&payer], + svm.latest_blockhash(), + ); + + let _ = svm.send_transaction(tx).is_ok(); +}