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 2009 Sun Microsystems, Inc. All rights reserved. 24# Use is subject to license terms. 25# 26 27# 28# Copyright (c) 2017 by Delphix. All rights reserved. 29# 30 31. $STF_SUITE/include/libtest.shlib 32. $STF_SUITE/tests/functional/cli_root/zfs_mount/zfs_mount.cfg 33 34function force_unmount #dev 35{ 36 typeset dev=$1 37 38 ismounted $dev 39 if (( $? == 0 )); then 40 log_must zfs $unmountforce $dev 41 fi 42 return 0 43} 44 45# Create pool and ( fs | container | vol ) with the given parameters, 46# it'll destroy prior exist one that has the same name. 47 48function setup_filesystem #disklist #pool #fs #mntpoint #type #vdev 49{ 50 typeset disklist=$1 51 typeset pool=$2 52 typeset fs=${3##/} 53 typeset mntpoint=$4 54 typeset type=$5 55 typeset vdev=$6 56 57 if [[ -z $pool || -z $fs || -z $mntpoint ]]; then 58 log_note "Missing parameter: (\"$pool\", \"$fs\", \"$mntpoint\")" 59 return 1 60 fi 61 62 if is_global_zone && [[ -z $disklist ]] ; then 63 log_note "Missing disklist." 64 return 1 65 fi 66 67 if [[ $vdev != "" && \ 68 $vdev != "mirror" && \ 69 $vdev != "raidz" ]] ; then 70 71 log_note "Wrong vdev: (\"$vdev\")" 72 return 1 73 fi 74 75 poolexists $pool || \ 76 create_pool $pool $vdev $disklist 77 78 datasetexists $pool/$fs && \ 79 log_must cleanup_filesystem $pool $fs 80 81 rmdir $mntpoint > /dev/null 2>&1 82 if [[ ! -d $mntpoint ]]; then 83 log_must mkdir -p $mntpoint 84 fi 85 86 case "$type" in 87 'ctr') log_must zfs create -o mountpoint=$mntpoint $pool/$fs 88 ;; 89 'vol') log_must zfs create -V $VOLSIZE $pool/$fs 90 ;; 91 *) log_must zfs create -o mountpoint=$mntpoint $pool/$fs 92 ;; 93 esac 94 95 return 0 96} 97 98# Destroy ( fs | container | vol ) with the given parameters. 99function cleanup_filesystem #pool #fs 100{ 101 typeset pool=$1 102 typeset fs=${2##/} 103 typeset mtpt="" 104 105 if [[ -z $pool || -z $fs ]]; then 106 log_note "Missing parameter: (\"$pool\", \"$fs\")" 107 return 1 108 fi 109 110 if datasetexists "$pool/$fs" ; then 111 mtpt=$(get_prop mountpoint "$pool/$fs") 112 log_must zfs destroy -r $pool/$fs 113 114 [[ -d $mtpt ]] && \ 115 log_must rm -rf $mtpt 116 else 117 return 1 118 fi 119 120 return 0 121} 122 123# Make sure 'zfs mount' should display all ZFS filesystems currently mounted. 124# The results of 'zfs mount' and 'df -F zfs' should be identical. 125function verify_mount_display 126{ 127 typeset fs 128 129 for fs in $(zfs $mountcmd | awk '{print $1}') ; do 130 log_must mounted $fs 131 done 132 return 0 133} 134