d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#!/bin/ksh -p
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# CDDL HEADER START
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# The contents of this file are subject to the terms of the
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# Common Development and Distribution License (the "License").
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# You may not use this file except in compliance with the License.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# or http://www.opensolaris.org/os/licensing.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# See the License for the specific language governing permissions
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# and limitations under the License.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# When distributing Covered Code, include this CDDL HEADER in each
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# If applicable, add the following below this CDDL HEADER, with the
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# fields enclosed by brackets "[]" replaced with your own identifying
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# information: Portions Copyright [yyyy] [name of copyright owner]
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# CDDL HEADER END
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# Copyright 2007 Sun Microsystems, Inc. All rights reserved.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# Use is subject to license terms.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy# Copyright (c) 2012, 2016 by Delphix. All rights reserved.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy. $STF_SUITE/include/libtest.shlib
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy. $STF_SUITE/tests/functional/cli_root/zpool_clear/zpool_clear.cfg
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# DESCRIPTION:
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# Verify 'zpool clear' can clear pool errors.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# STRATEGY:
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# 1. Create various configuration pools
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# 2. Make errors to pool
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# 3. Use zpool clear to clear errors
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy# 4. Verify the errors has been cleared.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyverify_runnable "global"
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfunction cleanup
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy{
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy poolexists $TESTPOOL1 && \
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool destroy -f $TESTPOOL1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy for file in `ls $TESTDIR/file.*`; do
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must rm -f $file
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy done
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy}
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedylog_assert "Verify 'zpool clear' can clear errors of a storage pool."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedylog_onexit cleanup
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy#make raw files to create various configuration pools
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedytypeset -i i=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedywhile (( i < 3 )); do
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must mkfile $FILESIZE $TESTDIR/file.$i
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( i = i + 1 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedydone
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfbase=$TESTDIR/file
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyset -A poolconf "mirror $fbase.0 $fbase.1 $fbase.2" \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy "raidz1 $fbase.0 $fbase.1 $fbase.2" \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy "raidz2 $fbase.0 $fbase.1 $fbase.2"
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfunction check_err # <pool> [<vdev>]
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy{
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset pool=$1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy shift
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if (( $# > 0 )); then
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset checkvdev=$1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy else
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset checkvdev=""
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i errnum=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset c_read=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset c_write=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset c_cksum=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset tmpfile=/var/tmp/file.$$
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset healthstr="pool '$pool' is healthy"
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy typeset output="`zpool status -x $pool`"
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy [[ "$output" == "$healthstr" ]] && return $errnum
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy zpool status -x $pool | grep -v "^$" | grep -v "pool:" \
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy | grep -v "state:" | grep -v "config:" \
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy | grep -v "errors:" > $tmpfile
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset line
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i fetchbegin=1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy while read line; do
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if (( $fetchbegin != 0 )); then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy echo $line | grep "NAME" >/dev/null 2>&1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( $? == 0 )) && (( fetchbegin = 0 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy continue
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if [[ -n $checkvdev ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy echo $line | grep $checkvdev >/dev/null 2>&1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( $? != 0 )) && continue
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_read=`echo $line | awk '{print $3}'`
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_write=`echo $line | awk '{print $4}'`
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_cksum=`echo $line | awk '{print $5}'`
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if [ $c_read != 0 ] || [ $c_write != 0 ] || \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy [ $c_cksum != 0 ]
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy then
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( errnum = errnum + 1 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy break
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_read=`echo $line | awk '{print $3}'`
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_write=`echo $line | awk '{print $4}'`
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy c_cksum=`echo $line | awk '{print $5}'`
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if [ $c_read != 0 ] || [ $c_write != 0 ] || \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy [ $c_cksum != 0 ]
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy then
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( errnum = errnum + 1 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy done <$tmpfile
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy return $errnum
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy}
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfunction do_testing #<clear type> <vdevs>
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy{
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset FS=$TESTPOOL1/fs
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset file=/$FS/f
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset type=$1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy shift
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset vdev="$@"
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool create -f $TESTPOOL1 $vdev
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zfs create $FS
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy # Fully fill up the zfs filesystem in order to make data block errors
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy # zfs filesystem
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i ret=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i i=0
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy while true ; do
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy file_write -o create -f $file.$i -b $BLOCKSZ -c $NUM_WRITES
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ret=$?
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( $ret != 0 )) && break
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( i = i + 1 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy done
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy (( $ret != 28 )) && log_fail "file_write fails to fully fill up the $FS."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #Make errors to the testing pool by overwrite the vdev device with
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #/usr/bin/dd command. We donot want to have a full overwrite. That
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #may cause the system panic. So, we should skip the vdev label space.
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy #
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( i = $RANDOM % 3 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i wcount=0
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy typeset -i size
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy case $FILESIZE in
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy *g|*G)
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( size = ${FILESIZE%%[g|G]} ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( wcount = size*1024*1024 - 512 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ;;
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy *m|*M)
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( size = ${FILESIZE%%[m|M]} ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( wcount = size*1024 - 512 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ;;
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy *k|*K)
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( size = ${FILESIZE%%[k|K]} ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( wcount = size - 512 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ;;
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy *)
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy (( wcount = FILESIZE/1024 - 512 ))
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ;;
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy esac
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy dd if=/dev/zero of=$fbase.$i seek=512 bs=1024 count=$wcount conv=notrunc \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy > /dev/null 2>&1
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must sync
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool scrub $TESTPOOL1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy # Wait for the completion of scrub operation
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy while is_pool_scrubbing $TESTPOOL1; do
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy sleep 1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy done
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy check_err $TESTPOOL1 && \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy log_fail "No error generated."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if [[ $type == "device" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool clear $TESTPOOL1 $fbase.$i
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ! check_err $TESTPOOL1 $fbase.$i && \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy log_fail "'zpool clear' fails to clear error for $fbase.$i device."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy if [[ $type == "pool" ]]; then
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool clear $TESTPOOL1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy ! check_err $TESTPOOL1 && \
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy log_fail "'zpool clear' fails to clear error for pool $TESTPOOL1."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy fi
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
1d32ba663e202c24a5a1f2e5aef83fffb447cb7fJohn Wren Kennedy log_must zpool destroy $TESTPOOL1
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy}
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedylog_note "'zpool clear' clears leaf-device error."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfor devconf in "${poolconf[@]}"; do
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy do_testing "device" $devconf
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedydone
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedylog_note "'zpool clear' clears top-level pool error."
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedyfor devconf in "${poolconf[@]}"; do
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy do_testing "pool" $devconf
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedydone
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedy
d583b39bfb4e2571d3e41097c5c357ffe353ad45John Wren Kennedylog_pass "'zpool clear' clears pool errors as expected."