7290 ZFS test suite needs to control what utilities it can run
[unleashed.git] / usr / src / test / zfs-tests / tests / functional / cli_root / zfs / zfs_002_pos.ksh
blob7a4d3a0eafb65be1da7f2e96dad5934d7d362e33
1 #!/bin/ksh -p
3 # CDDL HEADER START
5 # The contents of this file are subject to the terms of the
6 # Common Development and Distribution License (the "License").
7 # You may not use this file except in compliance with the License.
9 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 # or http://www.opensolaris.org/os/licensing.
11 # See the License for the specific language governing permissions
12 # and limitations under the License.
14 # When distributing Covered Code, include this CDDL HEADER in each
15 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 # If applicable, add the following below this CDDL HEADER, with the
17 # fields enclosed by brackets "[]" replaced with your own identifying
18 # information: Portions Copyright [yyyy] [name of copyright owner]
20 # CDDL HEADER END
24 # Copyright 2009 Sun Microsystems, Inc. All rights reserved.
25 # Use is subject to license terms.
29 # Copyright (c) 2012, 2016 by Delphix. All rights reserved.
32 . $STF_SUITE/include/libtest.shlib
35 # DESCRIPTION:
36 # With ZFS_ABORT set, all zfs commands should be able to abort and generate a
37 # core file.
39 # STRATEGY:
40 # 1. Create an array of zfs command
41 # 2. Execute each command in the array
42 # 3. Verify the command aborts and generate a core file
45 verify_runnable "both"
47 function cleanup
49 unset ZFS_ABORT
51 if [[ -d $corepath ]]; then
52 rm -rf $corepath
54 for ds in $fs1 $fs $ctr; do
55 if datasetexists $ds; then
56 log_must zfs destroy -rRf $ds
58 done
61 log_assert "With ZFS_ABORT set, all zfs commands can abort and generate a " \
62 "core file."
63 log_onexit cleanup
65 #preparation work for testing
66 corepath=$TESTDIR/core
67 if [[ -d $corepath ]]; then
68 rm -rf $corepath
70 log_must mkdir $corepath
72 ctr=$TESTPOOL/$TESTCTR
73 log_must zfs create $ctr
75 fs=$ctr/$TESTFS
76 fs1=$ctr/$TESTFS1
77 snap=$fs@$TESTSNAP
78 clone=$ctr/$TESTCLONE
79 streamf=$corepath/s.$$
81 typeset cmds=("create $fs" "list $fs" "snapshot $snap" "set snapdir=hidden $fs" \
82 "get snapdir $fs" "rollback $snap" "inherit snapdir $fs" \
83 "rename $fs $fs-new" "rename $fs-new $fs" "unmount $fs" \
84 "mount $fs" "share $fs" "unshare $fs" "send $snap \>$streamf" \
85 "receive $fs1 \<$streamf" "clone $snap $clone" "promote $clone" \
86 "promote $fs" "destroy -rRf $fs")
88 typeset badparams=("" "create" "destroy" "snapshot" "rollback" "clone" \
89 "promote" "rename" "list -*" "set" "get -*" "inherit" "mount -A" \
90 "unmount" "share" "unshare" "send" "receive")
92 log_must coreadm -p ${corepath}/core.%f
93 log_must export ZFS_ABORT=yes
95 for subcmd in "${cmds[@]}" "${badparams[@]}"; do
96 zfs $subcmd >/dev/null 2>&1 && log_fail "$subcmd passed incorrectly."
97 corefile=${corepath}/core.zfs
98 if [[ ! -e $corefile ]]; then
99 log_fail "zfs $subcmd cannot generate core file with " \
100 "ZFS_ABORT set."
102 log_must rm -f $corefile
103 done
105 log_pass "With ZFS_ABORT set, zfs command can abort and generate core file " \
106 "as expected."