Define BPF_OUT_DIR for program-test, also handle -- arguments better

This commit is contained in:
Michael Vines 2020-11-05 12:13:50 -08:00
parent 77d9d06a44
commit b511e51415
2 changed files with 40 additions and 8 deletions

1
Cargo.lock generated
View File

@ -3763,6 +3763,7 @@ dependencies = [
name = "solana-cargo-test-bpf" name = "solana-cargo-test-bpf"
version = "1.5.0" version = "1.5.0"
dependencies = [ dependencies = [
"cargo_metadata",
"clap", "clap",
] ]

View File

@ -64,6 +64,20 @@ where
} }
fn test_bpf(config: Config) { fn test_bpf(config: Config) {
let mut metadata_command = cargo_metadata::MetadataCommand::new();
if let Some(manifest_path) = config.manifest_path.as_ref() {
metadata_command.manifest_path(manifest_path);
}
let metadata = metadata_command.exec().unwrap_or_else(|err| {
eprintln!("Failed to obtain package metadata: {}", err);
exit(1);
});
let bpf_out_dir = config
.bpf_out_dir
.unwrap_or_else(|| format!("{}", metadata.target_directory.join("deploy").display()));
let mut cargo_args = vec![]; let mut cargo_args = vec![];
if config.no_default_features { if config.no_default_features {
cargo_args.push("--no-default-features"); cargo_args.push("--no-default-features");
@ -85,13 +99,14 @@ fn test_bpf(config: Config) {
build_bpf_args.push("--bpf-sdk"); build_bpf_args.push("--bpf-sdk");
build_bpf_args.push(bpf_sdk); build_bpf_args.push(bpf_sdk);
} }
if let Some(bpf_out_dir) = config.bpf_out_dir.as_ref() { build_bpf_args.push("--bpf-out-dir");
build_bpf_args.push("--bpf-out-dir"); build_bpf_args.push(&bpf_out_dir);
build_bpf_args.push(bpf_out_dir);
}
spawn(&config.cargo_build_bpf, &build_bpf_args); spawn(&config.cargo_build_bpf, &build_bpf_args);
env::set_var("bpf", "1"); // Hint to solana-program-test that it should load BPF programs // Pass --bpf-out-dir along to the solana-program-test crate
env::set_var("BPF_OUT_DIR", bpf_out_dir);
cargo_args.insert(0, "test"); cargo_args.insert(0, "test");
for extra_cargo_test_arg in &config.extra_cargo_test_args { for extra_cargo_test_arg in &config.extra_cargo_test_args {
cargo_args.push(&extra_cargo_test_arg); cargo_args.push(&extra_cargo_test_arg);
@ -109,6 +124,9 @@ fn main() {
} }
} }
let em_dash = "--".to_string();
let args_contain_dashash = args.contains(&em_dash);
let matches = App::new(crate_name!()) let matches = App::new(crate_name!())
.about(crate_description!()) .about(crate_description!())
.version(crate_version!()) .version(crate_version!())
@ -157,7 +175,7 @@ fn main() {
) )
.arg( .arg(
Arg::with_name("extra_cargo_test_args") Arg::with_name("extra_cargo_test_args")
.value_name("extra args for cargo test") .value_name("extra args for cargo test and the test binary")
.index(1) .index(1)
.multiple(true) .multiple(true)
.help("All extra arguments are passed through to cargo test"), .help("All extra arguments are passed through to cargo test"),
@ -186,7 +204,20 @@ fn main() {
config.cargo = PathBuf::from(cargo_build_bpf); config.cargo = PathBuf::from(cargo_build_bpf);
} }
test_bpf(config); // clap.rs swallows "--" in the case when the user provides it as the first `extra_cargo_test_args`
//
// For example, this command-line "cargo-test-bpf -- --nocapture" results in `extra_cargo_test_args` only
// containing "--nocapture". This is a problem because `cargo test` will never see the `--`.
//
// Whereas "cargo-test-bpf testname -- --nocapture" correctly produces a `extra_cargo_test_args`
// with "testname -- --nocapture".
//
// So if the original cargo-test-bpf arguments contain "--" but `extra_cargo_test_args` does
// not, then prepend "--".
//
if args_contain_dashash && !config.extra_cargo_test_args.contains(&em_dash) {
config.extra_cargo_test_args.insert(0, em_dash);
}
// TODO: args after -- go to ct test_bpf(config);
} }