solana/programs/bpf/tests/programs.rs

141 lines
5.1 KiB
Rust
Raw Normal View History

#[cfg(any(feature = "bpf_c", feature = "bpf_rust"))]
2019-03-02 21:33:02 -08:00
mod bpf {
use solana_runtime::bank::Bank;
2019-03-21 07:14:14 -07:00
use solana_runtime::bank_client::BankClient;
use solana_runtime::loader_utils::{create_invoke_instruction, load_program};
2019-03-02 21:33:02 -08:00
use solana_sdk::genesis_block::GenesisBlock;
use solana_sdk::native_loader;
use std::env;
use std::fs::File;
use std::path::PathBuf;
2019-03-02 21:33:02 -08:00
/// BPF program file extension
const PLATFORM_FILE_EXTENSION_BPF: &str = "so";
2019-03-02 21:33:02 -08:00
/// Create a BPF program file name
fn create_bpf_path(name: &str) -> PathBuf {
let mut pathbuf = {
let current_exe = env::current_exe().unwrap();
PathBuf::from(current_exe.parent().unwrap().parent().unwrap())
};
pathbuf.push("bpf/");
pathbuf.push(name);
pathbuf.set_extension(PLATFORM_FILE_EXTENSION_BPF);
pathbuf
}
#[cfg(feature = "bpf_c")]
mod bpf_c {
use super::*;
use solana_sdk::bpf_loader;
use solana_sdk::signature::KeypairUtil;
2019-04-03 14:11:08 -07:00
use solana_sdk::sync_client::SyncClient;
2019-03-02 21:33:02 -08:00
use std::io::Read;
#[test]
fn test_program_bpf_c_noop() {
solana_logger::setup();
let mut file = File::open(create_bpf_path("noop")).expect("file open failed");
let mut elf = Vec::new();
file.read_to_end(&mut elf).unwrap();
let (genesis_block, alice_keypair) = GenesisBlock::new(50);
2019-03-02 21:33:02 -08:00
let bank = Bank::new(&genesis_block);
let bank_client = BankClient::new(&bank);
2019-03-02 21:33:02 -08:00
// Call user program
let program_id = load_program(&bank_client, &alice_keypair, &bpf_loader::id(), elf);
let instruction = create_invoke_instruction(alice_keypair.pubkey(), program_id, &1u8);
bank_client
2019-04-03 14:11:08 -07:00
.send_instruction(&alice_keypair, instruction)
.unwrap();
2019-03-02 21:33:02 -08:00
}
#[test]
fn test_program_bpf_c() {
solana_logger::setup();
let programs = [
"bpf_to_bpf",
"multiple_static",
"noop",
"noop++",
"relative_call",
"struct_pass",
"struct_ret",
];
for program in programs.iter() {
println!("Test program: {:?}", program);
let mut file = File::open(create_bpf_path(program)).expect("file open failed");
let mut elf = Vec::new();
file.read_to_end(&mut elf).unwrap();
let (genesis_block, alice_keypair) = GenesisBlock::new(50);
2019-03-02 21:33:02 -08:00
let bank = Bank::new(&genesis_block);
let bank_client = BankClient::new(&bank);
2019-03-02 21:33:02 -08:00
let loader_id = load_program(
&bank_client,
&alice_keypair,
&native_loader::id(),
2019-03-02 21:33:02 -08:00
"solana_bpf_loader".as_bytes().to_vec(),
);
// Call user program
let program_id = load_program(&bank_client, &alice_keypair, &loader_id, elf);
2019-03-21 07:14:14 -07:00
let instruction =
create_invoke_instruction(alice_keypair.pubkey(), program_id, &1u8);
bank_client
2019-04-03 14:11:08 -07:00
.send_instruction(&alice_keypair, instruction)
.unwrap();
2019-03-02 21:33:02 -08:00
}
}
}
2019-03-02 21:33:02 -08:00
// Cannot currently build the Rust BPF program as part
// of the rest of the build due to recursive `cargo build` causing
// a build deadlock. Therefore you must build the Rust programs
// yourself first by calling `make all` in the Rust BPF program's directory
#[cfg(feature = "bpf_rust")]
mod bpf_rust {
use super::*;
use solana_sdk::signature::KeypairUtil;
2019-04-03 14:11:08 -07:00
use solana_sdk::sync_client::SyncClient;
2019-03-02 21:33:02 -08:00
use std::io::Read;
#[test]
fn test_program_bpf_rust() {
solana_logger::setup();
let programs = ["solana_bpf_rust_noop"];
for program in programs.iter() {
let filename = create_bpf_path(program);
println!("Test program: {:?} from {:?}", program, filename);
let mut file = File::open(filename).unwrap();
let mut elf = Vec::new();
file.read_to_end(&mut elf).unwrap();
let (genesis_block, alice_keypair) = GenesisBlock::new(50);
2019-03-02 21:33:02 -08:00
let bank = Bank::new(&genesis_block);
let bank_client = BankClient::new(&bank);
2019-03-21 07:14:14 -07:00
2019-03-02 21:33:02 -08:00
let loader_id = load_program(
&bank_client,
&alice_keypair,
&native_loader::id(),
2019-03-02 21:33:02 -08:00
"solana_bpf_loader".as_bytes().to_vec(),
);
// Call user program
let program_id = load_program(&bank_client, &alice_keypair, &loader_id, elf);
2019-03-21 07:14:14 -07:00
let instruction =
create_invoke_instruction(alice_keypair.pubkey(), program_id, &1u8);
bank_client
2019-04-03 14:11:08 -07:00
.send_instruction(&alice_keypair, instruction)
.unwrap();
2019-03-02 21:33:02 -08:00
}
}
}
}