Mercurial > illumos > illumos-gate
view usr/src/test/zfs-tests/tests/functional/cli_root/zfs_mount/zfs_mount_006_pos.ksh @ 13899:0bcf78798346
3311 Want a test framework for arbitrary OS unit tests
3312 Add a testrunner package for OS unit tests
3313 Add a testrunner package to convert ZFS tests from STF
Reviewed by: Matt Ahrens <matthew.ahrens@delphix.com>
Reviewed by: Will Guyette <will.guyette@delphix.com>
Reviewed by: Dan Kimmel <dan.kimmel@delphix.com>
Reviewed by: Adam Leventhal <ahl@delphix.com>
Reviewed by: Henrik Mattson <henrik.mattson@delphix.com>
Reviewed by: Sonu Pillai <sonu.pillai@delphix.com>
Reviewed by: Christopher Siden <chris.siden@delphix.com>
Reviewed by: George Wilson <george.wilson@delphix.com>
Reviewed by: Richard Lowe <richlowe@richlowe.net>
Approved by: Richard Lowe <richlowe@richlowe.net>
author | John Wren Kennedy <john.kennedy@delphix.com> |
---|---|
date | Wed, 05 Dec 2012 22:04:50 -0500 |
parents | |
children |
line wrap: on
line source
#!/bin/ksh -p # # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License (the "License"). # You may not use this file except in compliance with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # # Copyright 2007 Sun Microsystems, Inc. All rights reserved. # Use is subject to license terms. # . $STF_SUITE/include/libtest.shlib . $STF_SUITE/tests/functional/cli_root/zfs_mount/zfs_mount.kshlib # # DESCRIPTION: # Invoke "zfs mount <filesystem>" with a filesystem # which mountpoint be the identical or the top of an existing one, # it will fail with a return code of 1 # # STRATEGY: # 1. Prepare an existing mounted filesystem. # 2. Setup a new filesystem and make sure that it is unmounted. # 3. Mount the new filesystem using the various combinations # - zfs set mountpoint=<identical path> <filesystem> # - zfs set mountpoint=<top path> <filesystem> # 4. Verify that mount failed with return code of 1. # verify_runnable "both" function cleanup { log_must force_unmount $TESTPOOL/$TESTFS datasetexists $TESTPOOL/$TESTFS1 && \ cleanup_filesystem $TESTPOOL $TESTFS1 [[ -d $TESTDIR ]] && \ log_must $RM -rf $TESTDIR log_must $ZFS set mountpoint=$TESTDIR $TESTPOOL/$TESTFS log_must force_unmount $TESTPOOL/$TESTFS return 0 } typeset -i ret=0 log_assert "Verify that '$ZFS $mountcmd <filesystem>' " \ "which mountpoint be the identical or the top of an existing one " \ "will fail with return code 1." log_onexit cleanup unmounted $TESTPOOL/$TESTFS || \ log_must force_unmount $TESTPOOL/$TESTFS [[ -d $TESTDIR ]] && \ log_must $RM -rf $TESTDIR typeset -i MAXDEPTH=3 typeset -i depth=0 typeset mtpt=$TESTDIR while (( depth < MAXDEPTH )); do mtpt=$mtpt/$depth (( depth = depth + 1)) done log_must $ZFS set mountpoint=$mtpt $TESTPOOL/$TESTFS log_must $ZFS $mountcmd $TESTPOOL/$TESTFS mounted $TESTPOOL/$TESTFS || \ log_unresolved "Filesystem $TESTPOOL/$TESTFS is unmounted" log_must $ZFS create $TESTPOOL/$TESTFS1 unmounted $TESTPOOL/$TESTFS1 || \ log_must force_unmount $TESTPOOL/$TESTFS1 while [[ -n $mtpt ]] ; do (( depth == MAXDEPTH )) && \ log_note "Verify that '$ZFS $mountcmd <filesystem>' " \ "which mountpoint be the identical of an existing one " \ "will fail with return code 1." log_must $ZFS set mountpoint=$mtpt $TESTPOOL/$TESTFS1 log_mustnot $ZFS $mountcmd $TESTPOOL/$TESTFS1 unmounted $TESTPOOL/$TESTFS1 || \ log_fail "Filesystem $TESTPOOL/$TESTFS1 is mounted." mtpt=${mtpt%/*} (( depth == MAXDEPTH )) && \ log_note "Verify that '$ZFS $mountcmd <filesystem>' " \ "which mountpoint be the top of an existing one " \ "will fail with return code 1." (( depth = depth - 1 )) done log_pass "'$ZFS $mountcmd <filesystem>' " \ "which mountpoint be the identical or the top of an existing one " \ "will fail with return code 1."