[functional-tests] (thin create devices-in-reverse-order)
This commit is contained in:
parent
324d17981a
commit
2fe7a884a2
@ -8,6 +8,7 @@
|
|||||||
(functional-tests)
|
(functional-tests)
|
||||||
(fmt fmt)
|
(fmt fmt)
|
||||||
(list-utils)
|
(list-utils)
|
||||||
|
(logging)
|
||||||
(loops)
|
(loops)
|
||||||
(prefix (parser-combinators) p:)
|
(prefix (parser-combinators) p:)
|
||||||
(process)
|
(process)
|
||||||
@ -121,6 +122,7 @@
|
|||||||
(dm-device-path dev))))
|
(dm-device-path dev))))
|
||||||
((dev size)
|
((dev size)
|
||||||
(run-ok (dd-cmd "if=/dev/zero"
|
(run-ok (dd-cmd "if=/dev/zero"
|
||||||
|
"oflag=direct"
|
||||||
(string-append "of=" (dm-device-path dev))
|
(string-append "of=" (dm-device-path dev))
|
||||||
"bs=512" (fmt #f "count=" (to-sectors size)))))))
|
"bs=512" (fmt #f "count=" (to-sectors size)))))))
|
||||||
|
|
||||||
@ -159,11 +161,11 @@
|
|||||||
(set! nr (+ nr 1))
|
(set! nr (+ nr 1))
|
||||||
name))))
|
name))))
|
||||||
|
|
||||||
(define (with-pool-fn md-table data-table block-size fn)
|
(define (with-pool-fn md-table data-table block-size opts fn)
|
||||||
(with-devices ((md (generate-dev-name) "" md-table)
|
(with-devices ((md (generate-dev-name) "" md-table)
|
||||||
(data (generate-dev-name) "" data-table))
|
(data (generate-dev-name) "" data-table))
|
||||||
(zero-dev md (kilo 4))
|
(zero-dev md (kilo 4))
|
||||||
(let ((ptable (pool-table md data block-size (thin-pool-options))))
|
(let ((ptable (pool-table md data block-size opts)))
|
||||||
(with-device (pool (generate-dev-name) "" ptable)
|
(with-device (pool (generate-dev-name) "" ptable)
|
||||||
(fn pool)))))
|
(fn pool)))))
|
||||||
|
|
||||||
@ -173,6 +175,13 @@
|
|||||||
(with-pool-fn md-table
|
(with-pool-fn md-table
|
||||||
data-table
|
data-table
|
||||||
block-size
|
block-size
|
||||||
|
(thin-pool-options)
|
||||||
|
(lambda (pool) b1 b2 ...)))
|
||||||
|
((_ (pool md-table data-table block-size opts) b1 b2 ...)
|
||||||
|
(with-pool-fn md-table
|
||||||
|
data-table
|
||||||
|
block-size
|
||||||
|
opts
|
||||||
(lambda (pool) b1 b2 ...)))))
|
(lambda (pool) b1 b2 ...)))))
|
||||||
|
|
||||||
(define-syntax with-default-pool
|
(define-syntax with-default-pool
|
||||||
@ -183,11 +192,15 @@
|
|||||||
(kilo 64))
|
(kilo 64))
|
||||||
b1 b2 ...))))
|
b1 b2 ...))))
|
||||||
|
|
||||||
(define (default-md-table)
|
(define default-md-table
|
||||||
(list ((mk-fast-allocator) (meg 32))))
|
(case-lambda
|
||||||
|
(() (default-md-table (meg 32)))
|
||||||
|
((size) (list ((mk-fast-allocator) size)))))
|
||||||
|
|
||||||
(define (default-data-table size)
|
(define default-data-table
|
||||||
(list ((mk-slow-allocator) size)))
|
(case-lambda
|
||||||
|
(() (default-data-table (gig 10)))
|
||||||
|
((size) (list ((mk-slow-allocator) size)))))
|
||||||
|
|
||||||
(define (thin-table pool id size)
|
(define (thin-table pool id size)
|
||||||
(list
|
(list
|
||||||
@ -270,7 +283,7 @@
|
|||||||
(if (pool-status-discard-passdown status) "discard-passdown, " "")
|
(if (pool-status-discard-passdown status) "discard-passdown, " "")
|
||||||
(if (pool-status-block-zeroing status) "block-zero, " "")
|
(if (pool-status-block-zeroing status) "block-zero, " "")
|
||||||
"io-mode: " (pool-status-io-mode status) ", "
|
"io-mode: " (pool-status-io-mode status) ", "
|
||||||
"no-space-behaviour: " (pool-status-no-space-behaviour status) ", ")))
|
"no-space-behaviour: " (pool-status-no-space-behaviour status))))
|
||||||
|
|
||||||
(define digit (p:charset "0123456789"))
|
(define digit (p:charset "0123456789"))
|
||||||
|
|
||||||
@ -577,6 +590,25 @@
|
|||||||
(kilo 64))
|
(kilo 64))
|
||||||
#t)))
|
#t)))
|
||||||
|
|
||||||
|
;; Chasing a bug in btree_split_beneath()
|
||||||
|
(define-dm-scenario (thin create devices-in-reverse-order)
|
||||||
|
"Keep adding a key that's lower than what's in the tree."
|
||||||
|
(with-pool (pool (default-md-table (gig 1))
|
||||||
|
(default-data-table)
|
||||||
|
(kilo 64))
|
||||||
|
(let ((count 10000))
|
||||||
|
(let loop ((n count))
|
||||||
|
(unless (zero? n)
|
||||||
|
(info "creating thin " n)
|
||||||
|
(create-thin pool n)
|
||||||
|
(loop (- n 2))))
|
||||||
|
;; Check they're all still there
|
||||||
|
(let loop ((n count))
|
||||||
|
(unless (zero? n)
|
||||||
|
(info "deleting thin " n)
|
||||||
|
(delete-thin pool n)
|
||||||
|
(loop (- n 2)))))))
|
||||||
|
|
||||||
;;;-----------------------------------------------------------
|
;;;-----------------------------------------------------------
|
||||||
;;; Thin deletion scenarios
|
;;; Thin deletion scenarios
|
||||||
;;;-----------------------------------------------------------
|
;;;-----------------------------------------------------------
|
||||||
@ -629,5 +661,19 @@
|
|||||||
(assert-pool-used-data pool (kilo 64) thin-size)
|
(assert-pool-used-data pool (kilo 64) thin-size)
|
||||||
(delete-thin pool 0)
|
(delete-thin pool 0)
|
||||||
(assert-pool-used-data pool (kilo 64) (sectors 0)))))
|
(assert-pool-used-data pool (kilo 64) (sectors 0)))))
|
||||||
|
|
||||||
|
(define-dm-scenario (thin delete after-no-space)
|
||||||
|
"You can delete after the pool has run out of data space"
|
||||||
|
(with-pool (pool (default-md-table)
|
||||||
|
(default-data-table (meg 128))
|
||||||
|
(kilo 64)
|
||||||
|
(thin-pool-options error-if-no-space skip-block-zeroing))
|
||||||
|
(with-new-thin (thin pool 0 (gig 1))
|
||||||
|
;;(assert-raises (zero-dev thin)))
|
||||||
|
(zero-dev thin))
|
||||||
|
(fmt #t (fmt-pool-status (get-pool-status pool)))
|
||||||
|
(assert-pool-used-data pool (kilo 64) (meg 128))
|
||||||
|
(delete-thin pool 0)
|
||||||
|
(assert-pool-used-data pool (kilo 64) (sectors 0))))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -49,6 +49,7 @@
|
|||||||
(import (chezscheme)
|
(import (chezscheme)
|
||||||
(disk-units)
|
(disk-units)
|
||||||
(fmt fmt)
|
(fmt fmt)
|
||||||
|
(logging)
|
||||||
(srfi s8 receive)
|
(srfi s8 receive)
|
||||||
(utils))
|
(utils))
|
||||||
|
|
||||||
@ -293,6 +294,7 @@
|
|||||||
(define load
|
(define load
|
||||||
(foreign-procedure "dm_load" ((* DMIoctlInterface) string (* Target)) int))
|
(foreign-procedure "dm_load" ((* DMIoctlInterface) string (* Target)) int))
|
||||||
|
|
||||||
|
(info dev " <- " targets)
|
||||||
(let* ((ctargets (build-c-targets targets)))
|
(let* ((ctargets (build-c-targets targets)))
|
||||||
(ensure-free-ctargets ctargets
|
(ensure-free-ctargets ctargets
|
||||||
(unless (zero? (load (current-dm-interface) (dm-device-name dev) ctargets))
|
(unless (zero? (load (current-dm-interface) (dm-device-name dev) ctargets))
|
||||||
|
Loading…
Reference in New Issue
Block a user