From 30854ee9692f9f4fee2b02c3952cfeb24ae8bd74 Mon Sep 17 00:00:00 2001 From: Perelyn <64838956+Perelyn-sama@users.noreply.github.com> Date: Sun, 2 Nov 2025 13:29:07 +0100 Subject: [PATCH] add rust test for pda rent payer --- Cargo.lock | 6 ++ Cargo.toml | 8 +++ .../pda-rent-payer/native/program/Cargo.toml | 9 ++- .../src/instructions/init_rent_vault.rs | 2 +- .../native/program/tests/test.rs | 70 +++++++++++++++++++ 5 files changed, 93 insertions(+), 2 deletions(-) create mode 100644 basics/pda-rent-payer/native/program/tests/test.rs diff --git a/Cargo.lock b/Cargo.lock index 1275e977..c1bbfa49 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2043,8 +2043,14 @@ 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-system-interface 2.0.0", + "solana-transaction", ] [[package]] diff --git a/Cargo.toml b/Cargo.toml index 7de307bb..ad05f929 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -67,3 +67,11 @@ spl-token-2022-interface = "2.0.0" # pinocchio pinocchio = "=0.8.1" pinocchio-log = "0.4.0" + +# testing +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/pda-rent-payer/native/program/Cargo.toml b/basics/pda-rent-payer/native/program/Cargo.toml index bd7efa7b..909e0046 100644 --- a/basics/pda-rent-payer/native/program/Cargo.toml +++ b/basics/pda-rent-payer/native/program/Cargo.toml @@ -13,9 +13,16 @@ solana-system-interface.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.workspace = true +solana-instruction.workspace = true +solana-keypair.workspace = true +solana-pubkey.workspace = true +solana-transaction.workspace = true +solana-native-token.workspace = true diff --git a/basics/pda-rent-payer/native/program/src/instructions/init_rent_vault.rs b/basics/pda-rent-payer/native/program/src/instructions/init_rent_vault.rs index 4613359c..d65f97f8 100644 --- a/basics/pda-rent-payer/native/program/src/instructions/init_rent_vault.rs +++ b/basics/pda-rent-payer/native/program/src/instructions/init_rent_vault.rs @@ -12,7 +12,7 @@ use crate::state::RentVault; #[derive(BorshDeserialize, BorshSerialize)] pub struct InitRentVaultArgs { - fund_lamports: u64, + pub fund_lamports: u64, } pub fn init_rent_vault( diff --git a/basics/pda-rent-payer/native/program/tests/test.rs b/basics/pda-rent-payer/native/program/tests/test.rs new file mode 100644 index 00000000..4bec223f --- /dev/null +++ b/basics/pda-rent-payer/native/program/tests/test.rs @@ -0,0 +1,70 @@ +use litesvm::LiteSVM; +use pda_rent_payer_program::instructions::InitRentVaultArgs; +use pda_rent_payer_program::processor::MyInstruction; +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_pda_rent_payer() { + let program_id = Pubkey::new_unique(); + let program_bytes = include_bytes!("../../../../../target/deploy/pda_rent_payer_program.so"); + + let mut svm = LiteSVM::new(); + svm.add_program(program_id, program_bytes).unwrap(); + + let payer = Keypair::new(); + svm.airdrop(&payer.pubkey(), LAMPORTS_PER_SOL * 10).unwrap(); + + let rent_value_pda = Pubkey::find_program_address(&[b"rent_vault"], &program_id).0; + + let args = InitRentVaultArgs { + fund_lamports: 1000000000, + }; + + let data = borsh::to_vec(&MyInstruction::InitRentVault(args)).unwrap(); + + let ix = Instruction { + program_id, + accounts: vec![ + AccountMeta::new(rent_value_pda, false), + AccountMeta::new(payer.pubkey(), true), + AccountMeta::new(solana_system_interface::program::ID, false), + ], + data, + }; + + let tx = Transaction::new_signed_with_payer( + &[ix], + Some(&payer.pubkey()), + &[&payer], + svm.latest_blockhash(), + ); + + let _ = svm.send_transaction(tx).is_ok(); + + let new_account = Keypair::new(); + + let data = borsh::to_vec(&MyInstruction::CreateNewAccount).unwrap(); + + let ix = Instruction { + program_id, + accounts: vec![ + AccountMeta::new(new_account.pubkey(), true), + AccountMeta::new(rent_value_pda, false), + AccountMeta::new(solana_system_interface::program::ID, false), + ], + data, + }; + + let tx = Transaction::new_signed_with_payer( + &[ix], + Some(&payer.pubkey()), + &[&payer, &new_account], + svm.latest_blockhash(), + ); + + let _ = svm.send_transaction(tx).is_ok(); +}