Source code

Revision control

Copy as Markdown

Other Tools

#! /bin/bash
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
########################################################################
#
# tests/ec/ectest.sh
#
# needs to work on all Unix and Windows platforms
#
# special strings
# ---------------
# FIXME ... known problems, search for this string
# NOTE .... unexpected behavior
#
########################################################################
############################## ectest_init #############################
# local shell function to initialize this script
########################################################################
ectest_init()
{
SCRIPTNAME="ectest.sh"
if [ -z "${INIT_SOURCED}" -o "${INIT_SOURCED}" != "TRUE" ] ; then
cd ../common
. ./init.sh
fi
SCRIPTNAME="ectest.sh"
html_head "freebl and pk11 ectest tests"
}
ectest_cleanup()
{
html "</TABLE><BR>"
cd ${QADIR}
. common/cleanup.sh
}
ectest_genkeydb_test()
{
certutil -N -d "${HOSTDIR}" -f "${R_PWFILE}" 2>&1
if [ $? -ne 0 ]; then
return $?
fi
curves=( \
"curve25519" \
"secp256r1" \
"secp384r1" \
"secp521r1" \
)
for curve in "${curves[@]}"; do
echo "Test $curve key generation using certutil ..."
certutil -G -d "${HOSTDIR}" -k ec -q $curve -f "${R_PWFILE}" -z ${NOISE_FILE}
if [ $? -ne 0 ]; then
html_failed "ec test certutil keygen - $curve"
else
html_passed "ec test certutil keygen - $curve"
fi
done
echo "Test sect571r1 key generation using certutil that should fail because it's not implemented ..."
certutil -G -d "${HOSTDIR}" -k ec -q sect571r1 -f "${R_PWFILE}" -z ${NOISE_FILE}
if [ $? -eq 0 ]; then
html_failed "ec test certutil keygen - $curve"
else
html_passed "ec test certutil keygen - $curve"
fi
}
ectest_init
ectest_genkeydb_test
# TODO: expose individual tests and failures instead of overall
if [ -f ${BINDIR}/fbectest ]; then
FB_ECTEST_OUT=$(fbectest -n -d 2>&1)
FB_ECTEST_OUT=`echo $FB_ECTEST_OUT | grep -i 'not okay\|Assertion failure'`
if [ -n "$FB_ECTEST_OUT" ] ; then
html_failed "freebl ec tests"
else
html_passed "freebl ec tests"
fi
fi
if [ -f ${BINDIR}/pk11ectest ]; then
PK11_ECTEST_OUT=$(pk11ectest -n -d 2>&1)
PK11_ECTEST_OUT=`echo $PK11_ECTEST_OUT | grep -i 'not okay\|Assertion failure'`
if [ -n "$PK11_ECTEST_OUT" ] ; then
html_failed "pk11 ec tests"
else
html_passed "pk11 ec tests"
fi
fi
ectest_cleanup