summaryrefslogtreecommitdiffstats
path: root/src/tests/dejagnu
diff options
context:
space:
mode:
authorPaul Park <pjpark@mit.edu>1995-05-12 20:18:53 +0000
committerPaul Park <pjpark@mit.edu>1995-05-12 20:18:53 +0000
commit0f661439ab038604313aa1bd89ab2d41b67841d0 (patch)
tree3b315e57fdb717d597ca50d62dfa15e119f14fb9 /src/tests/dejagnu
parent13c1c9f78ced878f50458aa676ea83bc46ddd3b5 (diff)
downloadkrb5-0f661439ab038604313aa1bd89ab2d41b67841d0.tar.gz
krb5-0f661439ab038604313aa1bd89ab2d41b67841d0.tar.xz
krb5-0f661439ab038604313aa1bd89ab2d41b67841d0.zip
Change dejagnu tests to use new kadmin/kadmind
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@5810 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/tests/dejagnu')
-rw-r--r--src/tests/dejagnu/config/ChangeLog6
-rw-r--r--src/tests/dejagnu/config/default.exp144
2 files changed, 112 insertions, 38 deletions
diff --git a/src/tests/dejagnu/config/ChangeLog b/src/tests/dejagnu/config/ChangeLog
index 01475fadac..031f1c0378 100644
--- a/src/tests/dejagnu/config/ChangeLog
+++ b/src/tests/dejagnu/config/ChangeLog
@@ -1,3 +1,9 @@
+
+Fri May 12 16:15:07 EDT 1995 Paul Park (pjpark@mit.edu)
+ * default.exp: Change to use new kadmin/kadmind. Add entries for
+ krbtest/kadmin5, changepw and extraction for changepw service
+ entry.
+
Wed May 10 16:53:28 1995 Ezra Peisach <epeisach@kangaroo.mit.edu>
* default.exp: Added domain_realm stanza to krb5.conf.
diff --git a/src/tests/dejagnu/config/default.exp b/src/tests/dejagnu/config/default.exp
index aa308fc265..b5f61b72b9 100644
--- a/src/tests/dejagnu/config/default.exp
+++ b/src/tests/dejagnu/config/default.exp
@@ -40,7 +40,7 @@ if ![info exists KEY] {
# Clear away any files left over from a previous run.
# We can't use them now because we don't know the right KEY.
# krb5.conf might change if running tests on another host
-catch "exec rm -f tmpdir/db.ok tmpdir/srvtab tmpdir/krb5.conf"
+catch "exec rm -f tmpdir/db.ok tmpdir/srvtab tmpdir/krb5.conf tmpdir/cpw_srvtab"
# Put the installed kerberos directories on PATH.
# This needs to be fixed for V5.
@@ -81,11 +81,11 @@ if ![info exists KRB5KDC] {
}
if ![info exists KADMIND] {
- set KADMIND [findfile $objdir/../../kadmin.old/server/kadmind]
+ set KADMIND [findfile $objdir/../../kadmin/v5server/kadmind5]
}
if ![info exists KADMIN] {
- set KADMIN [findfile $objdir/../../kadmin.old/client/kadmin]
+ set KADMIN [findfile $objdir/../../kadmin/v5client/kadmin5]
}
if ![info exists KINIT] {
@@ -229,7 +229,7 @@ proc setup_kerberos_files { } {
# Create ACL file.
if ![file exists tmpdir/acl] {
set aclfile [open tmpdir/acl w]
- puts $aclfile "krbtest/admin@KRBTEST.COM *"
+ puts $aclfile "krbtest/kadmin5@KRBTEST.COM *"
close $aclfile
}
@@ -328,6 +328,61 @@ proc restore_kerberos_env { } {
}
}
+# setup_kadmind_srvtab
+# A procedure to build the srvtab for kadmind5 so that kadmin5 and it
+# may successfully communicate.
+# Returns 1 on success, 0 on failure.
+proc setup_kadmind_srvtab { } {
+ global KDB5_EDIT
+ global KEY
+ global tmppwd
+
+ catch "exec rm -f tmpdir/cpw_srvtab"
+ spawn $KDB5_EDIT -m -d $tmppwd/db -r KRBTEST.COM
+ expect_after {
+ timeout {
+ fail "kdb5_edit cpw_srvtab"
+ catch "exec rm -f tmpdir/cpw_srvtab"
+ catch "expect_after"
+ return 0
+ }
+ eof {
+ fail "kdb5_edit cpw_srvtab"
+ catch "exec rm -f tmpdir/cpw_srvtab"
+ catch "expect_after"
+ return 0
+ }
+ }
+ expect "Enter KDC database master key"
+ send "masterkey$KEY\r"
+ expect "kdb5_edit:"
+ send "xst KRBTEST.COM changepw\r"
+ expect "'changepw/KRBTEST.COM@KRBTEST.COM' added to keytab"
+ expect "kdb5_edit:"
+ send "quit\r"
+ expect "\r"
+ expect_after
+ if ![check_exit_status "kdb5_edit cpw_srvtab"] {
+ catch "exec rm -f tmpdir/cpw_srvtab"
+ send_error "ERROR: kdb5_edit cpw_srvtab exited abnormally\n"
+ return 0
+ }
+
+ catch "exec mv -f KRBTEST.COM-new-srvtab tmpdir/cpw_srvtab" exec_output
+ if ![string match "" $exec_output] {
+ send_log "$exec_output\n"
+ verbose $exec_output
+ send_error "ERROR: can't mv new cpw_srvtab\n"
+ return 0
+ }
+
+ # Make the srvtab file globally readable in case we are using a
+ # root shell and the srvtab is NFS mounted.
+ catch "exec chmod a+r tmpdir/cpw_srvtab"
+
+ return 1
+}
+
# setup_kerberos_db
# Initialize the Kerberos database. If the argument is non-zero, call
# pass at relevant points. Returns 1 on success, 0 on failure.
@@ -467,13 +522,19 @@ proc setup_kerberos_db { standalone } {
}
send "masterkey$KEY\r"
expect "kdb5_edit:"
+ send "ank krbtest/kadmin5@KRBTEST.COM\r"
+ expect "Enter password:"
+ send "adminpass$KEY\r"
+ expect "Re-enter password for verification:"
+ send "adminpass$KEY\r"
+ expect "kdb5_edit:"
send "ank krbtest/admin@KRBTEST.COM\r"
expect "Enter password:"
send "adminpass$KEY\r"
expect "Re-enter password for verification:"
send "adminpass$KEY\r"
expect "kdb5_edit:"
- send "ark kadmin/KRBTEST.COM@KRBTEST.COM\r"
+ send "ark changepw/KRBTEST.COM@KRBTEST.COM\r"
expect "kdb5_edit:"
send "quit\r"
expect "\r"
@@ -485,6 +546,10 @@ proc setup_kerberos_db { standalone } {
return 0
}
+ if ![setup_kadmind_srvtab] {
+ return 0
+ }
+
if {$standalone} {
pass "kdb5_edit"
}
@@ -560,7 +625,7 @@ proc start_kerberos_daemons { standalone } {
catch "exec sleep 2"
# Start up the kadmind daemon
- spawn $KADMIND -d $tmppwd/db -p 3750 -a $tmppwd/acl -m -r KRBTEST.COM
+ spawn $KADMIND -d $tmppwd/db -p 3750 -a $tmppwd/acl -T tmpdir/cpw_srvtab -m -r KRBTEST.COM -n
set kadmind_pid [exp_pid]
set kadmind_spawn_id $spawn_id
expect {
@@ -573,12 +638,17 @@ proc start_kerberos_daemons { standalone } {
return 0
}
eof {
- fail "krb5kdc"
+ fail "kadmind"
stop_kerberos_daemons
return 0
}
}
expect {
+ "cannot bind to network address" {
+ fail "kadmind"
+ stop_kerberos_daemons
+ return 0
+ }
"\r" { }
timeout {
fail "kadmind"
@@ -614,15 +684,19 @@ proc stop_kerberos_daemons { } {
if [info exists kdc_pid] {
catch "close -i $kdc_spawn_id"
catch "exec kill $kdc_pid"
- wait -i $kdc_spawn_id
+ set kdc_list [wait -i $kdc_spawn_id]
+ verbose "wait -i $kdc_spawn_id returned $kdc_list (kdc)"
unset kdc_pid
+ unset kdc_list
}
if [info exists kadmind_pid] {
catch "close -i $kadmind_spawn_id"
catch "exec kill $kadmind_pid"
- wait -i $kadmind_spawn_id
+ set kadmind_list [wait -i $kadmind_spawn_id]
+ verbose "wait -i $kadmind_spawn_id returned $kadmind_list (kadmind5)"
unset kadmind_pid
+ unset kadmind_list
}
return 1
@@ -640,7 +714,7 @@ proc add_kerberos_key { kkey standalone } {
global spawn_id
# Use kadmin to add an key.
- spawn $KADMIN -p 3750 krbtest@KRBTEST.COM
+ spawn $KADMIN -m -p krbtest/kadmin5@KRBTEST.COM
expect_after {
timeout {
fail "kadmin $kkey"
@@ -653,32 +727,23 @@ proc add_kerberos_key { kkey standalone } {
return 0
}
}
- expect "Password for krbtest/admin@KRBTEST.COM:"
- send "adminpass$KEY\r"
- expect -re "Command (.*):"
- send "add $kkey@KRBTEST.COM\r"
- expect {
- "Enter password:" { }
- "Principal Already Exists" {
- expect -re "Command (.*):"
- send "q\r"
- expect "Have a Good Day.\r"
- catch "expect_after"
- if ![check_exit_status kadmin] {
- return 0
- }
- return 1
- }
- }
+ expect "kadmin5:"
+ send "ank $kkey@KRBTEST.COM\r"
+ expect "Enter new password for $kkey@KRBTEST.COM :"
send "$kkey"
send "$KEY\r"
- expect "Re-enter password for verification:"
+ expect "Re-enter new password for $kkey@KRBTEST.COM :"
send "$kkey"
send "$KEY\r"
- expect "Database Addition Successful"
- expect -re "Command (.*):"
+ expect "Enter password for krbtest/kadmin5@KRBTEST.COM:"
+ send "adminpass$KEY\r"
+ expect {
+ "principal $kkey@KRBTEST.COM added" { }
+ "Principal $kkey@KRBTEST.COM already exists" { }
+ }
+ expect "kadmin5:"
send "q\r"
- expect "Have a Good Day.\r"
+ expect "\r"
expect_after
if ![check_exit_status kadmin] {
return 0
@@ -703,7 +768,7 @@ proc add_random_key { kkey standalone } {
global spawn_id
# Use kadmin to add an key.
- spawn $KADMIN -p 3750 krbtest@KRBTEST.COM
+ spawn $KADMIN -m -p krbtest/kadmin5@KRBTEST.COM
expect_after {
timeout {
fail "kadmin $kkey"
@@ -716,14 +781,17 @@ proc add_random_key { kkey standalone } {
return 0
}
}
- expect "Password for krbtest/admin@KRBTEST.COM:"
+ expect "kadmin5:"
+ send "ark $kkey@KRBTEST.COM\r"
+ expect "Enter password for krbtest/kadmin5@KRBTEST.COM:"
send "adminpass$KEY\r"
- expect -re "Command (.*):"
- send "addrnd $kkey@KRBTEST.COM\r"
- expect "Database Addition Successful"
- expect -re "Command (.*):"
+ expect {
+ "principal $kkey@KRBTEST.COM added" { }
+ "Principal $kkey@KRBTEST.COM already exists" { }
+ }
+ expect "kadmin5:"
send "q\r"
- expect "Have a Good Day.\r"
+ expect "\r"
expect_after
if ![check_exit_status kadmin] {
return 0