a403a6449bb74f68e7c80e55e9f2efef6e72e447
[openssl.git] / test / testtsa
1 #!/bin/sh
2
3 #
4 # A few very basic tests for the 'ts' time stamping authority command.
5 #
6
7 SH="/bin/sh"
8 PATH=../../apps:$PATH
9 export SH PATH
10
11 OPENSSL_CONF="../CAtsa.cnf"
12 export OPENSSL_CONF
13
14 OPENSSL="`pwd`/../util/opensslwrap.sh"
15 export OPENSSL
16
17 error () {
18
19     echo "TSA test failed!" >&2
20     exit 1
21 }
22
23 setup_dir () {
24
25     rm -rf tsa 2>/dev/null
26     mkdir tsa
27     cd ./tsa
28 }
29
30 clean_up_dir () {
31
32     cd ..
33     rm -rf tsa
34 }
35
36 create_ca () {
37
38     echo "Creating a new CA for the TSA tests..."
39     /bin/rm -fr demoCA
40     $SH ../../apps/CA.sh -newca <<EOF
41
42 HU
43 Budapest
44 Budapest
45 Gov-CA Ltd.
46 ca1
47 EOF
48     test $? != 0 && error
49 }
50
51 create_tsa_cert () {
52
53     INDEX=$1
54     EXT=$2
55     ../../util/shlib_wrap.sh ../../apps/openssl req -new -out tsa_req${INDEX}.pem -keyout tsa_key${INDEX}.pem <<EOF
56 HU
57 Budapest
58 Buda
59 Hun-TSA Ltd.
60 tsa${INDEX}
61 EOF
62     test $? != 0 && error
63
64     ../../util/shlib_wrap.sh ../../apps/openssl ca -in tsa_req${INDEX}.pem -out tsa_cert${INDEX}.pem \
65         -extensions $EXT <<EOF
66 y
67 y
68 EOF
69     test $? != 0 && error
70 }
71
72 print_request () {
73
74     ../../util/shlib_wrap.sh ../../apps/openssl ts -query -in $1 -text
75 }
76
77 create_time_stamp_request1 () {
78
79     ../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../testtsa -policy tsa_policy1 -cert -out req1.tsq
80     test $? != 0 && error
81 }
82
83 create_time_stamp_request2 () {
84
85     ../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../testtsa -policy tsa_policy2 -no_nonce \
86         -out req2.tsq
87     test $? != 0 && error
88 }
89
90 create_time_stamp_request3 () {
91
92     ../../util/shlib_wrap.sh ../../apps/openssl ts -query -data ../CAtsa.cnf -no_nonce -out req3.tsq
93     test $? != 0 && error
94 }
95
96 print_response () {
97
98     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $1 -text
99     test $? != 0 && error
100 }
101
102 create_time_stamp_response () {
103
104     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -section $3 -queryfile $1 -out $2
105     test $? != 0 && error
106 }
107
108 time_stamp_response_token_test () {
109
110     RESPONSE2=$2.copy.tsr
111     TOKEN_DER=$2.token.der
112     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -out $TOKEN_DER -token_out
113     test $? != 0 && error
114     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $TOKEN_DER -token_in -out $RESPONSE2
115     test $? != 0 && error
116     cmp $RESPONSE2 $2
117     test $? != 0 && error
118     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -text -token_out
119     test $? != 0 && error
120     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $TOKEN_DER -token_in -text -token_out
121     test $? != 0 && error
122     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -queryfile $1 -text -token_out
123     test $? != 0 && error
124 }
125
126 verify_time_stamp_response () {
127
128     ../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2 -CAfile demoCA/cacert.pem \
129         -untrusted tsa_cert1.pem
130     test $? != 0 && error
131     ../../util/shlib_wrap.sh ../../apps/openssl ts -verify -data $3 -in $2 -CAfile demoCA/cacert.pem \
132         -untrusted tsa_cert1.pem
133     test $? != 0 && error
134 }
135
136 verify_time_stamp_token () {
137
138     # create the token from the response first
139     ../../util/shlib_wrap.sh ../../apps/openssl ts -reply -in $2 -out $2.token -token_out
140     test $? != 0 && error
141     ../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2.token -token_in \
142         -CAfile demoCA/cacert.pem -untrusted tsa_cert1.pem
143     test $? != 0 && error
144     ../../util/shlib_wrap.sh ../../apps/openssl ts -verify -data $3 -in $2.token -token_in \
145         -CAfile demoCA/cacert.pem -untrusted tsa_cert1.pem
146     test $? != 0 && error
147 }
148
149 verify_time_stamp_response_fail () {
150
151     ../../util/shlib_wrap.sh ../../apps/openssl ts -verify -queryfile $1 -in $2 -CAfile demoCA/cacert.pem \
152         -untrusted tsa_cert1.pem
153     # Checks if the verification failed, as it should have.
154     test $? == 0 && error
155     echo Ok
156 }
157
158 # main functions
159
160 echo "Setting up TSA test directory..."
161 setup_dir
162
163 echo "Creating CA for TSA tests..."
164 create_ca
165
166 echo "Creating tsa_cert1.pem TSA server cert..."
167 create_tsa_cert 1 tsa_cert
168
169 echo "Creating tsa_cert2.pem non-TSA server cert..."
170 create_tsa_cert 2 non_tsa_cert
171
172 echo "Creating req1.req time stamp request for file testtsa..."
173 create_time_stamp_request1
174
175 echo "Printing req1.req..."
176 print_request req1.tsq
177
178 echo "Generating valid response for req1.req..."
179 create_time_stamp_response req1.tsq resp1.tsr tsa_config1
180
181 echo "Printing response..."
182 print_response resp1.tsr
183
184 echo "Verifying valid response..."
185 verify_time_stamp_response req1.tsq resp1.tsr ../testtsa
186
187 echo "Verifying valid token..."
188 verify_time_stamp_token req1.tsq resp1.tsr ../testtsa
189
190 # The tests below are commented out, because invalid signer certificates
191 # can no longer be specified in the config file.
192
193 # echo "Generating _invalid_ response for req1.req..."
194 # create_time_stamp_response req1.tsq resp1_bad.tsr tsa_config2
195
196 # echo "Printing response..."
197 # print_response resp1_bad.tsr
198
199 # echo "Verifying invalid response, it should fail..."
200 # verify_time_stamp_response_fail req1.tsq resp1_bad.tsr
201
202 echo "Creating req2.req time stamp request for file testtsa..."
203 create_time_stamp_request2
204
205 echo "Printing req2.req..."
206 print_request req2.tsq
207
208 echo "Generating valid response for req2.req..."
209 create_time_stamp_response req2.tsq resp2.tsr tsa_config1
210
211 echo "Checking '-token_in' and '-token_out' options with '-reply'..."
212 time_stamp_response_token_test req2.tsq resp2.tsr
213
214 echo "Printing response..."
215 print_response resp2.tsr
216
217 echo "Verifying valid response..."
218 verify_time_stamp_response req2.tsq resp2.tsr ../testtsa
219
220 echo "Verifying response against wrong request, it should fail..."
221 verify_time_stamp_response_fail req1.tsq resp2.tsr
222
223 echo "Verifying response against wrong request, it should fail..."
224 verify_time_stamp_response_fail req2.tsq resp1.tsr
225
226 echo "Creating req3.req time stamp request for file CAtsa.cnf..."
227 create_time_stamp_request3
228
229 echo "Printing req3.req..."
230 print_request req3.tsq
231
232 echo "Verifying response against wrong request, it should fail..."
233 verify_time_stamp_response_fail req3.tsq resp1.tsr
234
235 echo "Cleaning up..."
236 clean_up_dir
237
238 exit 0