xref: /freebsd/sys/contrib/openzfs/tests/zfs-tests/tests/functional/pam/setup.ksh (revision 8a62a2a5659d1839d8799b4274c04469d7f17c78)
1#!/bin/ksh -p
2# SPDX-License-Identifier: CDDL-1.0
3#
4# CDDL HEADER START
5#
6# The contents of this file are subject to the terms of the
7# Common Development and Distribution License (the "License").
8# You may not use this file except in compliance with the License.
9#
10# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
11# or https://opensource.org/licenses/CDDL-1.0.
12# See the License for the specific language governing permissions
13# and limitations under the License.
14#
15# When distributing Covered Code, include this CDDL HEADER in each
16# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
17# If applicable, add the following below this CDDL HEADER, with the
18# fields enclosed by brackets "[]" replaced with your own identifying
19# information: Portions Copyright [yyyy] [name of copyright owner]
20#
21# CDDL HEADER END
22#
23
24. $STF_SUITE/tests/functional/pam/utilities.kshlib
25
26command -v pamtester > /dev/null || log_unsupported "pam tests require the pamtester utility to be installed"
27[ -f "$pammodule" ] || log_unsupported "$pammodule missing"
28
29DISK=${DISKS%% *}
30create_pool $TESTPOOL "$DISK"
31
32log_must zfs create -o mountpoint="$TESTDIR" "$TESTPOOL/pam"
33log_must zfs create -o mountpoint="$TESTDIR-multi-home" "$TESTPOOL/pam-multi-home"
34log_must add_group pamtestgroup
35log_must add_user pamtestgroup ${username}
36log_must mkdir -p "$runstatedir"
37
38echo "testpass" | zfs create -o encryption=aes-256-gcm -o keyformat=passphrase -o keylocation=prompt "$TESTPOOL/pam/${username}"
39log_must zfs unmount "$TESTPOOL/pam/${username}"
40log_must zfs unload-key "$TESTPOOL/pam/${username}"
41echo "testpass" | zfs create -o encryption=aes-256-gcm -o keyformat=passphrase -o keylocation=prompt "$TESTPOOL/pam-multi-home/${username}"
42log_must zfs unmount "$TESTPOOL/pam-multi-home/${username}"
43log_must zfs unload-key "$TESTPOOL/pam-multi-home/${username}"
44
45for i in {1..$PAM_MULTI_HOME_COUNT} ; do
46       log_must zfs create -o mountpoint="$TESTDIR-multi-home$i" "$TESTPOOL/pam-multi-home$i"
47       echo "testpass" | zfs create -o encryption=aes-256-gcm -o keyformat=passphrase -o keylocation=prompt "$TESTPOOL/pam-multi-home$i/${username}"
48       log_must zfs unmount "$TESTPOOL/pam-multi-home$i/${username}"
49       log_must zfs unload-key "$TESTPOOL/pam-multi-home$i/${username}"
50done
51
52log_pass
53