New function DSA_dup_DH, and fixes for bugs that were found
[openssl.git] / test / Makefile.ssl
1 #
2 # test/Makefile.ssl
3 #
4
5 DIR=            test
6 TOP=            ..
7 CC=             cc
8 INCLUDES=       -I../include
9 CFLAG=          -g
10 INSTALL_PREFIX=
11 OPENSSLDIR=     /usr/local/ssl
12 INSTALLTOP=     /usr/local/ssl
13 MAKEFILE=       Makefile.ssl
14 MAKE=           make -f $(MAKEFILE)
15 MAKEDEPEND=     $(TOP)/util/domd $(TOP)
16
17 PEX_LIBS=
18 EX_LIBS= #-lnsl -lsocket
19
20 CFLAGS= $(INCLUDES) $(CFLAG)
21
22 GENERAL=Makefile.ssl maketests.com \
23         tests.com testenc.com tx509.com trsa.com tcrl.com tsid.com treq.com \
24         tpkcs7.com tpkcs7d.com tverify.com testgen.com testss.com testssl.com \
25         testca.com VMSca-response.1 VMSca-response.2
26
27 DLIBCRYPTO= ../libcrypto.a
28 DLIBSSL= ../libssl.a
29 LIBCRYPTO= -L.. -lcrypto
30 LIBSSL= -L.. -lssl
31
32 BNTEST=         bntest
33 EXPTEST=        exptest
34 IDEATEST=       ideatest
35 SHATEST=        shatest
36 SHA1TEST=       sha1test
37 MDC2TEST=       mdc2test
38 RMDTEST=        rmdtest
39 MD2TEST=        md2test
40 MD5TEST=        md5test
41 HMACTEST=       hmactest
42 RC2TEST=        rc2test
43 RC4TEST=        rc4test
44 RC5TEST=        rc5test
45 BFTEST=         bftest
46 CASTTEST=       casttest
47 DESTEST=        destest
48 RANDTEST=       randtest
49 DHTEST=         dhtest
50 DSATEST=        dsatest
51 METHTEST=       methtest
52 SSLTEST=        ssltest
53 RSATEST=        rsa_oaep_test
54
55 EXE=    $(BNTEST) $(IDEATEST) $(MD2TEST)  $(MD5TEST) $(HMACTEST) \
56         $(RC2TEST) $(RC4TEST) $(RC5TEST) \
57         $(DESTEST) $(SHATEST) $(SHA1TEST) $(MDC2TEST) $(RMDTEST) \
58         $(RANDTEST) $(DHTEST) \
59         $(BFTEST) $(CASTTEST) $(SSLTEST) $(EXPTEST) $(DSATEST) $(RSATEST)
60
61 # $(METHTEST)
62
63 OBJ=    $(BNTEST).o $(IDEATEST).o $(MD2TEST).o  $(MD5TEST).o $(HMACTEST).o \
64         $(RC2TEST).o $(RC4TEST).o $(RC5TEST).o \
65         $(DESTEST).o $(SHATEST).o $(SHA1TEST).o $(MDC2TEST).o $(RMDTEST).o \
66         $(RANDTEST).o $(DHTEST).o $(CASTTEST).o \
67         $(BFTEST).o  $(SSLTEST).o  $(DSATEST).o  $(EXPTEST).o $(RSATEST).o
68 SRC=    $(BNTEST).c $(IDEATEST).c $(MD2TEST).c  $(MD5TEST).c  $(HMACTEST).c \
69         $(RC2TEST).c $(RC4TEST).c $(RC5TEST).c \
70         $(DESTEST).c $(SHATEST).c $(SHA1TEST).c $(MDC2TEST).c $(RMDTEST).c \
71         $(RANDTEST).c $(DHTEST).c $(CASTTEST).c \
72         $(BFTEST).c  $(SSLTEST).c $(DSATEST).c   $(EXPTEST).c $(RSATEST).c
73
74 EXHEADER= 
75 HEADER= $(EXHEADER)
76
77 ALL=    $(GENERAL) $(SRC) $(HEADER)
78
79 top:
80         (cd ..; $(MAKE) DIRS=$(DIR) all)
81
82 all:    exe
83
84 exe:    $(EXE)
85
86 files:
87         $(PERL) $(TOP)/util/files.pl Makefile.ssl >> $(TOP)/MINFO
88
89 links:
90         @@$(TOP)/util/point.sh Makefile.ssl Makefile
91
92 errors:
93
94 install:
95
96 tags:
97         ctags $(SRC)
98
99 tests:  exe apps \
100         test_des test_idea test_sha test_md5 test_hmac test_md2 test_mdc2 \
101         test_rc2 test_rc4 test_rc5 test_bf test_cast \
102         test_rand test_bn test_enc test_x509 test_rsa test_crl test_sid \
103         test_reqgen test_req test_pkcs7 test_verify test_dh test_dsa \
104         test_ss test_ssl test_ca
105
106 apps:
107         @(cd ../apps; $(MAKE)  CC='${CC}' CFLAG='${CFLAG}' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' all)
108
109 test_des:
110         ./$(DESTEST)
111
112 test_idea:
113         ./$(IDEATEST)
114
115 test_sha:
116         ./$(SHATEST)
117         ./$(SHA1TEST)
118
119 test_mdc2:
120         ./$(MDC2TEST)
121
122 test_md5:
123         ./$(MD5TEST)
124
125 test_hmac:
126         ./$(HMACTEST)
127
128 test_md2:
129         ./$(MD2TEST)
130
131 test_rmd:
132         ./$(RMDTEST)
133
134 test_bf:
135         ./$(BFTEST)
136
137 test_cast:
138         ./$(CASTTEST)
139
140 test_rc2:
141         ./$(RC2TEST)
142
143 test_rc4:
144         ./$(RC4TEST)
145
146 test_rc5:
147         ./$(RC5TEST)
148
149 test_rand:
150         ./$(RANDTEST)
151
152 test_enc:
153         @sh ./testenc
154
155 test_x509:
156         echo test normal x509v1 certificate
157         sh ./tx509 2>/dev/null
158         echo test first x509v3 certificate
159         sh ./tx509 v3-cert1.pem 2>/dev/null
160         echo test second x509v3 certificate
161         sh ./tx509 v3-cert2.pem 2>/dev/null
162
163 test_rsa:
164         @sh ./trsa 2>/dev/null
165         ./$(RSATEST)
166
167 test_crl:
168         @sh ./tcrl 2>/dev/null
169
170 test_sid:
171         @sh ./tsid 2>/dev/null
172
173 test_req:
174         @sh ./treq 2>/dev/null
175         @sh ./treq testreq2.pem 2>/dev/null
176
177 test_pkcs7:
178         @sh ./tpkcs7 2>/dev/null
179         @sh ./tpkcs7d 2>/dev/null
180
181 test_bn:
182         @echo starting big number library test, could take a while...
183         @(./$(BNTEST)|bc) | awk '{ \
184 if ($$0 != "0") {print "error"; exit(1); } \
185 if (((NR+1)%64) == 0) print NR+1," tests done"; }'
186         @echo 'test a^b%c implementations'
187         ./$(EXPTEST)
188
189 test_verify:
190         @echo "The following command should have some OK's and some failures"
191         @echo "There are definitly a few expired certificates"
192         ../apps/openssl verify -CApath ../certs ../certs/*.pem
193
194 test_dh:
195         @echo "Generate as set of DH parameters"
196         ./$(DHTEST)
197
198 test_dsa:
199         @echo "Generate as set of DSA parameters"
200         ./$(DSATEST)
201
202 test_reqgen:
203         @echo "Generate and verify a certificate request"
204         @sh ./testgen
205
206 test_ss:
207         @echo "Generate and certify a test certificate"
208         @sh ./testss
209
210 test_ssl:
211         @echo "test SSL protocol"
212         @sh ./testssl
213
214 test_ca:
215         @echo "Generate and certify a test certificate via the 'ca' program"
216         @sh ./testca
217
218 lint:
219         lint -DLINT $(INCLUDES) $(SRC)>fluff
220
221 depend:
222         $(MAKEDEPEND) $(INCLUDES) $(DEPFLAG) $(PROGS) $(SRC)
223
224 dclean:
225         $(PERL) -pe 'if (/^# DO NOT DELETE THIS LINE/) {print; exit(0);}' $(MAKEFILE) >Makefile.new
226         mv -f Makefile.new $(MAKEFILE)
227
228 clean:
229         rm -f *.o *.obj lib tags core .pure .nfs* *.old *.bak fluff $(EXE) *.ss log
230
231 $(DLIBSSL):
232         (cd ../ssl; $(MAKE))
233
234 $(DLIBCRYPTO):
235         (cd ../crypto; $(MAKE))
236
237 $(RSATEST): $(RSATEST).o $(DLIBCRYPTO)
238         $(CC) -o $(RSATEST) $(CFLAGS) $(RSATEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
239
240 $(BNTEST): $(BNTEST).o $(DLIBCRYPTO)
241         $(CC) -o $(BNTEST) $(CFLAGS) $(BNTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
242
243 $(EXPTEST): $(EXPTEST).o $(DLIBCRYPTO)
244         $(CC) -o $(EXPTEST) $(CFLAGS) $(EXPTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
245
246 $(IDEATEST): $(IDEATEST).o $(DLIBCRYPTO)
247         $(CC) -o $(IDEATEST) $(CFLAGS) $(IDEATEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
248
249 $(MD2TEST): $(MD2TEST).o $(DLIBCRYPTO)
250         $(CC) -o $(MD2TEST) $(CFLAGS) $(MD2TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
251
252 $(SHATEST): $(SHATEST).o $(DLIBCRYPTO)
253         $(CC) -o $(SHATEST) $(CFLAGS) $(SHATEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
254
255 $(SHA1TEST): $(SHA1TEST).o $(DLIBCRYPTO)
256         $(CC) -o $(SHA1TEST) $(CFLAGS) $(SHA1TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
257
258 $(RMDTEST): $(RMDTEST).o $(DLIBCRYPTO)
259         $(CC) -o $(RMDTEST) $(CFLAGS) $(RMDTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
260
261 $(MDC2TEST): $(MDC2TEST).o $(DLIBCRYPTO)
262         $(CC) -o $(MDC2TEST) $(CFLAGS) $(MDC2TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
263
264 $(MD5TEST): $(MD5TEST).o $(DLIBCRYPTO)
265         $(CC) -o $(MD5TEST) $(CFLAGS) $(MD5TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
266
267 $(HMACTEST): $(HMACTEST).o $(DLIBCRYPTO)
268         $(CC) -o $(HMACTEST) $(CFLAGS) $(HMACTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
269
270 $(RC2TEST): $(RC2TEST).o $(DLIBCRYPTO)
271         $(CC) -o $(RC2TEST) $(CFLAGS) $(RC2TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
272
273 $(BFTEST): $(BFTEST).o $(DLIBCRYPTO)
274         $(CC) -o $(BFTEST) $(CFLAGS) $(BFTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
275
276 $(CASTTEST): $(CASTTEST).o $(DLIBCRYPTO)
277         $(CC) -o $(CASTTEST) $(CFLAGS) $(CASTTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
278
279 $(RC4TEST): $(RC4TEST).o $(DLIBCRYPTO)
280         $(CC) -o $(RC4TEST) $(CFLAGS) $(RC4TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
281
282 $(RC5TEST): $(RC5TEST).o $(DLIBCRYPTO)
283         $(CC) -o $(RC5TEST) $(CFLAGS) $(RC5TEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
284
285 $(DESTEST): $(DESTEST).o $(DLIBCRYPTO)
286         $(CC) -o $(DESTEST) $(CFLAGS) $(DESTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
287
288 $(RANDTEST): $(RANDTEST).o $(DLIBCRYPTO)
289         $(CC) -o $(RANDTEST) $(CFLAGS) $(RANDTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
290
291 $(DHTEST): $(DHTEST).o $(DLIBCRYPTO)
292         $(CC) -o $(DHTEST) $(CFLAGS) $(DHTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
293
294 $(DSATEST): $(DSATEST).o $(DLIBCRYPTO)
295         $(CC) -o $(DSATEST) $(CFLAGS) $(DSATEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
296
297 $(METHTEST): $(METHTEST).o $(DLIBCRYPTO)
298         $(CC) -o $(METHTEST) $(CFLAGS) $(METHTEST).o $(PEX_LIBS) $(LIBCRYPTO) $(EX_LIBS)
299
300 $(SSLTEST): $(SSLTEST).o $(DLIBSSL) $(DLIBCRYPTO)
301         $(CC) -o $(SSLTEST) $(CFLAGS) $(SSLTEST).o $(PEX_LIBS) $(LIBSSL) $(LIBCRYPTO) $(EX_LIBS)
302
303 # DO NOT DELETE THIS LINE -- make depend depends on it.
304
305 bftest.o: ../include/openssl/blowfish.h
306 bntest.o: ../include/openssl/asn1.h ../include/openssl/bio.h
307 bntest.o: ../include/openssl/blowfish.h ../include/openssl/bn.h
308 bntest.o: ../include/openssl/cast.h ../include/openssl/crypto.h
309 bntest.o: ../include/openssl/des.h ../include/openssl/dh.h
310 bntest.o: ../include/openssl/dsa.h ../include/openssl/e_os.h
311 bntest.o: ../include/openssl/e_os2.h ../include/openssl/err.h
312 bntest.o: ../include/openssl/evp.h ../include/openssl/idea.h
313 bntest.o: ../include/openssl/md2.h ../include/openssl/md5.h
314 bntest.o: ../include/openssl/mdc2.h ../include/openssl/objects.h
315 bntest.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
316 bntest.o: ../include/openssl/pkcs7.h ../include/openssl/rand.h
317 bntest.o: ../include/openssl/rc2.h ../include/openssl/rc4.h
318 bntest.o: ../include/openssl/rc5.h ../include/openssl/ripemd.h
319 bntest.o: ../include/openssl/rsa.h ../include/openssl/safestack.h
320 bntest.o: ../include/openssl/sha.h ../include/openssl/stack.h
321 bntest.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h
322 casttest.o: ../include/openssl/cast.h
323 destest.o: ../include/openssl/des.h ../include/openssl/e_os2.h
324 destest.o: ../include/openssl/opensslconf.h
325 dhtest.o: ../include/openssl/bio.h ../include/openssl/bn.h
326 dhtest.o: ../include/openssl/crypto.h ../include/openssl/dh.h
327 dhtest.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
328 dhtest.o: ../include/openssl/stack.h
329 dsatest.o: ../include/openssl/bio.h ../include/openssl/bn.h
330 dsatest.o: ../include/openssl/crypto.h ../include/openssl/dh.h
331 dsatest.o: ../include/openssl/dsa.h ../include/openssl/err.h
332 dsatest.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
333 dsatest.o: ../include/openssl/rand.h ../include/openssl/stack.h
334 exptest.o: ../include/openssl/bio.h ../include/openssl/bn.h
335 exptest.o: ../include/openssl/crypto.h ../include/openssl/err.h
336 exptest.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
337 exptest.o: ../include/openssl/rand.h ../include/openssl/stack.h
338 hmactest.o: ../include/openssl/asn1.h ../include/openssl/bio.h
339 hmactest.o: ../include/openssl/blowfish.h ../include/openssl/bn.h
340 hmactest.o: ../include/openssl/cast.h ../include/openssl/crypto.h
341 hmactest.o: ../include/openssl/des.h ../include/openssl/dh.h
342 hmactest.o: ../include/openssl/dsa.h ../include/openssl/e_os2.h
343 hmactest.o: ../include/openssl/evp.h ../include/openssl/hmac.h
344 hmactest.o: ../include/openssl/idea.h ../include/openssl/md2.h
345 hmactest.o: ../include/openssl/md5.h ../include/openssl/mdc2.h
346 hmactest.o: ../include/openssl/objects.h ../include/openssl/opensslconf.h
347 hmactest.o: ../include/openssl/opensslv.h ../include/openssl/rc2.h
348 hmactest.o: ../include/openssl/rc4.h ../include/openssl/rc5.h
349 hmactest.o: ../include/openssl/ripemd.h ../include/openssl/rsa.h
350 hmactest.o: ../include/openssl/safestack.h ../include/openssl/sha.h
351 hmactest.o: ../include/openssl/stack.h
352 ideatest.o: ../include/openssl/idea.h ../include/openssl/opensslconf.h
353 md2test.o: ../include/openssl/md2.h ../include/openssl/opensslconf.h
354 md5test.o: ../include/openssl/md5.h
355 mdc2test.o: ../include/openssl/des.h ../include/openssl/e_os2.h
356 mdc2test.o: ../include/openssl/mdc2.h ../include/openssl/opensslconf.h
357 randtest.o: ../include/openssl/rand.h
358 rc2test.o: ../include/openssl/opensslconf.h ../include/openssl/rc2.h
359 rc4test.o: ../include/openssl/opensslconf.h ../include/openssl/rc4.h
360 rc5test.o: ../include/openssl/rc5.h
361 rmdtest.o: ../include/openssl/ripemd.h
362 rsa_oaep_test.o: ../include/openssl/bn.h ../include/openssl/crypto.h
363 rsa_oaep_test.o: ../include/openssl/e_os.h ../include/openssl/e_os2.h
364 rsa_oaep_test.o: ../include/openssl/err.h ../include/openssl/opensslconf.h
365 rsa_oaep_test.o: ../include/openssl/opensslv.h ../include/openssl/rsa.h
366 rsa_oaep_test.o: ../include/openssl/stack.h
367 sha1test.o: ../include/openssl/sha.h
368 shatest.o: ../include/openssl/sha.h
369 ssltest.o: ../include/openssl/asn1.h ../include/openssl/bio.h
370 ssltest.o: ../include/openssl/blowfish.h ../include/openssl/bn.h
371 ssltest.o: ../include/openssl/buffer.h ../include/openssl/cast.h
372 ssltest.o: ../include/openssl/crypto.h ../include/openssl/des.h
373 ssltest.o: ../include/openssl/dh.h ../include/openssl/dsa.h
374 ssltest.o: ../include/openssl/e_os.h ../include/openssl/e_os2.h
375 ssltest.o: ../include/openssl/err.h ../include/openssl/evp.h
376 ssltest.o: ../include/openssl/idea.h ../include/openssl/lhash.h
377 ssltest.o: ../include/openssl/md2.h ../include/openssl/md5.h
378 ssltest.o: ../include/openssl/mdc2.h ../include/openssl/objects.h
379 ssltest.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
380 ssltest.o: ../include/openssl/pem.h ../include/openssl/pem2.h
381 ssltest.o: ../include/openssl/pkcs7.h ../include/openssl/rc2.h
382 ssltest.o: ../include/openssl/rc4.h ../include/openssl/rc5.h
383 ssltest.o: ../include/openssl/ripemd.h ../include/openssl/rsa.h
384 ssltest.o: ../include/openssl/safestack.h ../include/openssl/sha.h
385 ssltest.o: ../include/openssl/ssl.h ../include/openssl/ssl2.h
386 ssltest.o: ../include/openssl/ssl23.h ../include/openssl/ssl3.h
387 ssltest.o: ../include/openssl/stack.h ../include/openssl/tls1.h
388 ssltest.o: ../include/openssl/x509.h ../include/openssl/x509_vfy.h