]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - tests/sys/cddl/zfs/tests/slog/slog_012_neg.ksh
MFC r353117-r353118, r353281-r353282, r353284-r353289, r353309-r353310, r353360-r3533...
[FreeBSD/FreeBSD.git] / tests / sys / cddl / zfs / tests / slog / slog_012_neg.ksh
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 # $FreeBSD$
24
25 #
26 # Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
27 # Use is subject to license terms.
28 #
29 # ident "@(#)slog_012_neg.ksh   1.1     07/07/31 SMI"
30 #
31
32 . $STF_SUITE/tests/slog/slog.kshlib
33
34 #################################################################################
35 #
36 # __stc_assertion_start
37 #
38 # ID: slog_012_neg
39 #
40 # DESCRIPTION:
41 #       Pool can survive when one of mirror log device get corrupted
42 #
43 # STRATEGY:
44 #       1. Create pool with mirror slog devices
45 #       2. Make corrupted on one disk
46 #       3. Verify the pool is fine
47 #
48 # TESTABILITY: explicit
49 #
50 # TEST_AUTOMATION_LEVEL: automated
51 #
52 # CODING_STATUS: COMPLETED (2007-06-20)
53 #
54 # __stc_assertion_end
55 #
56 ################################################################################
57
58 verify_runnable "global"
59
60 log_assert "Pool can survive when one of mirror log device get corrupted."
61 log_onexit cleanup
62
63 function test_slog_mirror_corruption # <pooltype> <sparetype>
64 {
65         typeset pooltype=$1
66         typeset sparetype=$2
67
68         create_pool $TESTPOOL $type $VDEV $spare $SDEV log mirror $LDEV 
69
70         mntpnt=$(get_prop mountpoint $TESTPOOL)
71         #
72         # Create file in pool to trigger writing in slog devices
73         #
74         log_must $DD if=/dev/urandom of=$mntpnt/testfile.${TESTCASE_ID} count=100
75
76         ldev=$(random_get $LDEV)
77         eval `$STAT -s $ldev`
78         log_must $TRUNCATE -s0 $ldev
79         log_must $TRUNCATE -s $st_size $ldev
80         log_must $ZPOOL scrub $TESTPOOL
81
82         log_must display_status $TESTPOOL
83         log_must verify_slog_device $TESTPOOL $ldev UNAVAIL mirror
84
85         destroy_pool $TESTPOOL
86 }
87 slog_foreach_nologtype test_slog_mirror_corruption
88
89 log_pass "Pool can survive when one of mirror log device get corrupted."