Merge pull request #762 from aya-rs/remove-workaround

integration-test: Remove cargo symlink workaround
reviewable/pr742/r9
Tamir Duberstein 1 year ago committed by GitHub
commit fb00fa13f3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -9,6 +9,7 @@ aya-bpf = { path = "../../bpf/aya-bpf" }
aya-log-ebpf = { path = "../../bpf/aya-log-ebpf" }
[build-dependencies]
which = { workspace = true }
xtask = { path = "../../xtask" }
[[bin]]

@ -1,6 +1,7 @@
use std::{env, path::PathBuf};
use std::env;
use xtask::{create_symlink_to_binary, AYA_BUILD_INTEGRATION_BPF};
use which::which;
use xtask::AYA_BUILD_INTEGRATION_BPF;
/// Building this crate has an undeclared dependency on the `bpf-linker` binary. This would be
/// better expressed by [artifact-dependencies][bindeps] but issues such as
@ -24,12 +25,7 @@ fn main() {
.unwrap_or_default();
if build_integration_bpf {
let out_dir = env::var_os("OUT_DIR").unwrap();
let out_dir = PathBuf::from(out_dir);
let bpf_linker_symlink = create_symlink_to_binary(&out_dir, "bpf-linker").unwrap();
println!(
"cargo:rerun-if-changed={}",
bpf_linker_symlink.to_str().unwrap()
);
let bpf_linker = which("bpf-linker").unwrap();
println!("cargo:rerun-if-changed={}", bpf_linker.to_str().unwrap());
}
}

@ -1,10 +1,5 @@
use anyhow::{bail, Context as _, Result};
use std::{
fs,
path::{Path, PathBuf},
process::Command,
};
use which::which;
use std::process::Command;
pub const AYA_BUILD_INTEGRATION_BPF: &str = "AYA_BUILD_INTEGRATION_BPF";
pub const LIBBPF_DIR: &str = "xtask/libbpf";
@ -18,26 +13,3 @@ pub fn exec(cmd: &mut Command) -> Result<()> {
}
Ok(())
}
// Create a symlink in the out directory to work around the fact that cargo ignores anything
// in `$CARGO_HOME`, which is also where `cargo install` likes to place binaries. Cargo will
// stat through the symlink and discover that the binary has changed.
//
// This was introduced in https://github.com/rust-lang/cargo/commit/99f841c.
//
// TODO(https://github.com/rust-lang/cargo/pull/12369): Remove this when the fix is available.
pub fn create_symlink_to_binary(out_dir: &Path, binary_name: &str) -> Result<PathBuf> {
let binary = which(binary_name).unwrap();
let symlink = out_dir.join(binary_name);
match fs::remove_file(&symlink) {
Ok(()) => {}
Err(err) => {
if err.kind() != std::io::ErrorKind::NotFound {
return Err(err).context(format!("failed to remove symlink {}", symlink.display()));
}
}
}
std::os::unix::fs::symlink(binary, &symlink)
.with_context(|| format!("failed to create symlink {}", symlink.display()))?;
Ok(symlink)
}

Loading…
Cancel
Save