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 }