2020-08-07 14:30:00 +01:00
|
|
|
use anyhow::Result;
|
|
|
|
use duct::cmd;
|
2021-05-12 02:12:11 +08:00
|
|
|
use thinp::version::tools_version;
|
2020-08-07 14:30:00 +01:00
|
|
|
|
|
|
|
mod common;
|
|
|
|
|
|
|
|
use common::test_dir::*;
|
2021-05-04 16:10:20 +08:00
|
|
|
use common::*;
|
2020-08-07 14:30:00 +01:00
|
|
|
|
|
|
|
//------------------------------------------
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn accepts_v() -> Result<()> {
|
|
|
|
let stdout = cache_check!("-V").read()?;
|
2021-06-19 22:43:50 +08:00
|
|
|
assert!(stdout.contains(tools_version()));
|
2020-08-07 14:30:00 +01:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn accepts_version() -> Result<()> {
|
|
|
|
let stdout = cache_check!("--version").read()?;
|
2021-06-19 22:43:50 +08:00
|
|
|
assert!(stdout.contains(tools_version()));
|
2020-08-07 14:30:00 +01:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
const USAGE: &str = "Usage: cache_check [options] {device|file}\nOptions:\n {-q|--quiet}\n {-h|--help}\n {-V|--version}\n {--clear-needs-check-flag}\n {--super-block-only}\n {--skip-mappings}\n {--skip-hints}\n {--skip-discards}";
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn accepts_h() -> Result<()> {
|
|
|
|
let stdout = cache_check!("-h").read()?;
|
|
|
|
assert_eq!(stdout, USAGE);
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn accepts_help() -> Result<()> {
|
|
|
|
let stdout = cache_check!("--help").read()?;
|
|
|
|
assert_eq!(stdout, USAGE);
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn missing_metadata() -> Result<()> {
|
|
|
|
let stderr = run_fail(cache_check!())?;
|
2021-06-21 15:44:56 +08:00
|
|
|
assert!(stderr.contains(msg::MISSING_INPUT_ARG));
|
2020-08-07 14:30:00 +01:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn no_such_metadata() -> Result<()> {
|
|
|
|
let stderr = run_fail(cache_check!("/arbitrary/filename"))?;
|
|
|
|
assert!(stderr.contains("No such file or directory"));
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn metadata_cannot_be_a_directory() -> Result<()> {
|
|
|
|
let stderr = run_fail(cache_check!("/tmp"))?;
|
|
|
|
assert!(stderr.contains("Not a block device or regular file"));
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn unreadable_metadata() -> Result<()> {
|
|
|
|
let mut td = TestDir::new()?;
|
|
|
|
let md = mk_valid_md(&mut td)?;
|
|
|
|
cmd!("chmod", "-r", &md).run()?;
|
|
|
|
let stderr = run_fail(cache_check!(&md))?;
|
2021-06-21 15:44:56 +08:00
|
|
|
assert!(stderr.contains("Permission denied"));
|
2020-08-07 14:30:00 +01:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn corrupt_metadata() -> Result<()> {
|
|
|
|
let mut td = TestDir::new()?;
|
|
|
|
let md = mk_zeroed_md(&mut td)?;
|
|
|
|
run_fail(cache_check!(&md))?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn failing_q() -> Result<()> {
|
|
|
|
let mut td = TestDir::new()?;
|
|
|
|
let md = mk_zeroed_md(&mut td)?;
|
|
|
|
let output = cache_check!("-q", &md).unchecked().run()?;
|
|
|
|
assert!(!output.status.success());
|
|
|
|
assert_eq!(output.stdout.len(), 0);
|
|
|
|
assert_eq!(output.stderr.len(), 0);
|
|
|
|
Ok(())
|
|
|
|
}
|
2021-05-04 16:10:20 +08:00
|
|
|
|
2020-08-07 14:30:00 +01:00
|
|
|
#[test]
|
|
|
|
fn failing_quiet() -> Result<()> {
|
|
|
|
let mut td = TestDir::new()?;
|
|
|
|
let md = mk_zeroed_md(&mut td)?;
|
|
|
|
let output = cache_check!("--quiet", &md).unchecked().run()?;
|
|
|
|
assert!(!output.status.success());
|
|
|
|
assert_eq!(output.stdout.len(), 0);
|
|
|
|
assert_eq!(output.stderr.len(), 0);
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
// (define-scenario (cache-check valid-metadata-passes)
|
|
|
|
// "A valid metadata area passes"
|
|
|
|
// (with-valid-metadata (md)
|
|
|
|
// (run-ok (cache-check md))))
|
|
|
|
//
|
|
|
|
// (define-scenario (cache-check bad-metadata-version)
|
|
|
|
// "Invalid metadata version fails"
|
|
|
|
// (with-cache-xml (xml)
|
|
|
|
// (with-empty-metadata (md)
|
|
|
|
// (cache-restore "-i" xml "-o" md "--debug-override-metadata-version" "12345")
|
|
|
|
// (run-fail (cache-check md)))))
|
|
|
|
//
|
|
|
|
// (define-scenario (cache-check tiny-metadata)
|
|
|
|
// "Prints helpful message in case tiny metadata given"
|
|
|
|
// (with-temp-file-sized ((md "cache.bin" 1024))
|
|
|
|
// (run-fail-rcv (_ stderr) (cache-check md)
|
|
|
|
// (assert-starts-with "Metadata device/file too small. Is this binary metadata?" stderr))))
|
|
|
|
//
|
|
|
|
// (define-scenario (cache-check spot-accidental-xml-data)
|
|
|
|
// "Prints helpful message if XML metadata given"
|
|
|
|
// (with-cache-xml (xml)
|
|
|
|
// (system (fmt #f "man bash >> " xml))
|
|
|
|
// (run-fail-rcv (_ stderr) (cache-check xml)
|
|
|
|
// (assert-matches ".*This looks like XML. cache_check only checks the binary metadata format." stderr))))
|
|
|
|
//
|