Print this page
7290 ZFS test suite needs to control what utilities it can run
Reviewed by: Dan Kimmel <dan.kimmel@delphix.com>
Reviewed by: Matthew Ahrens <mahrens@delphix.com>
*** 10,20 ****
# source. A copy of the CDDL is also available via the Internet at
# http://www.illumos.org/license/CDDL.
#
#
! # Copyright (c) 2014 by Delphix. All rights reserved.
#
#
# Description:
# Verify that holes can be written and read back correctly in ZFS.
--- 10,20 ----
# source. A copy of the CDDL is also available via the Internet at
# http://www.illumos.org/license/CDDL.
#
#
! # Copyright (c) 2014, 2016 by Delphix. All rights reserved.
#
#
# Description:
# Verify that holes can be written and read back correctly in ZFS.
*** 32,85 ****
verify_runnable "both"
testfile="$TESTDIR/testfile"
for bs in 512 1024 2048 4096 8192 16384 32768 65536 131072; do
! log_must $ZFS set recsize=$bs $TESTPOOL/$TESTFS
#
# Create combinations of holes and data to verify holes ending files
# and the like. (hhh, hhd, hdh...)
#
! log_must $MKHOLES -h 0:$((bs * 6)) $testfile
verify_holes_and_data_blocks $testfile 6 0
! log_must $RM $testfile
! log_must $MKHOLES -h 0:$((bs * 4)) -d $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must $RM $testfile
! log_must $MKHOLES -h 0:$((bs * 2)) -d $((bs * 2)):$((bs * 2)) \
-h $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must $RM $testfile
! log_must $MKHOLES -h 0:$((bs * 2)) -d $((bs * 2)):$((bs * 4)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must $RM $testfile
! log_must $MKHOLES -d 0:$((bs * 2)) -h $((bs * 2)):$((bs * 4)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must $RM $testfile
! log_must $MKHOLES -d 0:$((bs * 2)) -h $((bs * 2)):$((bs * 2)) \
-d $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must $RM $testfile
! log_must $MKHOLES -d 0:$((bs * 4)) -h $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must $RM $testfile
! log_must $MKHOLES -d 0:$((bs * 6)) $testfile
verify_holes_and_data_blocks $testfile 0 6
! log_must $RM $testfile
# Verify holes are correctly seen past the largefile limit.
len=$((1024**3 * 5))
nblks=$((len / bs))
! log_must $MKHOLES -h 0:$len -d $len:$bs $testfile
verify_holes_and_data_blocks $testfile $nblks 1
! log_must $RM $testfile
done
log_pass "Basic hole tests pass."
--- 32,85 ----
verify_runnable "both"
testfile="$TESTDIR/testfile"
for bs in 512 1024 2048 4096 8192 16384 32768 65536 131072; do
! log_must zfs set recsize=$bs $TESTPOOL/$TESTFS
#
# Create combinations of holes and data to verify holes ending files
# and the like. (hhh, hhd, hdh...)
#
! log_must mkholes -h 0:$((bs * 6)) $testfile
verify_holes_and_data_blocks $testfile 6 0
! log_must rm $testfile
! log_must mkholes -h 0:$((bs * 4)) -d $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must rm $testfile
! log_must mkholes -h 0:$((bs * 2)) -d $((bs * 2)):$((bs * 2)) \
-h $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must rm $testfile
! log_must mkholes -h 0:$((bs * 2)) -d $((bs * 2)):$((bs * 4)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must rm $testfile
! log_must mkholes -d 0:$((bs * 2)) -h $((bs * 2)):$((bs * 4)) $testfile
verify_holes_and_data_blocks $testfile 4 2
! log_must rm $testfile
! log_must mkholes -d 0:$((bs * 2)) -h $((bs * 2)):$((bs * 2)) \
-d $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must rm $testfile
! log_must mkholes -d 0:$((bs * 4)) -h $((bs * 4)):$((bs * 2)) $testfile
verify_holes_and_data_blocks $testfile 2 4
! log_must rm $testfile
! log_must mkholes -d 0:$((bs * 6)) $testfile
verify_holes_and_data_blocks $testfile 0 6
! log_must rm $testfile
# Verify holes are correctly seen past the largefile limit.
len=$((1024**3 * 5))
nblks=$((len / bs))
! log_must mkholes -h 0:$len -d $len:$bs $testfile
verify_holes_and_data_blocks $testfile $nblks 1
! log_must rm $testfile
done
log_pass "Basic hole tests pass."