Sindbad~EG File Manager

Current Path : /usr/tests/sys/cddl/zfs/tests/hotspare/
Upload File :
Current File : /usr/tests/sys/cddl/zfs/tests/hotspare/hotspare_export_001_neg.ksh

#!/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