1#!/bin/ksh -p
2#
3# CDDL HEADER START
4#
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.
8#
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.
13#
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]
19#
20# CDDL HEADER END
21#
22
23#
24# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
25# Use is subject to license terms.
26#
27
28#
29# Copyright (c) 2013, 2016 by Delphix. All rights reserved.
30# Copyright (c) 2018 George Melikov. All Rights Reserved.
31#
32
33. $STF_SUITE/include/libtest.shlib
34. $STF_SUITE/tests/functional/delegate/delegate_common.kshlib
35
36if is_illumos; then
37	# check svc:/network/nis/client:default state
38	# disable it if the state is ON
39	# and the state will be restored during cleanup.ksh
40	log_must rm -f $NISSTAFILE
41	if [[ "ON" == $(svcs -H -o sta svc:/network/nis/client:default) ]]; then
42		log_must svcadm disable -t svc:/network/nis/client:default
43		log_must touch $NISSTAFILE
44	fi
45fi
46
47if is_freebsd; then
48	# To pass user mount tests
49	log_must sysctl vfs.usermount=1
50fi
51
52cleanup_user_group
53
54# Create staff group and add two user to it
55log_must add_group $STAFF_GROUP
56log_must add_user $STAFF_GROUP $STAFF1
57log_must add_user $STAFF_GROUP $STAFF2
58
59# Create other group and add two user to it
60log_must add_group $OTHER_GROUP
61log_must add_user $OTHER_GROUP $OTHER1
62log_must add_user $OTHER_GROUP $OTHER2
63
64#
65# Verify the test user can execute the zfs utilities.  This may not
66# be possible due to default permissions on the user home directory.
67# This can be resolved granting group read access.
68#
69# chmod 0750 $HOME
70#
71user_run $STAFF1 zfs list
72if [ $? -ne 0 ]; then
73	log_unsupported "Test user $STAFF1 cannot execute zfs utilities"
74fi
75
76DISK=${DISKS%% *}
77
78if is_linux; then
79	log_must set_tunable64 ADMIN_SNAPSHOT 1
80fi
81
82default_volume_setup $DISK
83