1*ebfedea0SLionel Sambuc#!/bin/sh 2*ebfedea0SLionel Sambuc# 3*ebfedea0SLionel Sambuc# Copyright (c) 2007 Kungliga Tekniska Högskolan 4*ebfedea0SLionel Sambuc# (Royal Institute of Technology, Stockholm, Sweden). 5*ebfedea0SLionel Sambuc# All rights reserved. 6*ebfedea0SLionel Sambuc# 7*ebfedea0SLionel Sambuc# Redistribution and use in source and binary forms, with or without 8*ebfedea0SLionel Sambuc# modification, are permitted provided that the following conditions 9*ebfedea0SLionel Sambuc# are met: 10*ebfedea0SLionel Sambuc# 11*ebfedea0SLionel Sambuc# 1. Redistributions of source code must retain the above copyright 12*ebfedea0SLionel Sambuc# notice, this list of conditions and the following disclaimer. 13*ebfedea0SLionel Sambuc# 14*ebfedea0SLionel Sambuc# 2. Redistributions in binary form must reproduce the above copyright 15*ebfedea0SLionel Sambuc# notice, this list of conditions and the following disclaimer in the 16*ebfedea0SLionel Sambuc# documentation and/or other materials provided with the distribution. 17*ebfedea0SLionel Sambuc# 18*ebfedea0SLionel Sambuc# 3. Neither the name of the Institute nor the names of its contributors 19*ebfedea0SLionel Sambuc# may be used to endorse or promote products derived from this software 20*ebfedea0SLionel Sambuc# without specific prior written permission. 21*ebfedea0SLionel Sambuc# 22*ebfedea0SLionel Sambuc# THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 23*ebfedea0SLionel Sambuc# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24*ebfedea0SLionel Sambuc# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25*ebfedea0SLionel Sambuc# ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 26*ebfedea0SLionel Sambuc# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27*ebfedea0SLionel Sambuc# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28*ebfedea0SLionel Sambuc# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29*ebfedea0SLionel Sambuc# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30*ebfedea0SLionel Sambuc# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31*ebfedea0SLionel Sambuc# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32*ebfedea0SLionel Sambuc# SUCH DAMAGE. 33*ebfedea0SLionel Sambuc# 34*ebfedea0SLionel Sambuc# Id 35*ebfedea0SLionel Sambuc# 36*ebfedea0SLionel Sambuc 37*ebfedea0SLionel Sambucsrcdir="@srcdir@" 38*ebfedea0SLionel Sambucobjdir="@objdir@" 39*ebfedea0SLionel Sambuc 40*ebfedea0SLionel Sambuc# If there is no useful db support compile in, disable test 41*ebfedea0SLionel Sambuc../db/have-db || exit 77 42*ebfedea0SLionel Sambuc 43*ebfedea0SLionel SambucR=TEST.H5L.SE 44*ebfedea0SLionel Sambuc 45*ebfedea0SLionel Sambucport=@port@ 46*ebfedea0SLionel Sambuc 47*ebfedea0SLionel Sambuckeytabfile=${objdir}/server.keytab 48*ebfedea0SLionel Sambuckeytab="FILE:${keytabfile}" 49*ebfedea0SLionel Sambucnokeytab="FILE:no-such-keytab" 50*ebfedea0SLionel Sambuccache="FILE:krb5ccfile" 51*ebfedea0SLionel Sambuccache2="FILE:krb5ccfile2" 52*ebfedea0SLionel Sambucnocache="FILE:no-such-cache" 53*ebfedea0SLionel Sambuc 54*ebfedea0SLionel Sambuckinit="${TESTS_ENVIRONMENT} ../../kuser/kinit -c $cache ${afs_no_afslog}" 55*ebfedea0SLionel Sambuckdestroy="${TESTS_ENVIRONMENT} ../../kuser/kdestroy -c $cache ${afs_no_unlog}" 56*ebfedea0SLionel Sambucklist="${TESTS_ENVIRONMENT} ../../kuser/klist -c $cache" 57*ebfedea0SLionel Sambuckadmin="${TESTS_ENVIRONMENT} ../../kadmin/kadmin -l -r $R" 58*ebfedea0SLionel Sambuckdc="${TESTS_ENVIRONMENT} ../../kdc/kdc --addresses=localhost -P $port" 59*ebfedea0SLionel Sambuc 60*ebfedea0SLionel Sambucacquire_cred="${TESTS_ENVIRONMENT} ../../lib/gssapi/test_acquire_cred" 61*ebfedea0SLionel Sambuctest_kcred="${TESTS_ENVIRONMENT} ../../lib/gssapi/test_kcred" 62*ebfedea0SLionel Sambuc 63*ebfedea0SLionel SambucKRB5_CONFIG="${objdir}/krb5.conf" 64*ebfedea0SLionel Sambucexport KRB5_CONFIG 65*ebfedea0SLionel Sambuc 66*ebfedea0SLionel SambucKRB5_KTNAME="${keytab}" 67*ebfedea0SLionel Sambucexport KRB5_KTNAME 68*ebfedea0SLionel SambucKRB5CCNAME="${cache}" 69*ebfedea0SLionel Sambucexport KRB5CCNAME 70*ebfedea0SLionel Sambuc 71*ebfedea0SLionel Sambucrm -f ${keytabfile} 72*ebfedea0SLionel Sambucrm -f current-db* 73*ebfedea0SLionel Sambucrm -f out-* 74*ebfedea0SLionel Sambucrm -f mkey.file* 75*ebfedea0SLionel Sambuc 76*ebfedea0SLionel Sambuc> messages.log 77*ebfedea0SLionel Sambuc 78*ebfedea0SLionel Sambucecho Creating database 79*ebfedea0SLionel Sambuc${kadmin} \ 80*ebfedea0SLionel Sambuc init \ 81*ebfedea0SLionel Sambuc --realm-max-ticket-life=1day \ 82*ebfedea0SLionel Sambuc --realm-max-renewable-life=1month \ 83*ebfedea0SLionel Sambuc ${R} || exit 1 84*ebfedea0SLionel Sambuc 85*ebfedea0SLionel Sambucecho upw > ${objdir}/foopassword 86*ebfedea0SLionel Sambuc 87*ebfedea0SLionel Sambuc${kadmin} add -p upw --use-defaults user@${R} || exit 1 88*ebfedea0SLionel Sambuc${kadmin} add -p upw --use-defaults another@${R} || exit 1 89*ebfedea0SLionel Sambuc${kadmin} add -p p1 --use-defaults host/host.test.h5l.se@${R} || exit 1 90*ebfedea0SLionel Sambuc${kadmin} ext -k ${keytab} host/host.test.h5l.se@${R} || exit 1 91*ebfedea0SLionel Sambuc 92*ebfedea0SLionel Sambucecho "Doing database check" 93*ebfedea0SLionel Sambuc${kadmin} check ${R} || exit 1 94*ebfedea0SLionel Sambuc 95*ebfedea0SLionel Sambucecho Starting kdc 96*ebfedea0SLionel Sambuc${kdc} & 97*ebfedea0SLionel Sambuckdcpid=$! 98*ebfedea0SLionel Sambuc 99*ebfedea0SLionel Sambucsh ${srcdir}/../kdc/wait-kdc.sh 100*ebfedea0SLionel Sambucif [ "$?" != 0 ] ; then 101*ebfedea0SLionel Sambuc kill ${kdcpid} 102*ebfedea0SLionel Sambuc exit 1 103*ebfedea0SLionel Sambucfi 104*ebfedea0SLionel Sambuc 105*ebfedea0SLionel Sambuctrap "kill ${kdcpid}; echo signal killing kdc; exit 1;" EXIT 106*ebfedea0SLionel Sambuc 107*ebfedea0SLionel Sambucexitcode=0 108*ebfedea0SLionel Sambuc 109*ebfedea0SLionel Sambucecho "initial ticket" 110*ebfedea0SLionel Sambuc${kinit} --password-file=${objdir}/foopassword user@${R} || exitcode=1 111*ebfedea0SLionel Sambuc 112*ebfedea0SLionel Sambucecho "keytab" 113*ebfedea0SLionel Sambuc${acquire_cred} \ 114*ebfedea0SLionel Sambuc --acquire-type=accept \ 115*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se || exit 1 116*ebfedea0SLionel Sambuc 117*ebfedea0SLionel Sambucecho "keytab w/o name" 118*ebfedea0SLionel Sambuc${acquire_cred} \ 119*ebfedea0SLionel Sambuc --acquire-type=accept || exit 1 120*ebfedea0SLionel Sambuc 121*ebfedea0SLionel Sambucecho "keytab w/ wrong name" 122*ebfedea0SLionel Sambuc${acquire_cred} \ 123*ebfedea0SLionel Sambuc --acquire-type=accept \ 124*ebfedea0SLionel Sambuc --acquire-name=host@host2.test.h5l.se 2>/dev/null && exit 1 125*ebfedea0SLionel Sambuc 126*ebfedea0SLionel Sambucecho "init using keytab" 127*ebfedea0SLionel Sambuc${acquire_cred} \ 128*ebfedea0SLionel Sambuc --acquire-type=initiate \ 129*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se > /dev/null || exit 1 130*ebfedea0SLionel Sambuc 131*ebfedea0SLionel Sambucecho "init using keytab (loop 10)" 132*ebfedea0SLionel Sambuc${acquire_cred} \ 133*ebfedea0SLionel Sambuc --acquire-type=initiate \ 134*ebfedea0SLionel Sambuc --loops=10 \ 135*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se > /dev/null || exit 1 136*ebfedea0SLionel Sambuc 137*ebfedea0SLionel Sambucecho "init using keytab (loop 10, target)" 138*ebfedea0SLionel Sambuc${acquire_cred} \ 139*ebfedea0SLionel Sambuc --acquire-type=initiate \ 140*ebfedea0SLionel Sambuc --loops=10 \ 141*ebfedea0SLionel Sambuc --target=host@host.test.h5l.se \ 142*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se > /dev/null || exit 1 143*ebfedea0SLionel Sambuc 144*ebfedea0SLionel Sambucecho "init using keytab (loop 10, kerberos)" 145*ebfedea0SLionel Sambuc${acquire_cred} \ 146*ebfedea0SLionel Sambuc --acquire-type=initiate \ 147*ebfedea0SLionel Sambuc --loops=10 \ 148*ebfedea0SLionel Sambuc --kerberos \ 149*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se > /dev/null || exit 1 150*ebfedea0SLionel Sambuc 151*ebfedea0SLionel Sambucecho "init using keytab (loop 10, target, kerberos)" 152*ebfedea0SLionel Sambuc${acquire_cred} \ 153*ebfedea0SLionel Sambuc --acquire-type=initiate \ 154*ebfedea0SLionel Sambuc --loops=10 \ 155*ebfedea0SLionel Sambuc --kerberos \ 156*ebfedea0SLionel Sambuc --target=host@host.test.h5l.se \ 157*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se > /dev/null || exit 1 158*ebfedea0SLionel Sambuc 159*ebfedea0SLionel Sambucecho "init using existing cc" 160*ebfedea0SLionel Sambuc${acquire_cred} \ 161*ebfedea0SLionel Sambuc --name-type=user-name \ 162*ebfedea0SLionel Sambuc --acquire-type=initiate \ 163*ebfedea0SLionel Sambuc --acquire-name=user || exit 1 164*ebfedea0SLionel Sambuc 165*ebfedea0SLionel SambucKRB5CCNAME=${nocache} 166*ebfedea0SLionel Sambuc 167*ebfedea0SLionel Sambucecho "fail init using existing cc" 168*ebfedea0SLionel Sambuc${acquire_cred} \ 169*ebfedea0SLionel Sambuc --name-type=user-name \ 170*ebfedea0SLionel Sambuc --acquire-type=initiate \ 171*ebfedea0SLionel Sambuc --acquire-name=user 2>/dev/null && exit 1 172*ebfedea0SLionel Sambuc 173*ebfedea0SLionel Sambucecho "use gss_krb5_ccache_name for user" 174*ebfedea0SLionel Sambuc${acquire_cred} \ 175*ebfedea0SLionel Sambuc --name-type=user-name \ 176*ebfedea0SLionel Sambuc --ccache=${cache} \ 177*ebfedea0SLionel Sambuc --acquire-type=initiate \ 178*ebfedea0SLionel Sambuc --acquire-name=user >/dev/null || exit 1 179*ebfedea0SLionel Sambuc 180*ebfedea0SLionel SambucKRB5CCNAME=${cache} 181*ebfedea0SLionel SambucKRB5_KTNAME=${nokeytab} 182*ebfedea0SLionel Sambuc 183*ebfedea0SLionel Sambucecho "kcred" 184*ebfedea0SLionel Sambuc${test_kcred} || exit 1 185*ebfedea0SLionel Sambuc 186*ebfedea0SLionel Sambuc${kdestroy} 187*ebfedea0SLionel Sambuc 188*ebfedea0SLionel SambucKRB5_KTNAME="${keytab}" 189*ebfedea0SLionel Sambuc 190*ebfedea0SLionel Sambucecho "init using keytab" 191*ebfedea0SLionel Sambuc${acquire_cred} \ 192*ebfedea0SLionel Sambuc --acquire-type=initiate \ 193*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se 2>/dev/null || exit 1 194*ebfedea0SLionel Sambuc 195*ebfedea0SLionel Sambucecho "init using keytab (ccache)" 196*ebfedea0SLionel Sambuc${acquire_cred} \ 197*ebfedea0SLionel Sambuc --acquire-type=initiate \ 198*ebfedea0SLionel Sambuc --ccache=${cache} \ 199*ebfedea0SLionel Sambuc --acquire-name=host@host.test.h5l.se 2>/dev/null || exit 1 200*ebfedea0SLionel Sambuc 201*ebfedea0SLionel Sambuctrap "" EXIT 202*ebfedea0SLionel Sambuc 203*ebfedea0SLionel Sambucecho "killing kdc (${kdcpid})" 204*ebfedea0SLionel Sambuckill ${kdcpid} 2> /dev/null 205*ebfedea0SLionel Sambuc 206*ebfedea0SLionel Sambucexit $exitcode 207