Index: projects/zfsd/head/tests/sys/cddl/zfs/tests/hotspare/hotspare_scrub_002_pos.ksh =================================================================== --- projects/zfsd/head/tests/sys/cddl/zfs/tests/hotspare/hotspare_scrub_002_pos.ksh (revision 292363) +++ projects/zfsd/head/tests/sys/cddl/zfs/tests/hotspare/hotspare_scrub_002_pos.ksh (revision 292364) @@ -1,118 +1,120 @@ #!/usr/local/bin/ksh93 -p # # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License (the "License"). # You may not use this file except in compliance with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # # Copyright 2013 Spectra Logic. All rights reserved. # Use is subject to license terms. # # . $STF_SUITE/tests/hotspare/hotspare.kshlib ################################################################################ # # __stc_assertion_start # # ID: hotspare_scrub_002_pos # # DESCRIPTION: # 'zpool scrub will scan spares as well as original devices' # # STRATEGY: # 1. Create a storage pool # 2. Add hot spare devices to the pool # 4. Replace one of the original devices with a spare # 5. Simulate errors on the spare # 6. Scrub the pool # 7. Verify that scrub detected the simulated errors # # TESTABILITY: explicit # # TEST_AUTOMATION_LEVEL: automated # # CODING STATUS: COMPLETED (2013-01-14) # # __stc_assertion_end # ############################################################################### verify_runnable "global" function cleanup { poolexists $TESTPOOL && destroy_pool $TESTPOOL partition_cleanup } # Returns the number of checksums errors detected on the given vdev function get_cksum #pool, vdev { typeset pool=$1 typeset vdev=$2 $ZPOOL status $pool | awk -v vdev=$vdev '$1~vdev {print $5; exit}' } function verify_assertion # odev { typeset odev=$1 log_must $ZPOOL replace $TESTPOOL $odev $sdev log_must check_state $TESTPOOL "$sdev" "INUSE" # corrupt out the $TESTPOOL to make sdev in use # Skip the first input block so we don't overwrite the vdev label log_must $DD if=/dev/zero bs=1024k count=63 oseek=1 conv=notrunc of=$sdev $SYNC - log_must $ZPOOL scrub $TESTPOOL + # The pool may already have started scrubbing, so don't assert this. + # Expected postconditions are checked below anyway. + $ZPOOL scrub $TESTPOOL while is_pool_scrubbing $TESTPOOL ; do $SLEEP 2 done # Verify that scrub detected the errors # Some vdevs (ie raidz1) will display the errors on the spare-0 line # instead of on the basic vdev line [[ $(get_cksum $TESTPOOL $sdev) > 0 ]] sdev_errors=$? [[ $(get_cksum $TESTPOOL "spare-0") > 0 ]] spare0_errors=$? log_must [ $sdev_errors -o $spare0_errors ] } log_assert "'zpool scrub' scans spare vdevs" log_onexit cleanup set_devs typeset odev="${devarray[3]}" typeset sdev="${devarray[0]}" # Don't test striped pools because they can't have spares set -A keywords "mirror" "raidz" "raidz2" for keyword in "${keywords[@]}" ; do setup_hotspares "$keyword" iterate_over_hotspares verify_assertion $odev destroy_pool "$TESTPOOL" done log_pass "'zpool scrub scans spare vdevs'"