2017-08-15 20:37:45 +05:30
|
|
|
(library
|
|
|
|
(thin-functional-tests)
|
|
|
|
|
|
|
|
(export register-thin-tests)
|
|
|
|
|
|
|
|
(import
|
|
|
|
(chezscheme)
|
2017-09-28 19:06:01 +05:30
|
|
|
(bcache block-manager)
|
2017-08-25 15:55:37 +05:30
|
|
|
(disk-units)
|
2017-08-15 20:37:45 +05:30
|
|
|
(fmt fmt)
|
|
|
|
(functional-tests)
|
2017-08-25 14:16:56 +05:30
|
|
|
(process)
|
2017-08-25 15:42:18 +05:30
|
|
|
(scenario-string-constants)
|
2017-08-23 15:18:33 +05:30
|
|
|
(temp-file)
|
2017-09-15 16:56:54 +05:30
|
|
|
(thin xml)
|
2017-09-14 20:39:43 +05:30
|
|
|
(srfi s8 receive))
|
2017-08-15 20:37:45 +05:30
|
|
|
|
|
|
|
(define-tool thin-check)
|
|
|
|
(define-tool thin-delta)
|
|
|
|
(define-tool thin-dump)
|
|
|
|
(define-tool thin-restore)
|
|
|
|
(define-tool thin-rmap)
|
2017-09-29 14:49:56 +05:30
|
|
|
(define-tool thin-repair)
|
2020-05-26 15:25:03 +05:30
|
|
|
(define-tool thin-metadata-pack)
|
|
|
|
(define-tool thin-metadata-unpack)
|
2017-08-15 20:37:45 +05:30
|
|
|
|
2017-08-24 18:33:07 +05:30
|
|
|
(define-syntax with-thin-xml
|
|
|
|
(syntax-rules ()
|
|
|
|
((_ (v) b1 b2 ...)
|
2017-08-29 19:16:59 +05:30
|
|
|
(with-temp-file-containing ((v "thin.xml" (fmt #f (generate-xml 10 1000))))
|
2017-08-24 18:33:07 +05:30
|
|
|
b1 b2 ...))))
|
2017-08-15 20:37:45 +05:30
|
|
|
|
|
|
|
(define-syntax with-valid-metadata
|
|
|
|
(syntax-rules ()
|
2017-08-25 15:42:18 +05:30
|
|
|
((_ (md) b1 b2 ...)
|
2017-08-29 19:16:59 +05:30
|
|
|
(with-temp-file-sized ((md "thin.bin" (meg 4)))
|
2017-08-25 15:42:18 +05:30
|
|
|
(with-thin-xml (xml)
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-ok (thin-restore "-i" xml "-o" md))
|
2017-08-25 15:42:18 +05:30
|
|
|
b1 b2 ...)))))
|
2017-08-15 20:37:45 +05:30
|
|
|
|
|
|
|
;;; It would be nice if the metadata was at least similar to valid data.
|
2019-10-08 19:04:24 +05:30
|
|
|
;;; Here I'm just using the start of the ls binary as 'random' data.
|
2017-08-15 20:37:45 +05:30
|
|
|
(define-syntax with-corrupt-metadata
|
|
|
|
(syntax-rules ()
|
2017-08-25 15:42:18 +05:30
|
|
|
((_ (md) b1 b2 ...)
|
2017-08-29 19:16:59 +05:30
|
|
|
(with-temp-file-sized ((md "thin.bin" (meg 4)))
|
2019-10-08 19:04:24 +05:30
|
|
|
(system (fmt #f "dd if=/usr/bin/ls of=" md " bs=4096 > /dev/null 2>&1"))
|
2017-08-25 15:42:18 +05:30
|
|
|
b1 b2 ...))))
|
2017-08-15 20:37:45 +05:30
|
|
|
|
2017-08-29 19:25:48 +05:30
|
|
|
(define-syntax with-empty-metadata
|
|
|
|
(syntax-rules ()
|
|
|
|
((_ (md) b1 b2 ...)
|
|
|
|
(with-temp-file-sized ((md "thin.bin" (meg 4)))
|
|
|
|
b1 b2 ...))))
|
|
|
|
|
2019-10-25 15:02:56 +05:30
|
|
|
(define (damage-superblock md)
|
|
|
|
(system (string-append "dd if=/dev/zero of=" md " bs=4K count=1 conv=notrunc > /dev/null 2>&1")))
|
|
|
|
|
|
|
|
(define-syntax with-damaged-superblock
|
|
|
|
(syntax-rules ()
|
|
|
|
((_ (md) b1 b2 ...)
|
|
|
|
(with-valid-metadata (md)
|
|
|
|
(damage-superblock md)
|
|
|
|
b1 b2 ...))))
|
|
|
|
|
2017-08-15 20:37:45 +05:30
|
|
|
;; We have to export something that forces all the initialisation expressions
|
|
|
|
;; to run.
|
2017-08-17 16:00:28 +05:30
|
|
|
(define (register-thin-tests) #t)
|
2017-08-15 20:37:45 +05:30
|
|
|
|
2017-08-31 14:39:58 +05:30
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
;;; thin_delta scenarios
|
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
(define-scenario (thin-delta v)
|
|
|
|
"thin_delta accepts -V"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-delta "-V")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-equal tools-version stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta version)
|
|
|
|
"thin_delta accepts --version"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-delta "--version")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-equal tools-version stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta h)
|
|
|
|
"thin_delta accepts -h"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-delta "-h")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-equal thin-delta-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta help)
|
|
|
|
"thin_delta accepts --help"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-delta "--help")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-equal thin-delta-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta unrecognised-option)
|
|
|
|
"Unrecognised option should cause failure"
|
2017-09-15 16:56:54 +05:30
|
|
|
(with-valid-metadata (md)
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-fail-rcv (stdout stderr) (thin-delta "--unleash-the-hedgehogs")
|
|
|
|
(assert-matches ".*thin_delta: unrecognized option '--unleash-the-hedgehogs" stderr))))
|
2017-08-31 14:39:58 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-delta snap1-unspecified)
|
|
|
|
"Fails without --snap1 fails"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-fail-rcv (_ stderr) (thin-delta "--snap2 45 foo")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-starts-with "--snap1 not specified." stderr)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta snap2-unspecified)
|
|
|
|
"Fails without --snap2 fails"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-fail-rcv (_ stderr) (thin-delta "--snap1 45 foo")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-starts-with "--snap2 not specified." stderr)))
|
|
|
|
|
|
|
|
(define-scenario (thin-delta device-unspecified)
|
|
|
|
"Fails if no device given"
|
2017-10-10 21:21:31 +05:30
|
|
|
(run-fail-rcv (_ stderr) (thin-delta "--snap1 45 --snap2 46")
|
2017-08-31 14:39:58 +05:30
|
|
|
(assert-starts-with "No input device provided." stderr)))
|
|
|
|
|
2020-05-26 15:25:03 +05:30
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
;;; thin_metadata_pack scenarios
|
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack version)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts --version"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-pack "--version")
|
2020-07-03 17:58:02 +05:30
|
|
|
(assert-equal "thin_metadata_pack 0.9.0-rc2" stdout)))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack h)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts -h"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-pack "-h")
|
|
|
|
(assert-equal thin-metadata-pack-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack help)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts --help"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-pack "--help")
|
|
|
|
(assert-equal thin-metadata-pack-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack unrecognised-option)
|
|
|
|
"Unrecognised option should cause failure"
|
|
|
|
(with-valid-metadata (md)
|
|
|
|
(run-fail-rcv (stdout stderr) (thin-metadata-pack "--unleash-the-hedgehogs")
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: Found argument '--unleash-the-hedgehogs'" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack missing-input-file)
|
|
|
|
"the input file wasn't specified"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-pack "-o " md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: The following required arguments were not provided:\n -i <DEV>" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack no-such-input-file)
|
|
|
|
"the input file can't be found"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-pack "-i no-such-file -o" md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "Couldn't find input file" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-pack missing-output-file)
|
|
|
|
"the output file wasn't specified"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-pack "-i" md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: The following required arguments were not provided:\n -o <FILE>" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
;;;-----------------------------------------------------------
|
2020-06-09 17:33:39 +05:30
|
|
|
;;; thin_metadata_unpack scenarios
|
2020-05-26 15:25:03 +05:30
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
(define-scenario (thin-metadata-unpack version)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts --version"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-unpack "--version")
|
2020-07-03 17:58:02 +05:30
|
|
|
(assert-equal "thin_metadata_unpack 0.9.0-rc2" stdout)))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack h)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts -h"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-unpack "-h")
|
|
|
|
(assert-equal thin-metadata-unpack-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack help)
|
2020-06-09 17:33:39 +05:30
|
|
|
"accepts --help"
|
2020-05-26 15:25:03 +05:30
|
|
|
(run-ok-rcv (stdout _) (thin-metadata-unpack "--help")
|
|
|
|
(assert-equal thin-metadata-unpack-help stdout)))
|
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack unrecognised-option)
|
|
|
|
"Unrecognised option should cause failure"
|
|
|
|
(with-valid-metadata (md)
|
|
|
|
(run-fail-rcv (stdout stderr) (thin-metadata-unpack "--unleash-the-hedgehogs")
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: Found argument '--unleash-the-hedgehogs'" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack missing-input-file)
|
|
|
|
"the input file wasn't specified"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-unpack "-o " md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: The following required arguments were not provided:\n -i <DEV>" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack no-such-input-file)
|
|
|
|
"the input file can't be found"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-unpack "-i no-such-file -o" md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "Couldn't find input file" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack missing-output-file)
|
|
|
|
"the output file wasn't specified"
|
|
|
|
(with-empty-metadata (md)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-unpack "-i" md)
|
2020-06-09 17:33:39 +05:30
|
|
|
(assert-starts-with "error: The following required arguments were not provided:\n -o <FILE>" stderr))))
|
2020-05-26 15:25:03 +05:30
|
|
|
|
|
|
|
(define-scenario (thin-metadata-unpack garbage-input-file)
|
|
|
|
"the input file is just zeroes"
|
|
|
|
(with-empty-metadata (bad-pack)
|
|
|
|
(run-fail-rcv (_ stderr) (thin-metadata-unpack "-i " bad-pack "-o junk")
|
|
|
|
(assert-starts-with "Not a pack file." stderr))))
|
|
|
|
|
|
|
|
;;;-----------------------------------------------------------
|
|
|
|
;;; thin_metadata_pack/unpack end to end scenario
|
|
|
|
;;;-----------------------------------------------------------)
|
|
|
|
(define-scenario (thin-metadata-pack end-to-end)
|
|
|
|
"pack -> unpack recovers metadata"
|
|
|
|
(let ((pack-file "md.pack"))
|
|
|
|
(with-valid-metadata (md-in)
|
|
|
|
(with-empty-metadata (md-out)
|
|
|
|
(run-ok (thin-metadata-pack "-i" md-in "-o" pack-file))
|
|
|
|
(run-ok (thin-metadata-unpack "-i" pack-file "-o" md-out))
|
|
|
|
(run-ok-rcv (dump1 _) (thin-dump md-in)
|
|
|
|
(run-ok-rcv (dump2 _) (thin-dump md-out)
|
|
|
|
(assert-equal dump1 dump2)))))))
|
|
|
|
|
|
|
|
)
|