1 #! /bin/sh 2 3 # Copyright (c) 2012 FUJITSU LIMITED 4 # 5 # This program is free software; you can redistribute it and/or modify 6 # it under the terms of the GNU General Public License as published by 7 # the Free Software Foundation; either version 2 of the License, or 8 # (at your option) any later version. 9 # 10 # This program is distributed in the hope that it will be useful, 11 # but WITHOUT ANY WARRANTY; without even the implied warranty of 12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See 13 # the GNU General Public License for more details. 14 # 15 # You should have received a copy of the GNU General Public License 16 # along with this program; if not, write to the Free Software 17 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 18 # 19 # Description: Test allowed_shells, vetoed_shells and shell_fallback 20 # in the configuration file. 21 # Author: Peng Haitao <penght (at] cn.fujitsu.com> 22 # History: 2012/02/09 - Created. 23 # 24 25 . ./sssd-lib.sh || exit 1 26 27 sssd_case1() 28 { 29 export TST_COUNT=1 30 31 tst_resm TINFO "test allowed_shells with the shell in \"/etc/shells\"." 32 33 sss_usermod -s $line_shell $username 34 getent passwd $username@LOCAL | grep "$line_shell" >/dev/null 2>&1 35 if [ $? -eq 0 ]; then 36 tst_resm TPASS "sssd: user login shell is $line_shell." 37 else 38 tst_resm TFAIL "sssd: user login shell should be $line_shell." 39 : $(( TFAILCNT += 1 )) 40 return $TFAILCNT 41 fi 42 43 return 0 44 } 45 46 sssd_case2() 47 { 48 export TST_COUNT=2 49 50 tst_resm TINFO "test not set allowed_shells" 51 52 make_config_file 53 sleep 1 54 55 restart_sssd_daemon 56 57 # When not set allowed_shells, the user shell is used even if is wrong 58 sss_usermod -s $LTPTMP/noshell $username 59 getent passwd $username@LOCAL | grep "$LTPTMP/noshell" >/dev/null 2>&1 60 if [ $? -eq 0 ]; then 61 tst_resm TPASS "sssd: user home dir is $LTPTMP/noshell." 62 else 63 tst_resm TFAIL "sssd: user home dir should be $LTPTMP/noshell." 64 : $(( TFAILCNT += 1 )) 65 return $TFAILCNT 66 fi 67 68 return 0 69 } 70 71 sssd_case3() 72 { 73 export TST_COUNT=3 74 75 tst_resm TINFO "test use shell_fallback when set allowed_shells" 76 77 # Create the configuration file specific to this test case. 78 make_config_file 79 sed -i -e "/\[nss\]/ a\allowed_shells = $LTPTMP/noshell" $CONFIG_FILE 80 sleep 1 81 82 sss_usermod -s $LTPTMP/noshell $username 83 84 restart_sssd_daemon 85 86 # When the shell is in the allowed_shells list but not in "/etc/shells" 87 # use the value of the shell_fallback parameter. 88 # shell_fallback's default value is /bin/sh. 89 getent passwd $username@LOCAL | grep "/bin/sh" >/dev/null 2>&1 90 if [ $? -eq 0 ]; then 91 tst_resm TPASS "sssd: user home dir is /bin/sh." 92 else 93 tst_resm TFAIL "sssd: user home dir should be /bin/sh." 94 : $(( TFAILCNT += 1 )) 95 return $TFAILCNT 96 fi 97 98 return 0 99 } 100 101 sssd_case4() 102 { 103 export TST_COUNT=4 104 105 tst_resm TINFO "test use shell_fallback when set allowed_shells" 106 107 # Create the configuration file specific to this test case. 108 make_config_file 109 sed -i -e "/\[nss\]/ a\allowed_shells = $LTPTMP/noshell" $CONFIG_FILE 110 sed -i -e "/\[nss\]/ a\shell_fallback = $line_shell" $CONFIG_FILE 111 sleep 1 112 113 sss_usermod -s $LTPTMP/noshell $username 114 115 restart_sssd_daemon 116 117 # When the shell is in the allowed_shells list but not in "/etc/shells" 118 # use the value of the shell_fallback parameter. 119 # shell_fallback's value is set $line_shell. 120 getent passwd $username@LOCAL | grep "$line_shell" >/dev/null 2>&1 121 if [ $? -eq 0 ]; then 122 tst_resm TPASS "sssd: user home dir is $line_shell." 123 else 124 tst_resm TFAIL "sssd: user home dir should be $line_shell." 125 : $(( TFAILCNT += 1 )) 126 return $TFAILCNT 127 fi 128 129 return 0 130 } 131 132 sssd_case5() 133 { 134 export TST_COUNT=5 135 136 tst_resm TINFO "test use shell_fallback when set vetoed_shells" 137 138 # Create the configuration file specific to this test case. 139 make_config_file 140 sed -i -e "/\[nss\]/ a\vetoed_shells = $line_shell" $CONFIG_FILE 141 sleep 1 142 143 sss_usermod -s $line_shell $username 144 145 restart_sssd_daemon 146 147 # When the shell is in the vetoed_shells list, 148 # use the value of the shell_fallback parameter. 149 # shell_fallback's default value is /bin/sh. 150 getent passwd $username@LOCAL | grep "/bin/sh" >/dev/null 2>&1 151 if [ $? -eq 0 ]; then 152 tst_resm TPASS "sssd: user home dir is /bin/sh." 153 else 154 tst_resm TFAIL "sssd: user home dir should be /bin/sh." 155 : $(( TFAILCNT += 1 )) 156 return $TFAILCNT 157 fi 158 159 return 0 160 } 161 162 sssd_case6() 163 { 164 export TST_COUNT=6 165 166 tst_resm TINFO "test use nologin when not in allowed_shells" 167 168 # Create the configuration file specific to this test case. 169 make_config_file 170 sed -i -e "/\[nss\]/ a\allowed_shells = $line_shell" $CONFIG_FILE 171 sleep 1 172 173 sss_usermod -s $LTPTMP/noshell $username 174 175 restart_sssd_daemon 176 177 # When the shell is not in the allowed_shells list, and not in 178 # "/etc/shells", a nologin shell is used. 179 getent passwd $username@LOCAL | grep "/sbin/nologin" >/dev/null 2>&1 180 if [ $? -eq 0 ]; then 181 tst_resm TPASS "sssd: user home dir is /sbin/nologin." 182 else 183 tst_resm TFAIL "sssd: user home dir should be /sbin/nologin." 184 : $(( TFAILCNT += 1 )) 185 return $TFAILCNT 186 fi 187 188 return 0 189 } 190 191 export TST_TOTAL=6 192 export TCID=sssd03 193 194 grep -v -w -E "nologin|sh|bash" /etc/shells > $LTPTMP/all_shells 195 line_shell=`sed -n '1p' $LTPTMP/all_shells` 196 if [ -z "$line_shell" ]; then 197 rm -f $LTPTMP/all_shells 198 tst_brkm TCONF NULL "Please install another shell." 199 return 0 200 fi 201 rm -f $LTPTMP/all_shells 202 203 TFAILCNT=0 204 username="sssd_test_user" 205 206 make_config_file 207 # make sure config file is OK 208 sleep 1 209 restart_sssd_daemon 210 sss_useradd $username 211 212 for i in $(seq 1 $TST_TOTAL); do 213 sssd_case$i 214 done 215 216 sss_userdel $username 217 cleanup ${TFAILCNT:=0} 218