38cf5b15c6
Since these are defined in C as macros, they must be reimplemented in libc as Rust functions. They're hard to get exactly right, and they vary from platform to platform. The test builds custom C code that uses the real macros, and compares its output to the Rust versions' output for various inputs. Skip the CMSG_NXTHDR test on sparc64 linux because it hits a Bus Error. Issue #1239 Skip the entire cmsg test program on s390x because it dumps core seemingly before the kernel finishes booting. Issue #1240
48 lines
1.3 KiB
Rust
48 lines
1.3 KiB
Rust
use std::env;
|
|
use std::process::Command;
|
|
use std::path::{Path, PathBuf};
|
|
|
|
fn main() {
|
|
let args = env::args_os()
|
|
.skip(1)
|
|
.filter(|arg| arg != "--quiet")
|
|
.collect::<Vec<_>>();
|
|
assert_eq!(args.len(), 1);
|
|
let test = PathBuf::from(&args[0]);
|
|
let dst = Path::new("/data/local/tmp").join(test.file_name().unwrap());
|
|
|
|
let status = Command::new("adb")
|
|
.arg("wait-for-device")
|
|
.status()
|
|
.expect("failed to run: adb wait-for-device");
|
|
assert!(status.success());
|
|
|
|
let status = Command::new("adb")
|
|
.arg("push")
|
|
.arg(&test)
|
|
.arg(&dst)
|
|
.status()
|
|
.expect("failed to run: adb pushr");
|
|
assert!(status.success());
|
|
|
|
let output = Command::new("adb")
|
|
.arg("shell")
|
|
.arg(&dst)
|
|
.output()
|
|
.expect("failed to run: adb shell");
|
|
assert!(status.success());
|
|
|
|
println!("status: {}\nstdout ---\n{}\nstderr ---\n{}",
|
|
output.status,
|
|
String::from_utf8_lossy(&output.stdout),
|
|
String::from_utf8_lossy(&output.stderr));
|
|
|
|
let stdout = String::from_utf8_lossy(&output.stdout);
|
|
let passed = stdout.lines().find(|l|
|
|
(l.starts_with("PASSED ") && l.contains(" tests")) ||
|
|
l.starts_with("test result: ok")
|
|
).unwrap_or_else(|| {
|
|
panic!("failed to find successful test run");
|
|
});
|
|
}
|