1 | #!/bin/sh
|
---|
2 | #
|
---|
3 | # Copyright (c) 2006 Kungliga Tekniska Högskolan
|
---|
4 | # (Royal Institute of Technology, Stockholm, Sweden).
|
---|
5 | # All rights reserved.
|
---|
6 | #
|
---|
7 | # Redistribution and use in source and binary forms, with or without
|
---|
8 | # modification, are permitted provided that the following conditions
|
---|
9 | # are met:
|
---|
10 | #
|
---|
11 | # 1. Redistributions of source code must retain the above copyright
|
---|
12 | # notice, this list of conditions and the following disclaimer.
|
---|
13 | #
|
---|
14 | # 2. Redistributions in binary form must reproduce the above copyright
|
---|
15 | # notice, this list of conditions and the following disclaimer in the
|
---|
16 | # documentation and/or other materials provided with the distribution.
|
---|
17 | #
|
---|
18 | # 3. Neither the name of the Institute nor the names of its contributors
|
---|
19 | # may be used to endorse or promote products derived from this software
|
---|
20 | # without specific prior written permission.
|
---|
21 | #
|
---|
22 | # THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
---|
23 | # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
---|
24 | # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
---|
25 | # ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
---|
26 | # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
---|
27 | # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
---|
28 | # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
---|
29 | # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
---|
30 | # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
---|
31 | # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
---|
32 | # SUCH DAMAGE.
|
---|
33 | #
|
---|
34 | # $Id$
|
---|
35 | #
|
---|
36 |
|
---|
37 | srcdir="@srcdir@"
|
---|
38 | objdir="@objdir@"
|
---|
39 | EGREP="@EGREP@"
|
---|
40 |
|
---|
41 | # If there is no useful db support compile in, disable test
|
---|
42 | ./have-db || exit 77
|
---|
43 |
|
---|
44 | R=EXAMPLE.ORG
|
---|
45 |
|
---|
46 | kadmin="${TESTS_ENVIRONMENT} ../../kadmin/kadmin -l -r $R"
|
---|
47 | iproplog="${TESTS_ENVIRONMENT} ../../lib/kadm5/iprop-log"
|
---|
48 |
|
---|
49 | KRB5_CONFIG="${objdir}/krb5.conf"
|
---|
50 | export KRB5_CONFIG
|
---|
51 |
|
---|
52 | rm -f current-db*
|
---|
53 | rm -f log.current-db*
|
---|
54 | rm -f out-*
|
---|
55 | rm -f mkey.file*
|
---|
56 |
|
---|
57 | echo init database
|
---|
58 | ${kadmin} \
|
---|
59 | init \
|
---|
60 | --realm-max-ticket-life=1day \
|
---|
61 | --realm-max-renewable-life=1month \
|
---|
62 | EXAMPLE.ORG || exit 1
|
---|
63 |
|
---|
64 | echo test add
|
---|
65 | ${kadmin} add -r --use-defaults foo || exit 1
|
---|
66 | ${kadmin} list '*' > /dev/null || exit 1
|
---|
67 | ${kadmin} list '*' | ${EGREP} '^foo$' > /dev/null || exit 1
|
---|
68 |
|
---|
69 | echo "test add (double)"
|
---|
70 | ${kadmin} add -r --use-defaults foo 2>/dev/null && exit 1
|
---|
71 |
|
---|
72 | echo test rename
|
---|
73 | ${kadmin} rename foo bar
|
---|
74 | ${kadmin} list '*' | ${EGREP} '^foo$' > /dev/null && exit 1
|
---|
75 | ${kadmin} list '*' | ${EGREP} '^bar$' > /dev/null || exit 1
|
---|
76 |
|
---|
77 | echo test delete
|
---|
78 | ${kadmin} delete bar || exit 1
|
---|
79 | ${kadmin} list '*' | ${EGREP} '^bar$' > /dev/null && exit 1
|
---|
80 |
|
---|
81 | echo "test delete (double)"
|
---|
82 | ${kadmin} delete bar 2> /dev/null && exit 1
|
---|
83 |
|
---|
84 | echo "creating sample user"
|
---|
85 | ${kadmin} add -r --use-defaults foo || exit 1
|
---|
86 | ${kadmin} get foo > tempfile || exit 1
|
---|
87 | echo checking principal
|
---|
88 | ${EGREP} " *Principal: foo@EXAMPLE.ORG$" tempfile > /dev/null || exit 1
|
---|
89 | echo checking kvno
|
---|
90 | ${EGREP} " *Kvno: 1$" tempfile > /dev/null || exit 1
|
---|
91 | echo checking failed login count
|
---|
92 | ${EGREP} " *Failed login count: 0$" tempfile > /dev/null || exit 1
|
---|
93 | echo checking modifier
|
---|
94 | ${EGREP} " *Modifier: kadmin/admin@EXAMPLE.ORG$" tempfile > /dev/null || exit 1
|
---|
95 | echo checking attributes
|
---|
96 | ${EGREP} " *Attributes: $" tempfile > /dev/null || exit 1
|
---|
97 | echo checking renew time
|
---|
98 | ${EGREP} " *Max renewable life: 1 week$" tempfile > /dev/null || exit 1
|
---|
99 |
|
---|
100 | echo modifing renewable-life
|
---|
101 | ${kadmin} modify --max-renewable-life=2months foo
|
---|
102 | echo checking renew time
|
---|
103 | ${kadmin} get foo > tempfile || exit 1
|
---|
104 | ${EGREP} " *Max renewable life: 2 months$" tempfile > /dev/null || exit 1
|
---|
105 |
|
---|
106 | echo "creating sample server"
|
---|
107 | ${kadmin} add -r --use-defaults host/datan.example.org || exit 1
|
---|
108 | ${kadmin} get host/datan.example.org > tempfile || exit 1
|
---|
109 | echo checking principal
|
---|
110 | ${EGREP} " *Principal: host/datan.example.org@EXAMPLE.ORG$" tempfile > /dev/null || exit 1
|
---|
111 | echo checking kvno
|
---|
112 | ${EGREP} " *Kvno: 1$" tempfile > /dev/null || exit 1
|
---|
113 |
|
---|
114 | echo "iprop-log dump"
|
---|
115 | ${iproplog} dump > /dev/null || exit 1
|
---|
116 | echo "iprop-log last-version"
|
---|
117 | ${iproplog} last-version > /dev/null || exit 1
|
---|
118 |
|
---|
119 | echo "check iprop replay"
|
---|
120 |
|
---|
121 | ${kadmin} dump out-current-db || exit 1
|
---|
122 | sort out-current-db > out-current-db-sort
|
---|
123 |
|
---|
124 | rm -f current-db*
|
---|
125 |
|
---|
126 | echo "replaying"
|
---|
127 | ${iproplog} replay > /dev/null || exit 1
|
---|
128 |
|
---|
129 | ${kadmin} dump out-current-db2 || exit 1
|
---|
130 | sort out-current-db2 > out-current-db2-sort
|
---|
131 |
|
---|
132 | # XXX database should really be the same afterward... :(
|
---|
133 | # cmp out-current-db-sort out-current-db2-sort || exit 1
|
---|
134 |
|
---|
135 |
|
---|
136 |
|
---|
137 | exit 0
|
---|