canmount_002_pos.ksh revision d583b39bfb4e2571d3e41097c5c357ffe353ad45
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# CDDL HEADER START
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# The contents of this file are subject to the terms of the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Common Development and Distribution License (the "License").
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# You may not use this file except in compliance with the License.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# See the License for the specific language governing permissions
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# and limitations under the License.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# When distributing Covered Code, include this CDDL HEADER in each
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# If applicable, add the following below this CDDL HEADER, with the
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# fields enclosed by brackets "[]" replaced with your own identifying
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# information: Portions Copyright [yyyy] [name of copyright owner]
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# CDDL HEADER END
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Copyright 2009 Sun Microsystems, Inc. All rights reserved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Use is subject to license terms.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Copyright (c) 2012 by Delphix. All rights reserved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync. $STF_SUITE/tests/functional/cli_root/zfs_set/zfs_set_common.kshlib
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# DESCRIPTION:
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Setting valid canmount to filesystem, it is successful.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# Whatever is set to volume or snapshot, it is failed.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# 'zfs set canmount=noauto <fs>'
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# 1. Setup a pool and create fs, volume, snapshot clone within it.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# 2. Set canmount=noauto for each dataset and check the retuen value
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# and check if it still can be mounted by mount -a.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync# 3. mount each dataset(except volume) to see if it can be mounted.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync "$TESTPOOL/$TESTFS" "$TESTPOOL/$TESTCTR" "$TESTPOOL/$TESTCLONE"
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync "$TESTPOOL/$TESTVOL" "$TESTPOOL/$TESTFS@$TESTSNAP" \
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync "$TESTPOOL/$TESTVOL@$TESTSNAP" "$TESTPOOL/$TESTCLONE1"
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync "$TESTPOOL/$TESTFS@$TESTSNAP" "$TESTPOOL/$TESTVOL@$TESTSNAP"
log_must $ZFS set mountpoint=${old_mnt[i]} $ds
log_must $ZFS set canmount=${old_canmount[i]} $ds
if datasetexists $ds; then
if [[ -d $mntp ]]; then
if snapexists $TESTPOOL/$TESTFS@$TESTSNAP ; then
if snapexists $TESTPOOL/$TESTVOL@$TESTSNAP ; then
if [[ -d $tmpmnt ]]; then
set -A old_mnt
set -A old_canmount
typeset ds
ds=${dataset_pos[i]}
dataset=${dataset_pos[i]}