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