2019-05-20 16:08:56 +00:00
|
|
|
use std::io::{BufRead, BufReader};
|
|
|
|
use std::process::{Command, Stdio};
|
|
|
|
|
|
|
|
// Test if xattrs are correctly archived and restored
|
|
|
|
#[test]
|
|
|
|
fn pxar_create_and_extract() {
|
|
|
|
let src_dir = "./tests/catar_data/test_xattrs_src/";
|
|
|
|
let dest_dir = "./tests/catar_data/test_xattrs_dest/";
|
|
|
|
|
2019-05-22 13:02:41 +00:00
|
|
|
let exec_path = if cfg!(debug_assertions) {
|
|
|
|
"./target/debug/pxar"
|
|
|
|
} else {
|
|
|
|
"./target/release/pxar"
|
|
|
|
};
|
2019-05-20 16:08:56 +00:00
|
|
|
|
2019-05-22 13:02:41 +00:00
|
|
|
println!("run '{} create archive.pxar {}'", exec_path, src_dir);
|
|
|
|
|
|
|
|
Command::new(exec_path)
|
2019-05-20 16:08:56 +00:00
|
|
|
.arg("create")
|
|
|
|
.arg("./tests/archive.pxar")
|
|
|
|
.arg(src_dir)
|
|
|
|
.status()
|
|
|
|
.unwrap_or_else(|err| {
|
2019-05-22 13:02:41 +00:00
|
|
|
panic!("Failed to invoke '{}': {}", exec_path, err)
|
2019-05-20 16:08:56 +00:00
|
|
|
});
|
|
|
|
|
2019-12-18 10:46:05 +00:00
|
|
|
println!("run '{} extract archive.pxar {}'", exec_path, dest_dir);
|
|
|
|
|
2019-05-22 13:02:41 +00:00
|
|
|
Command::new(exec_path)
|
2019-05-20 16:08:56 +00:00
|
|
|
.arg("extract")
|
|
|
|
.arg("./tests/archive.pxar")
|
2019-07-16 13:45:17 +00:00
|
|
|
.arg("--target")
|
2019-05-20 16:08:56 +00:00
|
|
|
.arg(dest_dir)
|
|
|
|
.status()
|
|
|
|
.unwrap_or_else(|err| {
|
2019-05-22 13:02:41 +00:00
|
|
|
panic!("Failed to invoke '{}': {}", exec_path, err)
|
2019-05-20 16:08:56 +00:00
|
|
|
});
|
|
|
|
|
2019-12-18 10:46:05 +00:00
|
|
|
println!("run 'rsync --dry-run --itemize-changes --archive {} {}' to verify'", src_dir, dest_dir);
|
2019-05-20 16:08:56 +00:00
|
|
|
/* Use rsync with --dry-run and --itemize-changes to compare
|
|
|
|
src_dir and dest_dir */
|
|
|
|
let stdout = Command::new("rsync")
|
|
|
|
.arg("--dry-run")
|
|
|
|
.arg("--itemize-changes")
|
2019-07-16 11:19:51 +00:00
|
|
|
.arg("--archive")
|
2019-05-20 16:08:56 +00:00
|
|
|
.arg(src_dir)
|
|
|
|
.arg(dest_dir)
|
|
|
|
.stdout(Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.stdout
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let reader = BufReader::new(stdout);
|
2021-01-19 10:37:49 +00:00
|
|
|
let line_iter = reader.lines().map(|l| l.unwrap());
|
2019-12-18 10:46:05 +00:00
|
|
|
let mut linecount = 0;
|
2021-01-19 10:37:49 +00:00
|
|
|
for curr in line_iter {
|
2019-12-18 10:46:05 +00:00
|
|
|
println!("{}", curr);
|
|
|
|
linecount += 1;
|
|
|
|
}
|
2019-05-20 16:08:56 +00:00
|
|
|
println!("Rsync listed {} differences to address", linecount);
|
|
|
|
|
|
|
|
// Cleanup archive
|
|
|
|
Command::new("rm")
|
|
|
|
.arg("./tests/archive.pxar")
|
|
|
|
.status()
|
|
|
|
.unwrap_or_else(|err| {
|
|
|
|
panic!("Failed to invoke 'rm': {}", err)
|
|
|
|
});
|
|
|
|
|
|
|
|
// Cleanup destination dir
|
|
|
|
Command::new("rm")
|
|
|
|
.arg("-r")
|
|
|
|
.arg(dest_dir)
|
|
|
|
.status()
|
|
|
|
.unwrap_or_else(|err| {
|
|
|
|
panic!("Failed to invoke 'rm': {}", err)
|
|
|
|
});
|
|
|
|
|
|
|
|
// If source and destination folder contain the same content,
|
|
|
|
// the output of the rsync invokation should yield no lines.
|
|
|
|
if linecount != 0 {
|
|
|
|
panic!("pxar create and extract did not yield the same contents");
|
|
|
|
}
|
|
|
|
}
|