Sindbad~EG File Manager
#!/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
#
# $FreeBSD$
#
# Copyright 2009 Sun Microsystems, Inc. All rights reserved.
# Use is subject to license terms.
#
# ident "@(#)hotspare_export_001_neg.ksh 1.2 09/06/22 SMI"
#
. $STF_SUITE/tests/hotspare/hotspare.kshlib
################################################################################
#
# __stc_assertion_start
#
# ID: hotspare_export_001_neg
#
# DESCRIPTION:
# If 2 storage pools have shared hotspares, if the shared hotspare was used by
# one of the pool, the export of the pool that use hotspare will fail.
#
# STRATEGY:
# 1. Create 2 storage pools with hot spares shared.
# 2. Fail one vdev in one pool to make the hotspare in use.
# 3. Export the pool that currently use the hotspare
# 4. Verify the export will failed with warning message.
# 5. Verify export -f will success.
#
# TESTABILITY: explicit
#
# TEST_AUTOMATION_LEVEL: automated
#
# CODING STATUS: COMPLETED (2008-12-12)
#
# __stc_assertion_end
#
###############################################################################
verify_runnable "global"
function cleanup
{
if poolexists $TESTPOOL ; then
destroy_pool $TESTPOOL
else
$ZPOOL import -d $HOTSPARE_TMPDIR -f | $GREP \
"pool: $TESTPOOL">/dev/null 2>&1
if (( $? == 0 )); then
log_must $ZPOOL import -d $HOTSPARE_TMPDIR -f $TESTPOOL
destroy_pool $TESTPOOL
fi
fi
poolexists $TESTPOOL1 && \
destroy_pool $TESTPOOL1
partition_cleanup
}
log_onexit cleanup
function verify_assertion # type, dev
{
typeset pool_type=$1
typeset hotspare=$2
typeset err_dev=${devarray[3]}
typeset pool_dev="${devarray[6]}"
typeset mntp=$(get_prop mountpoint $TESTPOOL)
create_pool $TESTPOOL1 $pool_dev spare $hotspare
zpool replace $TESTPOOL $err_dev $hotspare
log_must check_hotspare_state "$TESTPOOL" "$hotspare" "INUSE"
log_must $ZPOOL status $TESTPOOL
log_must $ZPOOL status $TESTPOOL1
log_mustnot $ZPOOL export $TESTPOOL
log_must $ZPOOL export -f $TESTPOOL
log_must $ZPOOL import -d $HOTSPARE_TMPDIR -f $TESTPOOL
destroy_pool $TESTPOOL
destroy_pool $TESTPOOL1
}
log_onexit cleanup
log_assert "export pool that using shared hotspares will fail"
set_devs
typeset share_spare="${devarray[0]}"
set -A my_keywords "mirror" "raidz1" "raidz2"
for keyword in "${my_keywords[@]}" ; do
setup_hotspares $keyword $share_spare
verify_assertion $keyword $share_spare
done
log_pass "export pool that using shared hotspares will fail"
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists