xref: /freebsd/crypto/heimdal/lib/hx509/test_cert.in (revision 6a068746777241722b2b32c5d0bc443a2a64d80b)
1c19800e8SDoug Rabson#!/bin/sh
2c19800e8SDoug Rabson#
3*ae771770SStanislav Sedov# Copyright (c) 2007 Kungliga Tekniska Högskolan
4c19800e8SDoug Rabson# (Royal Institute of Technology, Stockholm, Sweden).
5c19800e8SDoug Rabson# All rights reserved.
6c19800e8SDoug Rabson#
7c19800e8SDoug Rabson# Redistribution and use in source and binary forms, with or without
8c19800e8SDoug Rabson# modification, are permitted provided that the following conditions
9c19800e8SDoug Rabson# are met:
10c19800e8SDoug Rabson#
11c19800e8SDoug Rabson# 1. Redistributions of source code must retain the above copyright
12c19800e8SDoug Rabson#    notice, this list of conditions and the following disclaimer.
13c19800e8SDoug Rabson#
14c19800e8SDoug Rabson# 2. Redistributions in binary form must reproduce the above copyright
15c19800e8SDoug Rabson#    notice, this list of conditions and the following disclaimer in the
16c19800e8SDoug Rabson#    documentation and/or other materials provided with the distribution.
17c19800e8SDoug Rabson#
18c19800e8SDoug Rabson# 3. Neither the name of the Institute nor the names of its contributors
19c19800e8SDoug Rabson#    may be used to endorse or promote products derived from this software
20c19800e8SDoug Rabson#    without specific prior written permission.
21c19800e8SDoug Rabson#
22c19800e8SDoug Rabson# THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
23c19800e8SDoug Rabson# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24c19800e8SDoug Rabson# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25c19800e8SDoug Rabson# ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
26c19800e8SDoug Rabson# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27c19800e8SDoug Rabson# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28c19800e8SDoug Rabson# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29c19800e8SDoug Rabson# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30c19800e8SDoug Rabson# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31c19800e8SDoug Rabson# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32c19800e8SDoug Rabson# SUCH DAMAGE.
33c19800e8SDoug Rabson#
34c19800e8SDoug Rabson# $Id: test_chain.in 20809 2007-06-03 03:19:06Z lha $
35c19800e8SDoug Rabson#
36c19800e8SDoug Rabson
37c19800e8SDoug Rabsonsrcdir="@srcdir@"
38c19800e8SDoug Rabsonobjdir="@objdir@"
39c19800e8SDoug Rabson
40c19800e8SDoug Rabsonhxtool="${TESTS_ENVIRONMENT} ./hxtool ${stat}"
41c19800e8SDoug Rabsonif ${hxtool} info | grep 'rsa: hcrypto null RSA' > /dev/null ; then
42c19800e8SDoug Rabson    exit 77
43c19800e8SDoug Rabsonfi
44c19800e8SDoug Rabsonif ${hxtool} info | grep 'rand: not available' > /dev/null ; then
45c19800e8SDoug Rabson    exit 77
46c19800e8SDoug Rabsonfi
47c19800e8SDoug Rabson
48c19800e8SDoug Rabsonecho "print DIR"
49c19800e8SDoug Rabson${hxtool} print --content DIR:$srcdir/data > /dev/null || exit 1
50c19800e8SDoug Rabson
51c19800e8SDoug Rabsonecho "print FILE"
52c19800e8SDoug Rabsonfor a in $srcdir/data/*.crt; do
53c19800e8SDoug Rabson    ${hxtool} print --content FILE:"$a" > /dev/null 2>/dev/null
54c19800e8SDoug Rabsondone
55c19800e8SDoug Rabson
56c19800e8SDoug Rabsonecho "print NULL"
57c19800e8SDoug Rabson${hxtool} print --content NULL: > /dev/null || exit 1
58c19800e8SDoug Rabson
59c19800e8SDoug Rabsonecho "copy dance"
60c19800e8SDoug Rabson${hxtool} certificate-copy \
61c19800e8SDoug Rabson    FILE:${srcdir}/data/test.crt PEM-FILE:cert-pem.tmp || exit 1
62c19800e8SDoug Rabson
63c19800e8SDoug Rabson${hxtool} certificate-copy PEM-FILE:cert-pem.tmp DER-FILE:cert-der.tmp || exit 1
64c19800e8SDoug Rabson${hxtool} certificate-copy DER-FILE:cert-der.tmp PEM-FILE:cert-pem2.tmp || exit 1
65c19800e8SDoug Rabson
66c19800e8SDoug Rabsoncmp cert-pem.tmp cert-pem2.tmp || exit 1
67c19800e8SDoug Rabson
68*ae771770SStanislav Sedovecho "verify n0ll cert (fail)"
69*ae771770SStanislav Sedov${hxtool} verify --missing-revoke \
70*ae771770SStanislav Sedov	--hostname=foo.com \
71*ae771770SStanislav Sedov	cert:FILE:$srcdir/data/n0ll.pem \
72*ae771770SStanislav Sedov	anchor:FILE:$srcdir/data/n0ll.pem && exit 1
73*ae771770SStanislav Sedov
74*ae771770SStanislav Sedovecho "verify n0ll cert (fail)"
75*ae771770SStanislav Sedov${hxtool} verify --missing-revoke \
76*ae771770SStanislav Sedov	cert:FILE:$srcdir/data/n0ll.pem \
77*ae771770SStanislav Sedov	anchor:FILE:$srcdir/data/n0ll.pem && exit 1
78*ae771770SStanislav Sedov
79*ae771770SStanislav Sedovecho "check that windows cert with utf16 in printable string works"
80*ae771770SStanislav Sedov${hxtool} verify --missing-revoke \
81*ae771770SStanislav Sedov	cert:FILE:$srcdir/data/win-u16-in-printablestring.der \
82*ae771770SStanislav Sedov	anchor:FILE:$srcdir/data/win-u16-in-printablestring.der || exit 1
83c19800e8SDoug Rabson
84c19800e8SDoug Rabsonexit 0
85