1 #
2 # CDDL HEADER START
3 #
4 # The contents of this file are subject to the terms of the
5 # Common Development and Distribution License (the "License").
6 # You may not use this file except in compliance with the License.
7 #
8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 # or http://www.opensolaris.org/os/licensing.
10 # See the License for the specific language governing permissions
11 # and limitations under the License.
12 #
13 # When distributing Covered Code, include this CDDL HEADER in each
14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 # If applicable, add the following below this CDDL HEADER, with the
16 # fields enclosed by brackets "[]" replaced with your own identifying
17 # information: Portions Copyright [yyyy] [name of copyright owner]
18 #
19 # CDDL HEADER END
20 #
21
22 #
23 # Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 # Use is subject to license terms.
25 #
26
27 #
28 # Copyright (c) 2013 by Delphix. All rights reserved.
29 #
30
31 . $STF_SUITE/include/libtest.shlib
32 . $STF_SUITE/tests/functional/slog/slog.cfg
33
34 function cleanup
35 {
36 if datasetexists $TESTPOOL ; then
37 log_must $ZPOOL destroy -f $TESTPOOL
38 fi
39 if datasetexists $TESTPOOL2 ; then
40 log_must $ZPOOL destroy -f $TESTPOOL2
41 fi
42 }
43
44 #
45 # Try zpool status/iostat for given pool
46 #
47 # $1 pool
48 #
49 function display_status
50 {
51 typeset pool=$1
52
53 typeset -i ret=0
54 $ZPOOL status -xv $pool > /dev/null 2>&1
55 ret=$?
56
57 $ZPOOL iostat > /dev/null 2>&1
58 ((ret |= $?))
59
60 typeset mntpnt=$(get_prop mountpoint $pool)
61 $DD if=/dev/random of=$mntpnt/testfile.$$ &
62 typeset pid=$!
63
64 $ZPOOL iostat -v 1 3 > /dev/null
65 ((ret |= $?))
66
67 kill -9 $pid
68
69 return $ret
70 }
71
72 #
73 # Verify the give slog device have correct type and status
74 #
75 # $1 pool name
76 # $2 device name
77 # $3 device status
78 # $4 device type
79 #
80 function verify_slog_device
81 {
82 typeset pool=$1
83 typeset device=$2
84 typeset status=$3
85 typeset type=$4
86
87 if [[ -z $pool || -z $device || -z $status ]]; then
88 log_fail "Usage: verify_slog_device <pool> <device> " \
89 "<status> [type]"
90 fi
91
92 if [[ $WRAPPER == *"smi"* ]]; then
93 $ECHO $device | $EGREP "^c[0-F]+([td][0-F]+)+$" > /dev/null 2>&1
94 if (( $? == 0 )); then
95 device=${device}s2
96 fi
97 fi
98
99 #
100 # Get all the slog devices and status table like below
101 #
102 # mirror:/disks/d ONLINE mirror:/disks/e ONLINE stripe:/disks/f ONLINE
103 #
104 set -A dev_stat_tab $($ZPOOL status -v $pool | $NAWK 'BEGIN {start=0} \
105 /\tlogs/ {start=1}
106 /\tmirror/ || /\tspares/ || /^$/ {start=0}
107 (start==1) && /\t (\/|[a-zA-Z])/ \
108 {print "stripe:" $1 " " $2}
109 (start==1) && /\t (\/|[a-zA-Z])/ \
110 {print "mirror:" $1 " " $2}
111 # When hotspare is replacing
112 (start==1) && /\t (\/|[a-zA-Z])/ \
113 {print "mirror:" $1 " " $2}'
114 )
115
116 typeset -i i=0
117 typeset find=0
118 while (( i < ${#dev_stat_tab[@]} )); do
119 typeset dev=${dev_stat_tab[$i]}
120 typeset stat=${dev_stat_tab[((i+1))]}
121
122 case $dev in
123 stripe:$device)
124 if [[ "$type" == 'mirror' ]]; then
125 log_note "Unexpected type: mirror"
126 return 1
127 else
128 if [[ $stat != $status ]]; then
129 log_note "Status($stat) " \
130 "!= Expected stat($status)"
131 return 1
132 fi
133 return 0
134 fi
135 ;;
136 mirror:$device)
137 if [[ -z "$type" || $type == 'stripe' ]]; then
138 log_note "Unexpected type: stripe"
139 return 1
140 else
141 if [[ $stat != $status ]]; then
142 log_note "Status($stat) " \
143 "!= Expected stat($status)"
144 return 1
145 fi
146 return 0
147 fi
148 ;;
149 esac
150
151 ((i += 2))
152 done
153
154 log_note "Can not find device: $device"
155
156 return 1
157 }