|
Packit Service |
4684c1 |
#!/bin/sh
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
# Copyright (C) 2016 Red Hat, Inc.
|
|
Packit Service |
4684c1 |
# Inc.
|
|
Packit Service |
4684c1 |
#
|
|
Packit Service |
4684c1 |
# Author: Nikos Mavrogiannopoulos
|
|
Packit Service |
4684c1 |
#
|
|
Packit Service |
4684c1 |
# This file is part of GnuTLS.
|
|
Packit Service |
4684c1 |
#
|
|
Packit Service |
4684c1 |
# GnuTLS is free software; you can redistribute it and/or modify it
|
|
Packit Service |
4684c1 |
# under the terms of the GNU General Public License as published by the
|
|
Packit Service |
4684c1 |
# Free Software Foundation; either version 3 of the License, or (at
|
|
Packit Service |
4684c1 |
# your option) any later version.
|
|
Packit Service |
4684c1 |
#
|
|
Packit Service |
4684c1 |
# GnuTLS is distributed in the hope that it will be useful, but
|
|
Packit Service |
4684c1 |
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
4684c1 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
4684c1 |
# General Public License for more details.
|
|
Packit Service |
4684c1 |
#
|
|
Packit Service |
4684c1 |
# You should have received a copy of the GNU General Public License
|
|
Packit Service |
4684c1 |
# along with GnuTLS; if not, write to the Free Software Foundation,
|
|
Packit Service |
4684c1 |
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
# This test cannot run under windows because it passes UTF8 data on command
|
|
Packit Service |
4684c1 |
# line. This seems not to work under windows. It intentionally depends on
|
|
Packit Service |
4684c1 |
# bash as few other shells cannot handle utf8 strings
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
srcdir="${srcdir:-.}"
|
|
Packit Service |
4684c1 |
CERTTOOL="${CERTTOOL:-../../src/certtool${EXEEXT}}"
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
if ! test -x "${CERTTOOL}"; then
|
|
Packit Service |
4684c1 |
exit 77
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
if ! test -z "${VALGRIND}"; then
|
|
Packit Service |
4684c1 |
VALGRIND="${LIBTOOL:-libtool} --mode=execute ${VALGRIND} --error-exitcode=1"
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
DIFF="${DIFF:-diff}"
|
|
Packit Service |
4684c1 |
DEBUG=""
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
TMPFILE=pkcs12-utf8.$$.tmp
|
|
Packit Service |
4684c1 |
TMPFILE_PEM=pkcs12-utf8.$$.tmp.pem
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
echo "Testing decoding of known keys"
|
|
Packit Service |
4684c1 |
echo "=============================="
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
ret=0
|
|
Packit Service |
4684c1 |
for p12 in "key-utf8-1.p12 ένα-δύο" "key-utf8-2.p12 ένα_δύο_τρία_τέσσερα"; do
|
|
Packit Service |
4684c1 |
set -- ${p12}
|
|
Packit Service |
4684c1 |
file="$1"
|
|
Packit Service |
4684c1 |
passwd="$2"
|
|
Packit Service |
4684c1 |
if test "x$DEBUG" != "x"; then
|
|
Packit Service |
4684c1 |
${VALGRIND} "${CERTTOOL}" -d 99 --p12-info --inder --password "${passwd}" \
|
|
Packit Service |
4684c1 |
--infile "${srcdir}/data/${file}"
|
|
Packit Service |
4684c1 |
else
|
|
Packit Service |
4684c1 |
${VALGRIND} "${CERTTOOL}" --p12-info --inder --password "${passwd}" \
|
|
Packit Service |
4684c1 |
--infile "${srcdir}/data/${file}" >/dev/null
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
rc=$?
|
|
Packit Service |
4684c1 |
if test ${rc} != 0; then
|
|
Packit Service |
4684c1 |
echo "PKCS12 FATAL ${p12}"
|
|
Packit Service |
4684c1 |
exit 1
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
done
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
echo ""
|
|
Packit Service |
4684c1 |
echo "Testing encoding/decoding"
|
|
Packit Service |
4684c1 |
echo "========================="
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
${VALGRIND} "${CERTTOOL}" --pkcs-cipher=aes-256 --to-p12 --password "ένα δύο tria" --p12-name "my-key" --load-certificate "${srcdir}/../certs/cert-ecc256.pem" --load-privkey "${srcdir}/../certs/ecc256.pem" --load-ca-certificate "${srcdir}/../certs/ca-cert-ecc.pem" --outder --outfile $TMPFILE >/dev/null
|
|
Packit Service |
4684c1 |
rc=$?
|
|
Packit Service |
4684c1 |
if test ${rc} != 0; then
|
|
Packit Service |
4684c1 |
echo "PKCS12 FATAL encoding"
|
|
Packit Service |
4684c1 |
exit 1
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
${VALGRIND} "${CERTTOOL}" --p12-info --inder --password "ένα δύο tria" --infile $TMPFILE >${TMPFILE_PEM} 2>/dev/null
|
|
Packit Service |
4684c1 |
rc=$?
|
|
Packit Service |
4684c1 |
if test ${rc} != 0; then
|
|
Packit Service |
4684c1 |
echo "PKCS12 FATAL decrypting/decoding"
|
|
Packit Service |
4684c1 |
exit 1
|
|
Packit Service |
4684c1 |
fi
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
rm -f "$TMPFILE" "$TMPFILE_PEM"
|
|
Packit Service |
4684c1 |
|
|
Packit Service |
4684c1 |
exit 0
|