use serial_test::serial;
use std::time::Duration;
#[macro_use]
mod common;
use common::{ensure_test_project, DaemonTestHarness};
const TEST_PROJECT: &str = "ci-test";
const TEST_PROGRAM: &str = "sample_binary";
fn try_start_harness(context: &str) -> Option<DaemonTestHarness> {
match DaemonTestHarness::new(TEST_PROJECT, TEST_PROGRAM) {
Ok(h) => Some(h),
Err(e) => {
let msg = format!("{}", e);
if msg.contains("program file(s) not found") {
eprintln!(
"Skipping ({}): bridge can't find program (known macOS issue)",
context
);
None
} else {
panic!("Failed to start bridge ({}): {}", context, e);
}
}
}
}
#[test]
#[serial]
fn test_stale_files_cleaned_on_restart() {
require_ghidra!();
ensure_test_project(TEST_PROJECT, TEST_PROGRAM);
{
let Some(_harness) = try_start_harness("first bridge") else {
return;
};
assert_cmd::cargo::cargo_bin_cmd!("ghidra")
.arg("ping")
.arg("--project")
.arg(TEST_PROJECT)
.timeout(Duration::from_secs(30))
.assert()
.success();
}
std::thread::sleep(Duration::from_millis(500));
{
let Some(_harness) = try_start_harness("second bridge after restart") else {
return;
};
assert_cmd::cargo::cargo_bin_cmd!("ghidra")
.arg("ping")
.arg("--project")
.arg(TEST_PROJECT)
.timeout(Duration::from_secs(30))
.assert()
.success();
}
}
#[test]
#[serial]
fn test_recovery_after_crash() {
require_ghidra!();
ensure_test_project(TEST_PROJECT, TEST_PROGRAM);
{
let Some(_harness) = try_start_harness("initial bridge") else {
return;
};
assert_cmd::cargo::cargo_bin_cmd!("ghidra")
.arg("ping")
.arg("--project")
.arg(TEST_PROJECT)
.timeout(Duration::from_secs(30))
.assert()
.success();
}
std::thread::sleep(Duration::from_millis(1000));
{
let Some(_harness) = try_start_harness("bridge after crash") else {
return;
};
assert_cmd::cargo::cargo_bin_cmd!("ghidra")
.arg("ping")
.arg("--project")
.arg(TEST_PROJECT)
.timeout(Duration::from_secs(30))
.assert()
.success();
}
}
#[test]
#[serial]
fn test_bridge_not_ready_error() {
require_ghidra!();
ensure_test_project(TEST_PROJECT, TEST_PROGRAM);
let Some(harness) = try_start_harness("bridge") else {
return;
};
assert_cmd::cargo::cargo_bin_cmd!("ghidra")
.arg("ping")
.arg("--project")
.arg(TEST_PROJECT)
.timeout(Duration::from_secs(30))
.assert()
.success();
drop(harness);
}