12fae26bdSAlan Somers#!/usr/local/bin/ksh93 -p
22fae26bdSAlan Somers#
32fae26bdSAlan Somers# CDDL HEADER START
42fae26bdSAlan Somers#
52fae26bdSAlan Somers# The contents of this file are subject to the terms of the
62fae26bdSAlan Somers# Common Development and Distribution License (the "License").
72fae26bdSAlan Somers# You may not use this file except in compliance with the License.
82fae26bdSAlan Somers#
92fae26bdSAlan Somers# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
102fae26bdSAlan Somers# or http://www.opensolaris.org/os/licensing.
112fae26bdSAlan Somers# See the License for the specific language governing permissions
122fae26bdSAlan Somers# and limitations under the License.
132fae26bdSAlan Somers#
142fae26bdSAlan Somers# When distributing Covered Code, include this CDDL HEADER in each
152fae26bdSAlan Somers# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
162fae26bdSAlan Somers# If applicable, add the following below this CDDL HEADER, with the
172fae26bdSAlan Somers# fields enclosed by brackets "[]" replaced with your own identifying
182fae26bdSAlan Somers# information: Portions Copyright [yyyy] [name of copyright owner]
192fae26bdSAlan Somers#
202fae26bdSAlan Somers# CDDL HEADER END
212fae26bdSAlan Somers#
222fae26bdSAlan Somers
232fae26bdSAlan Somers#
242fae26bdSAlan Somers# Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
252fae26bdSAlan Somers# Use is subject to license terms.
262fae26bdSAlan Somers
272fae26bdSAlan Somers. $STF_SUITE/tests/slog/slog.kshlib
282fae26bdSAlan Somers
292fae26bdSAlan Somers#################################################################################
302fae26bdSAlan Somers#
312fae26bdSAlan Somers# __stc_assertion_start
322fae26bdSAlan Somers#
332fae26bdSAlan Somers# ID: slog_014_pos
342fae26bdSAlan Somers#
352fae26bdSAlan Somers# DESCRIPTION:
362fae26bdSAlan Somers#	log device can survive when one of pool device get corrupted
372fae26bdSAlan Somers#
382fae26bdSAlan Somers# STRATEGY:
392fae26bdSAlan Somers#	1. Create pool with slog devices
402fae26bdSAlan Somers#	2. remove one disk
412fae26bdSAlan Somers#	3. Verify the log is fine
422fae26bdSAlan Somers#
432fae26bdSAlan Somers# TESTABILITY: explicit
442fae26bdSAlan Somers#
452fae26bdSAlan Somers# TEST_AUTOMATION_LEVEL: automated
462fae26bdSAlan Somers#
472fae26bdSAlan Somers# CODING_STATUS: COMPLETED (2009-05-26)
482fae26bdSAlan Somers#
492fae26bdSAlan Somers# __stc_assertion_end
502fae26bdSAlan Somers#
512fae26bdSAlan Somers################################################################################
522fae26bdSAlan Somers
532fae26bdSAlan Somersverify_runnable "global"
542fae26bdSAlan Somers
552fae26bdSAlan Somerslog_assert "log device can survive when one of the pool device get corrupted."
562fae26bdSAlan Somerslog_onexit cleanup
572fae26bdSAlan Somers
582fae26bdSAlan Somersfunction test_slog_survives_pool_corruption # <pooltype> <sparetype>
592fae26bdSAlan Somers{
602fae26bdSAlan Somers	typeset pooltype=$1
612fae26bdSAlan Somers	typeset sparetype=$2
622fae26bdSAlan Somers
632fae26bdSAlan Somers	# This only works for pools that have redundancy
642fae26bdSAlan Somers	[ -z "$pooltype" ] && return
652fae26bdSAlan Somers
662fae26bdSAlan Somers	create_pool $TESTPOOL $pooltype $VDEV $sparetype $SDEV log $LDEV
672fae26bdSAlan Somers
682fae26bdSAlan Somers	# Remove one of the pool device, then scrub to make the pool DEGRADED
692fae26bdSAlan Somers	log_must $RM -f $VDIR/a
702fae26bdSAlan Somers	log_must $ZPOOL scrub $TESTPOOL
712fae26bdSAlan Somers
722fae26bdSAlan Somers	# Check and verify pool status
732fae26bdSAlan Somers	log_must display_status $TESTPOOL
742fae26bdSAlan Somers	log_must $ZPOOL status $TESTPOOL 2>&1 >/dev/null
752fae26bdSAlan Somers
762fae26bdSAlan Somers	# Check that there is some status: field informing us of a
772fae26bdSAlan Somers	# problem.  The exact error string is unspecified.
782fae26bdSAlan Somers	log_must $ZPOOL status -v $TESTPOOL | $GREP "status:"
792fae26bdSAlan Somers	for l in $LDEV; do
802fae26bdSAlan Somers		log_must check_state $TESTPOOL $l ONLINE
812fae26bdSAlan Somers	done
822fae26bdSAlan Somers
832fae26bdSAlan Somers	destroy_pool $TESTPOOL
842fae26bdSAlan Somers	create_vdevs $VDIR/a
852fae26bdSAlan Somers}
862fae26bdSAlan Somersslog_foreach_nologtype test_slog_survives_pool_corruption
872fae26bdSAlan Somers
882fae26bdSAlan Somerslog_pass "log device can survive when one of the pool device get corrupted."
89