From f1a89fb37f9dde4ac1a7d01da215ee53d40e8e01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Love=20H=C3=B6rnquist=20=C3=85strand?= Date: Thu, 27 Oct 2005 19:04:33 +0000 Subject: [PATCH] Use NIST test certificates to test the x509 stack. git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@16249 ec53bebd-3082-4978-b11e-865c3cabbd6b --- lib/hx509/test_nist.in | 86 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 lib/hx509/test_nist.in diff --git a/lib/hx509/test_nist.in b/lib/hx509/test_nist.in new file mode 100644 index 000000000..2a2beaee8 --- /dev/null +++ b/lib/hx509/test_nist.in @@ -0,0 +1,86 @@ +#!/bin/sh +# +# Copyright (c) 2004 - 2005 Kungliga Tekniska Högskolan +# (Royal Institute of Technology, Stockholm, Sweden). +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# 2. Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# +# 3. Neither the name of the Institute nor the names of its contributors +# may be used to endorse or promote products derived from this software +# without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS +# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY +# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF +# SUCH DAMAGE. +# +# $Id$ +# + +srcdir="@srcdir@" +nistdir=/sources/pki/nist/PKITS_data/certs + +test -d "$nistdir" || exit 77 + +while read validate verify cert chain1 chain2 ; do + expr "$validate" : "#" > /dev/null && continue + + if ./hxtool validate $nistdir/$cert > /dev/null; then + if test "$validate" = "f"; then + echo "validate passed on fail: $cert" + exit 1 + fi + else + if test "$validate" = "p"; then + echo "validate failed on pass: $cert" + exit 1 + fi + fi + + if test "$verify" = "s"; then + continue + fi + + args="anchor:FILE:$nistdir/TrustAnchorRootCertificate.crt" + if test "X$chain1" != "X"; then + args="chain:FILE:$nistdir/$chain1 $args" + fi + if test "X$chain2" != "X"; then + args="chain:FILE:$nistdir/$chain2 $args" + fi + + if ./hxtool verify cert:FILE:$nistdir/$cert $args > /dev/null ; then + if test "$verify" = "f"; then + echo "validate passed on fail: $cert" + exit 1 + fi + else + if test "$verify" = "p"; then + echo "validate failed on pass: $cert" + exit 1 + fi + fi + +done < $srcdir/data/nist-data + + +echo "done!" + +exit 0