diff options
author | Stefan Schubert <schubi@suse.de> | 2022-11-15 13:55:40 +0100 |
---|---|---|
committer | Stefan Schubert <stefan@gefluegelhof-schubert.de> | 2022-12-07 16:24:09 +0100 |
commit | e4917734c63ef6e887b3c4760771a14f75b9eb1f (patch) | |
tree | ed56bd49808fbe0fceefe1777ec980ac6d9f72c3 /xtests | |
parent | 5c1d6301fe872d5954de5e4ddf74adec9711c177 (diff) | |
download | pam-e4917734c63ef6e887b3c4760771a14f75b9eb1f.tar.gz pam-e4917734c63ef6e887b3c4760771a14f75b9eb1f.tar.bz2 pam-e4917734c63ef6e887b3c4760771a14f75b9eb1f.zip |
pam_shells: Added xtest test case
Test case for checking pam_authenticate in pam_shells.
Diffstat (limited to 'xtests')
-rw-r--r-- | xtests/Makefile.am | 4 | ||||
-rwxr-xr-x | xtests/run-xtests.sh | 7 | ||||
-rw-r--r-- | xtests/shells.conf | 3 | ||||
-rw-r--r-- | xtests/tst-pam_shells.c | 68 | ||||
-rw-r--r-- | xtests/tst-pam_shells.pamd | 2 | ||||
-rwxr-xr-x | xtests/tst-pam_shells.sh | 11 |
6 files changed, 94 insertions, 1 deletions
diff --git a/xtests/Makefile.am b/xtests/Makefile.am index 70f8441e..acf97469 100644 --- a/xtests/Makefile.am +++ b/xtests/Makefile.am @@ -25,6 +25,7 @@ EXTRA_DIST = run-xtests.sh tst-pam_dispatch1.pamd tst-pam_dispatch2.pamd \ tst-pam_succeed_if1.pamd tst-pam_succeed_if1.sh \ group.conf tst-pam_group1.pamd tst-pam_group1.sh \ tst-pam_authfail.pamd tst-pam_authsucceed.pamd \ + tst-pam_shells.pamd shells.conf tst-pam_shells.sh \ tst-pam_substack1.pamd tst-pam_substack1a.pamd tst-pam_substack1.sh \ tst-pam_substack2.pamd tst-pam_substack2a.pamd tst-pam_substack2.sh \ tst-pam_substack3.pamd tst-pam_substack3a.pamd tst-pam_substack3.sh \ @@ -43,7 +44,8 @@ XTESTS = tst-pam_dispatch1 tst-pam_dispatch2 tst-pam_dispatch3 \ tst-pam_access1 tst-pam_access2 tst-pam_access3 \ tst-pam_access4 tst-pam_limits1 tst-pam_succeed_if1 \ tst-pam_group1 tst-pam_authfail tst-pam_authsucceed \ - tst-pam_pwhistory1 tst-pam_time1 tst-pam_motd + tst-pam_pwhistory1 tst-pam_time1 tst-pam_motd \ + tst-pam_shells NOSRCTESTS = tst-pam_substack1 tst-pam_substack2 tst-pam_substack3 \ tst-pam_substack4 tst-pam_substack5 tst-pam_assemble_line1 diff --git a/xtests/run-xtests.sh b/xtests/run-xtests.sh index ff9a4dc1..e580e0ab 100755 --- a/xtests/run-xtests.sh +++ b/xtests/run-xtests.sh @@ -22,6 +22,10 @@ for config in access.conf group.conf time.conf limits.conf ; do mv /etc/security/$config /etc/security/$config-pam-xtests install -m 644 "${SRCDIR}"/$config /etc/security/$config done +[ -f /etc/shells ] && + mv /etc/shells /etc/shells-pam-xtests +install -m 644 "${SRCDIR}"/shells.conf /etc/shells + [ -f /etc/security/opasswd ] && mv /etc/security/opasswd /etc/security/opasswd-pam-xtests @@ -58,6 +62,9 @@ for config in access.conf group.conf time.conf limits.conf opasswd ; do fi done +[ -f "/etc/shells-pam-xtests" ] && + mv /etc/shells-pam-xtests /etc/shells + if test "$failed" -ne 0; then echo "===================" echo "$failed of $all tests failed" diff --git a/xtests/shells.conf b/xtests/shells.conf new file mode 100644 index 00000000..74776e68 --- /dev/null +++ b/xtests/shells.conf @@ -0,0 +1,3 @@ +/bin/ash +/bin/testbash +/bin/csh diff --git a/xtests/tst-pam_shells.c b/xtests/tst-pam_shells.c new file mode 100644 index 00000000..b6ba938e --- /dev/null +++ b/xtests/tst-pam_shells.c @@ -0,0 +1,68 @@ +/* + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, and the entire permission notice in its entirety, + * including the disclaimer of warranties. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the author may not be used to endorse or promote + * products derived from this software without specific prior + * written permission. + * + * ALTERNATIVELY, this product may be distributed under the terms of + * the GNU Public License, in which case the provisions of the GPL are + * required INSTEAD OF the above restrictions. (This clause is + * necessary due to a potential bad interaction between the GPL and + * the restrictions contained in a BSD-style copyright.) + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +/* + test case: + + shells.conf: + /bin/testbash + +*/ + +#include "test_assert.h" + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <security/pam_appl.h> + +static struct pam_conv conv; + +int +main(void) +{ + pam_handle_t *pamh = NULL; + int retval; + + // /bin/testbash is defined in shell definition file(s) + ASSERT_EQ(PAM_SUCCESS, pam_start("tst-pam_shells", "tstpamshells", &conv, &pamh)); + ASSERT_EQ(PAM_SUCCESS, retval=pam_authenticate (pamh, 0)); + ASSERT_EQ(PAM_SUCCESS, pam_end (pamh,retval)); + + // /bin/testnoshell is not defined in shell definition file(s) + ASSERT_EQ(PAM_SUCCESS, pam_start("tst-pam_shells", "tstnoshell", &conv, &pamh)); + ASSERT_EQ(PAM_AUTH_ERR, retval=pam_authenticate (pamh, 0)); + ASSERT_EQ(PAM_SUCCESS, pam_end (pamh,retval)); + + return 0; +} diff --git a/xtests/tst-pam_shells.pamd b/xtests/tst-pam_shells.pamd new file mode 100644 index 00000000..6ad4f319 --- /dev/null +++ b/xtests/tst-pam_shells.pamd @@ -0,0 +1,2 @@ +#%PAM-1.0 +auth required pam_shells.so diff --git a/xtests/tst-pam_shells.sh b/xtests/tst-pam_shells.sh new file mode 100755 index 00000000..5093f689 --- /dev/null +++ b/xtests/tst-pam_shells.sh @@ -0,0 +1,11 @@ +#!/bin/sh + +/usr/sbin/groupadd tstpamshells1 +/usr/sbin/useradd -s /bin/testbash -G tstpamshells1 -p '!!' tstpamshells +/usr/sbin/useradd -s /bin/testnoshell -G tstpamshells1 -p '!!' tstnoshell +./tst-pam_shells +RET=$? +/usr/sbin/userdel -r tstpamshells 2> /dev/null +/usr/sbin/userdel -r tstnoshell 2> /dev/null +/usr/sbin/groupdel tstpamshells1 2> /dev/null +exit $RET |