use borsh::BorshDeserialize; use counter_solana_native::Counter; use litesvm::LiteSVM; use solana_instruction::{AccountMeta, Instruction}; use solana_keypair::{Keypair, Signer}; use solana_native_token::LAMPORTS_PER_SOL; use solana_pubkey::Pubkey; use solana_rent::Rent; use solana_system_interface::instruction::create_account; use solana_transaction::Transaction; #[test] fn test_counter() { let program_id = Pubkey::new_unique(); let program_bytes = include_bytes!("../../tests/fixtures/counter_solana_native.so"); let mut svm = LiteSVM::new(); svm.add_program(program_id, program_bytes).unwrap(); let payer = Keypair::new(); let counter_account = Keypair::new(); svm.airdrop(&payer.pubkey(), LAMPORTS_PER_SOL * 10).unwrap(); let counter_account_size = std::mem::size_of::(); let create_ix = create_account( &payer.pubkey(), &counter_account.pubkey(), Rent::default().minimum_balance(counter_account_size), counter_account_size as u64, &program_id, ); let tx = Transaction::new_signed_with_payer( &[create_ix], Some(&payer.pubkey()), &[&payer, &counter_account], svm.latest_blockhash(), ); assert!(svm.send_transaction(tx).is_ok()); let ix = Instruction { program_id, accounts: vec![AccountMeta::new(counter_account.pubkey(), false)], data: vec![0], }; let tx = Transaction::new_signed_with_payer( &[ix], Some(&payer.pubkey()), &[payer], svm.latest_blockhash(), ); dbg!(&[0].split_at(1)); let _ = svm.send_transaction(tx).is_ok(); let counter_account_data = svm.get_account(&counter_account.pubkey()).unwrap().data; let couneter = Counter::try_from_slice(&counter_account_data).unwrap(); assert_eq!(couneter.count, 1); }