[functional-tests] use ../bin in the path for tools, even if they're
failing.
This commit is contained in:
@@ -25,9 +25,9 @@
|
||||
(syntax-rules ()
|
||||
((_ (md) b1 b2 ...)
|
||||
(with-temp-file-sized ((md "era.bin" (meg 4)))
|
||||
(with-era-xml (xml)
|
||||
(era-restore "-i" xml "-o" md)
|
||||
b1 b2 ...)))))
|
||||
(with-era-xml (xml)
|
||||
(run-ok (era-restore "-i" xml "-o" md))
|
||||
b1 b2 ...)))))
|
||||
|
||||
(define-syntax with-corrupt-metadata
|
||||
(syntax-rules ()
|
||||
@@ -48,76 +48,76 @@
|
||||
;;;-----------------------------------------------------------
|
||||
(define-scenario (era-check v)
|
||||
"era_check -V"
|
||||
(receive (stdout _) (era-check "-V")
|
||||
(run-ok-rcv (stdout _) (era-check "-V")
|
||||
(assert-equal tools-version stdout)))
|
||||
|
||||
(define-scenario (era-check version)
|
||||
"era_check --version"
|
||||
(receive (stdout _) (era-check "--version")
|
||||
(run-ok-rcv (stdout _) (era-check "--version")
|
||||
(assert-equal tools-version stdout)))
|
||||
|
||||
(define-scenario (era-check h)
|
||||
"era_check -h"
|
||||
(receive (stdout _) (era-check "-h")
|
||||
(run-ok-rcv (stdout _) (era-check "-h")
|
||||
(assert-equal era-check-help stdout)))
|
||||
|
||||
(define-scenario (era-check help)
|
||||
"era_check --help"
|
||||
(receive (stdout _) (era-check "--help")
|
||||
(run-ok-rcv (stdout _) (era-check "--help")
|
||||
(assert-equal era-check-help stdout)))
|
||||
|
||||
(define-scenario (era-check no-device-specified)
|
||||
"Fail if no device specified"
|
||||
(receive (_ stderr) (run-fail "era_check")
|
||||
(run-fail-rcv (_ stderr) (era-check)
|
||||
(assert-starts-with "No input file provided." stderr)))
|
||||
|
||||
(define-scenario (era-check dev-not-exist)
|
||||
"Fail if specified device doesn't exist"
|
||||
(receive (_ stderr) (run-fail "era_check /dev/unlikely")
|
||||
(run-fail-rcv (_ stderr) (era-check "/dev/unlikely")
|
||||
(assert-starts-with "/dev/unlikely: No such file or directory" stderr)))
|
||||
|
||||
(define-scenario (era-check dev-is-a-directory)
|
||||
"Fail if given a directory instead of a file or device"
|
||||
(receive (_ stderr) (run-fail "era_check /tmp")
|
||||
(run-fail-rcv (_ stderr) (era-check "/tmp")
|
||||
(assert-starts-with "/tmp: Not a block device or regular file" stderr)))
|
||||
|
||||
(define-scenario (era-check bad-permissions)
|
||||
"Fail if given a device with inadequate access permissions"
|
||||
(with-temp-file-sized ((md "era.bin" (meg 4)))
|
||||
(run-ok "chmod -r" md)
|
||||
(receive (_ stderr) (run-fail "era_check" md)
|
||||
(run-fail-rcv (_ stderr) (era-check md)
|
||||
(assert-starts-with "syscall 'open' failed: Permission denied" stderr))))
|
||||
|
||||
(define-scenario (era-check empty-dev)
|
||||
"Fail if given a file of zeroes"
|
||||
(with-empty-metadata (md)
|
||||
(run-fail "era_check" md)))
|
||||
(run-fail (era-check md))))
|
||||
|
||||
(define-scenario (era-check quiet)
|
||||
"Fail should give no output if --quiet"
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (run-fail "era_check --quiet" md)
|
||||
(run-fail-rcv (stdout stderr) (era-check "--quiet" md)
|
||||
(assert-eof stdout)
|
||||
(assert-eof stderr))))
|
||||
|
||||
(define-scenario (era-check q)
|
||||
"Fail should give no output if -q"
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (run-fail "era_check -q" md)
|
||||
(run-fail-rcv (stdout stderr) (era-check "-q" md)
|
||||
(assert-eof stdout)
|
||||
(assert-eof stderr))))
|
||||
|
||||
(define-scenario (era-check tiny-metadata)
|
||||
"Prints helpful message in case tiny metadata given"
|
||||
(with-temp-file-sized ((md "era.bin" 1024))
|
||||
(receive (_ stderr) (run-fail "era_check" md)
|
||||
(run-fail-rcv (_ stderr) (era-check md)
|
||||
(assert-starts-with "Metadata device/file too small. Is this binary metadata?" stderr))))
|
||||
|
||||
(define-scenario (era-check spot-accidental-xml-data)
|
||||
"Prints helpful message if XML metadata given"
|
||||
(with-era-xml (xml)
|
||||
(system (fmt #f "man bash >> " xml))
|
||||
(receive (_ stderr) (run-fail "era_check" xml)
|
||||
(run-fail-rcv (_ stderr) (era-check xml)
|
||||
(assert-matches ".*This looks like XML. era_check only checks the binary metadata format." stderr))))
|
||||
|
||||
;;;-----------------------------------------------------------
|
||||
@@ -125,34 +125,34 @@
|
||||
;;;-----------------------------------------------------------
|
||||
(define-scenario (era-restore v)
|
||||
"era_restore -V"
|
||||
(receive (stdout _) (era-restore "-V")
|
||||
(run-ok-rcv (stdout _) (era-restore "-V")
|
||||
(assert-equal tools-version stdout)))
|
||||
|
||||
(define-scenario (era-restore version)
|
||||
"era_restore --version"
|
||||
(receive (stdout _) (era-restore "--version")
|
||||
(run-ok-rcv (stdout _) (era-restore "--version")
|
||||
(assert-equal tools-version stdout)))
|
||||
|
||||
(define-scenario (era-restore h)
|
||||
"era_restore -h"
|
||||
(receive (stdout _) (era-restore "-h")
|
||||
(run-ok-rcv (stdout _) (era-restore "-h")
|
||||
(assert-equal era-restore-help stdout)))
|
||||
|
||||
(define-scenario (era-restore help)
|
||||
"era_restore --help"
|
||||
(receive (stdout _) (era-restore "--help")
|
||||
(run-ok-rcv (stdout _) (era-restore "--help")
|
||||
(assert-equal era-restore-help stdout)))
|
||||
|
||||
(define-scenario (era-restore input-unspecified)
|
||||
"Fails if no xml specified"
|
||||
(with-empty-metadata (md)
|
||||
(receive (_ stderr) (run-fail "era_restore" "-o" md)
|
||||
(run-fail-rcv (_ stderr) (era-restore "-o" md)
|
||||
(assert-starts-with "No input file provided." stderr))))
|
||||
|
||||
(define-scenario (era-restore missing-input-file)
|
||||
"the input file can't be found"
|
||||
(with-empty-metadata (md)
|
||||
(receive (_ stderr) (run-fail "era_restore -i no-such-file -o" md)
|
||||
(run-fail-rcv (_ stderr) (era-restore "-i no-such-file -o" md)
|
||||
(assert-superblock-untouched md)
|
||||
(assert-starts-with "Couldn't stat file" stderr))))
|
||||
|
||||
@@ -160,26 +160,26 @@
|
||||
"the input file is just zeroes"
|
||||
(with-empty-metadata (md)
|
||||
(with-temp-file-sized ((xml "era.xml" 4096))
|
||||
(receive (_ stderr) (run-fail "era_restore -i " xml "-o" md)
|
||||
(run-fail-rcv (_ stderr) (era-restore "-i " xml "-o" md)
|
||||
(assert-superblock-untouched md)))))
|
||||
|
||||
(define-scenario (era-restore output-unspecified)
|
||||
"Fails if no metadata dev specified"
|
||||
(with-era-xml (xml)
|
||||
(receive (_ stderr) (run-fail "era_restore" "-i" xml)
|
||||
(run-fail-rcv (_ stderr) (era-restore "-i" xml)
|
||||
(assert-starts-with "No output file provided." stderr))))
|
||||
|
||||
(define-scenario (era-restore success)
|
||||
"Succeeds with xml and metadata"
|
||||
(with-era-xml (xml)
|
||||
(with-empty-metadata (md)
|
||||
(era-restore "-i" xml "-o" md))))
|
||||
(run-ok (era-restore "-i" xml "-o" md)))))
|
||||
|
||||
(define-scenario (era-restore quiet)
|
||||
"No output with --quiet (succeeding)"
|
||||
(with-era-xml (xml)
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (era-restore "--quiet" "-i" xml "-o" md)
|
||||
(run-ok-rcv (stdout stderr) (era-restore "--quiet" "-i" xml "-o" md)
|
||||
(assert-eof stdout)
|
||||
(assert-eof stderr)))))
|
||||
|
||||
@@ -187,7 +187,7 @@
|
||||
"No output with -q (succeeding)"
|
||||
(with-era-xml (xml)
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (era-restore "-q" "-i" xml "-o" md)
|
||||
(run-ok-rcv (stdout stderr) (era-restore "-q" "-i" xml "-o" md)
|
||||
(assert-eof stdout)
|
||||
(assert-eof stderr)))))
|
||||
|
||||
@@ -195,7 +195,7 @@
|
||||
"No output with --quiet (failing)"
|
||||
(with-temp-file ((bad-xml "era.xml"))
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (run-fail "era_restore" "--quiet" "-i" bad-xml "-o" md)
|
||||
(run-fail-rcv (stdout stderr) (era-restore "--quiet" "-i" bad-xml "-o" md)
|
||||
(assert-eof stdout)
|
||||
(assert-starts-with "Couldn't stat file" stderr)))))
|
||||
|
||||
@@ -203,7 +203,7 @@
|
||||
"No output with --q(failing)"
|
||||
(with-temp-file ((bad-xml "era.xml"))
|
||||
(with-empty-metadata (md)
|
||||
(receive (stdout stderr) (run-fail "era_restore" "-q" "-i" bad-xml "-o" md)
|
||||
(run-fail-rcv (stdout stderr) (era-restore "-q" "-i" bad-xml "-o" md)
|
||||
(assert-eof stdout)
|
||||
(assert-starts-with "Couldn't stat file" stderr)))))
|
||||
|
||||
@@ -213,14 +213,14 @@
|
||||
(define-scenario (era-dump small-input-file)
|
||||
"Fails with small input file"
|
||||
(with-temp-file-sized ((md "era.bin" 512))
|
||||
(run-fail "era_dump" md)))
|
||||
(run-fail (era-dump md))))
|
||||
|
||||
(define-scenario (era-dump restore-is-noop)
|
||||
"era_dump followed by era_restore is a noop."
|
||||
(with-valid-metadata (md)
|
||||
(receive (d1-stdout _) (era-dump md)
|
||||
(run-ok-rcv (d1-stdout _) (era-dump md)
|
||||
(with-temp-file-containing ((xml "era.xml" d1-stdout))
|
||||
(era-restore "-i" xml "-o" md)
|
||||
(receive (d2-stdout _) (era-dump md)
|
||||
(run-ok (era-restore "-i" xml "-o" md))
|
||||
(run-ok-rcv (d2-stdout _) (era-dump md)
|
||||
(assert-equal d1-stdout d2-stdout))))))
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user