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 34function 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# 49function 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# 80function 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} 158