diff usr/src/test/zfs-tests/tests/functional/acl/nontrivial/zfs_acl_chmod_001_neg.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 diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/usr/src/test/zfs-tests/tests/functional/acl/nontrivial/zfs_acl_chmod_001_neg.ksh	Wed Dec 05 22:04:50 2012 -0500
@@ -0,0 +1,131 @@
+#!/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 2009 Sun Microsystems, Inc.  All rights reserved.
+# Use is subject to license terms.
+#
+
+. $STF_SUITE/tests/functional/acl/acl_common.kshlib
+
+#
+# DESCRIPTION:
+#	Verify  1) Illegal options to chmod should fail.
+#		2) Delete all the ACE will lead to fail.
+#		3) Add ACE exceed 1024 will cause to fail.
+#
+# STRATEGY:
+#	1. Loop root and non-root users
+#	2. Verify all kinds of illegal option will lead to chmod failed.
+#	3. Verify 'chmod A0-' will fail when try to delete all the ACE.
+#	4. Verify 'chmod A+' will succeed when the ACE number exceed 1024.
+#
+
+verify_runnable "both"
+
+log_assert "Verify illegal operating to ACL, it will fail."
+log_onexit cleanup
+
+function err_opts #node
+{
+	typeset A_opts="+A@ -A#- +A% =A^ =A# =A@ +A#\ asd \
+			A+@ A-#- A+% A=^ A=# A=@ A+#"
+
+	log_note "Illegal option to chmod should fail."
+	for A in ${A_opts[@]}; do
+		log_mustnot usr_exec $CHMOD ${A}owner@:read_data:allow $node
+		log_mustnot usr_exec $CHMOD A+ asd owner@:execute:deny $node
+	done
+
+	typeset type_opts="everyone groups owner user@ users"
+	for tp in ${type_opts[@]}; do
+		log_mustnot usr_exec $CHMOD A+$tp:read_data:deny $node
+	done
+
+	return 0
+}
+
+function del_all_ACE #node
+{
+	typeset node=$1
+	typeset -i cnt
+
+	cnt=$(count_ACE $node)
+	while (( cnt > 0 )); do
+		if (( cnt == 1 )); then
+			log_mustnot $CHMOD A0- $node
+		else
+			log_must $CHMOD A0- $node
+		fi
+
+		(( cnt -= 1 ))
+	done
+
+	return 0
+}
+
+function exceed_max_ACE #node
+{
+	typeset node=$1
+	typeset -i max=1024
+	typeset -i cnt
+
+	cnt=$(count_ACE $node)
+
+	# One more ACE exceed the max limitation.
+	(( max = max - cnt + 1 ))
+	while (( max > 0 )); do
+		if (( max == 1 )); then
+			log_mustnot $CHMOD A+owner@:read_data:allow $node
+		else
+			$CHMOD A+owner@:read_data:allow $node
+			if (($? != 0)); then
+				((cnt = 1024 - max))
+				log_fail "Add No.$cnt ACL item failed."
+			fi
+		fi
+
+		(( max -= 1 ))
+	done
+
+	return 0
+}
+
+typeset node
+typeset func_name="err_opts del_all_ACE exceed_max_ACE"
+
+for usr in "root" "$ZFS_ACL_STAFF1"; do
+	log_must set_cur_usr $usr
+
+	for node in $testfile $testdir; do
+		log_must usr_exec $TOUCH $testfile
+		log_must usr_exec $MKDIR $testdir
+
+		for func in $func_name; do
+			log_must eval "$func $node"
+		done
+
+		log_must usr_exec $RM -rf $testfile $testdir
+	done
+done
+
+log_pass "Verify illegal operating to ACL passed."