xref: /freebsd/tests/sys/cddl/zfs/tests/hotplug/hotplug_001_pos.ksh (revision ac00d4d59b18a76c6148ca5d7439bb446d38da5c)
1#!/usr/local/bin/ksh93 -p
2#
3# CDDL HEADER START
4#
5# The contents of this file are subject to the terms of the
6# Common Development and Distribution License (the "License").
7# You may not use this file except in compliance with the License.
8#
9# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10# or http://www.opensolaris.org/os/licensing.
11# See the License for the specific language governing permissions
12# and limitations under the License.
13#
14# When distributing Covered Code, include this CDDL HEADER in each
15# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16# If applicable, add the following below this CDDL HEADER, with the
17# fields enclosed by brackets "[]" replaced with your own identifying
18# information: Portions Copyright [yyyy] [name of copyright owner]
19#
20# CDDL HEADER END
21#
22
23#
24# Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
25# Use is subject to license terms.
26
27. $STF_SUITE/tests/hotplug/hotplug.kshlib
28
29#################################################################################
30#
31# __stc_assertion_start
32#
33# ID: hotplug_001_pos
34#
35# DESCRIPTION:
36#	When removing a device from a redundant pool, the device's state will
37#	be indicated as 'REMOVED'.
38#
39# STRATEGY:
40#	1. Create mirror/raidz/raidz2 pool.
41#	2. Synchronise with device in the background.
42#	3. Remove one of device of pool.
43#	4. Detect removed devices status is 'REMOVED'.
44#	5. Detect no FMA faulty message.
45#
46# TESTABILITY: explicit
47#
48# TEST_AUTOMATION_LEVEL: automated
49#
50# CODING_STATUS: COMPLETED (2007-06-01)
51#
52# __stc_assertion_end
53#
54################################################################################
55
56log_assert "When removing a device from a redundant pool, the device's " \
57	"state will be indicated as 'REMOVED'."
58
59for type in "mirror" "raidz" "raidz2"; do
60	log_note "Start $type testing ..."
61	setup_testenv $type
62
63	log_must destroy_gnop $DISK0
64	wait_for 15 1 check_state $TESTPOOL ${DISK0}.nop 'REMOVED'
65	log_must check_state $TESTPOOL ${DISK0}.nop 'REMOVED'
66
67	log_must create_gnop $DISK0
68	cleanup_testenv $TESTPOOL
69done
70
71log_pass "When removing a device from a redundant pool, the device's " \
72	"state will be indicated as 'REMOVED'."
73