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 }