2 # Copyright (C) 2015 Stefan Metzmacher <metze@samba.org>
6 Usage: test_kinit_trusts.sh SERVER USERNAME PASSWORD REALM DOMAIN TRUST_USERNAME TRUST_PASSWORD TRUST_REALM TRUST_DOMAIN PREFIX TYPE ENCTYPE
29 samba4bindir
="$BINDIR"
31 if test -x $samba4bindir/samba4kinit
; then
32 samba4kinit
=$samba4bindir/samba4kinit
35 smbclient
="$samba4bindir/smbclient4"
36 wbinfo
="$samba4bindir/wbinfo"
37 rpcclient
="$samba4bindir/rpcclient"
38 samba_tool
="$samba4bindir/samba-tool"
40 .
`dirname $0`/subunit.sh
42 SMBCLIENT_UNC
="//$SERVER.$REALM/tmp"
50 $VALGRIND $smbclient $CONFIGURATION $SMBCLIENT_UNC -c "$cmd" $@
52 if [ x
$status = x0
]; then
62 KRB5CCNAME_PATH
="$PREFIX/tmpccache"
63 KRB5CCNAME
="FILE:$KRB5CCNAME_PATH"
65 rm -rf $KRB5CCNAME_PATH
67 echo $TRUST_PASSWORD > $PREFIX/tmppassfile
68 testit
"kinit with password" $samba4kinit $enctype --password-file=$PREFIX/tmppassfile
--request-pac $TRUST_USERNAME@
$TRUST_REALM || failed
=`expr $failed + 1`
69 test_smbclient
"Test login with user kerberos ccache" 'ls' -k yes || failed
=`expr $failed + 1`
71 testit
"kinit with password (enterprise style)" $samba4kinit $enctype --enterprise --password-file=$PREFIX/tmppassfile
--request-pac $TRUST_USERNAME@
$TRUST_REALM || failed
=`expr $failed + 1`
72 test_smbclient
"Test login with user kerberos ccache" 'ls' -k yes || failed
=`expr $failed + 1`
74 if test x
"${TYPE}" = x
"forest" ;then
75 testit
"kinit with password (upn enterprise style)" $samba4kinit $enctype --enterprise --password-file=$PREFIX/tmppassfile
--request-pac testdenied_upn@
${TRUST_REALM}.upn || failed
=`expr $failed + 1`
76 test_smbclient
"Test login with user kerberos ccache" 'ls' -k yes || failed
=`expr $failed + 1`
79 testit
"kinit with password (windows style)" $samba4kinit $enctype --renewable --windows --password-file=$PREFIX/tmppassfile
--request-pac $TRUST_USERNAME@
$TRUST_REALM || failed
=`expr $failed + 1`
80 test_smbclient
"Test login with user kerberos ccache" 'ls' -k yes || failed
=`expr $failed + 1`
82 testit
"kinit renew ticket" $samba4kinit $enctype --request-pac -R
84 test_smbclient
"Test login with kerberos ccache" 'ls' -k yes || failed
=`expr $failed + 1`
86 testit
"check time with kerberos ccache" $VALGRIND $samba_tool time $SERVER.
$REALM $CONFIGURATION -k yes $@ || failed
=`expr $failed + 1`
88 lowerrealm
=$
(echo $TRUST_REALM |
tr '[A-Z]' '[a-z]')
89 test_smbclient
"Test login with user kerberos lowercase realm" 'ls' -k yes -U$TRUST_USERNAME@
$lowerrealm%$TRUST_PASSWORD || failed
=`expr $failed + 1`
90 test_smbclient
"Test login with user kerberos lowercase realm 2" 'ls' -k yes -U$TRUST_USERNAME@
$TRUST_REALM%$TRUST_PASSWORD --realm=$lowerrealm || failed
=`expr $failed + 1`
92 # Test the outgoing direction
93 SMBCLIENT_UNC
="//$TRUST_SERVER.$TRUST_REALM/tmp"
94 test_smbclient
"Test user login with the first outgoing secret" 'ls' -k yes -U$USERNAME@
$REALM%$PASSWORD || failed
=`expr $failed + 1`
96 testit_expect_failure
"setpassword should not work" $VALGRIND $samba_tool user setpassword
"${TRUST_DOMAIN}\$" --random-password || failed
=`expr $failed + 1`
98 testit
"wbinfo ping dc" $VALGRIND $wbinfo --ping-dc --domain=$TRUST_DOMAIN || failed
=`expr $failed + 1`
99 testit
"wbinfo change outgoing trust pw" $VALGRIND $wbinfo --change-secret --domain=$TRUST_DOMAIN || failed
=`expr $failed + 1`
100 testit
"wbinfo check outgoing trust pw" $VALGRIND $wbinfo --check-secret --domain=$TRUST_DOMAIN || failed
=`expr $failed + 1`
102 test_smbclient
"Test user login with the changed outgoing secret" 'ls' -k yes -U$USERNAME@
$REALM%$PASSWORD || failed
=`expr $failed + 1`
104 rm -f $PREFIX/tmpccache tmpccfile tmppassfile tmpuserpassfile tmpuserccache tmpkpasswdscript