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, 2016 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 # 93 # Get all the slog devices and status table like below 94 # 95 # mirror:/disks/d ONLINE mirror:/disks/e ONLINE stripe:/disks/f ONLINE 96 # 97 set -A dev_stat_tab $(zpool status -v $pool | nawk 'BEGIN {start=0} \ 98 /\tlogs/ {start=1} 99 /\tmirror/ || /\tspares/ || /^$/ {start=0} 100 (start==1) && /\t (\/|[a-zA-Z])/ \ 101 {print "stripe:" $1 " " $2} 102 (start==1) && /\t (\/|[a-zA-Z])/ \ 103 {print "mirror:" $1 " " $2} 104 # When hotspare is replacing 105 (start==1) && /\t (\/|[a-zA-Z])/ \ 106 {print "mirror:" $1 " " $2}' 107 ) 108 109 typeset -i i=0 110 typeset find=0 111 while (( i < ${#dev_stat_tab[@]} )); do 112 typeset dev=${dev_stat_tab[$i]} 113 typeset stat=${dev_stat_tab[((i+1))]} 114 115 case $dev in 116 stripe:$device) 117 if [[ "$type" == 'mirror' ]]; then 118 log_note "Unexpected type: mirror" 119 return 1 120 else 121 if [[ $stat != $status ]]; then 122 log_note "Status($stat) " \ 123 "!= Expected stat($status)" 124 return 1 125 fi 126 return 0 127 fi 128 ;; 129 mirror:$device) 130 if [[ -z "$type" || $type == 'stripe' ]]; then 131 log_note "Unexpected type: stripe" 132 return 1 133 else 134 if [[ $stat != $status ]]; then 135 log_note "Status($stat) " \ 136 "!= Expected stat($status)" 137 return 1 138 fi 139 return 0 140 fi 141 ;; 142 esac 143 144 ((i += 2)) 145 done 146 147 log_note "Can not find device: $device" 148 149 return 1 150} 151