#!/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/ssl_gtests/ssl_gtests.sh # # Script to drive the ssl gtest unit tests # # needs to work on all Unix and Windows platforms # # special strings # --------------- # FIXME ... known problems, search for this string # NOTE .... unexpected behavior # ######################################################################## ssl_gtest_certs() { mkdir -p "${SSLGTESTDIR}" cd "${SSLGTESTDIR}" PROFILEDIR=`pwd` if [ "${OS_ARCH}" = "WINNT" -a "$OS_NAME" = "CYGWIN_NT" ]; then PROFILEDIR=`cygpath -m "${PROFILEDIR}"` fi ${BINDIR}/certutil -N -d "${PROFILEDIR}" --empty-password 2>&1 html_msg $? 0 "create ssl_gtest database" pushd "${QADIR}" . common/certsetup.sh popd counter=0 make_cert client rsa sign make_cert rsa rsa sign kex make_cert rsa2048 rsa2048 sign kex make_cert rsa8192 rsa8192 sign kex make_cert rsa_sign rsa sign make_cert rsa_pss rsapss sign make_cert rsa_pss384 rsapss384 sign make_cert rsa_pss512 rsapss512 sign make_cert rsa_pss_noparam rsapss_noparam sign make_cert rsa_decrypt rsa kex make_cert ecdsa256 p256 sign make_cert ecdsa384 p384 sign make_cert ecdsa521 p521 sign make_cert ecdh_ecdsa p256 kex make_cert rsa_ca rsa_ca ca make_cert rsa_chain rsa_chain sign make_cert rsa_pss_ca rsapss_ca ca make_cert rsa_pss_chain rsapss_chain sign make_cert rsa_ca_rsa_pss_chain rsa_ca_rsapss_chain sign make_cert ecdh_rsa ecdh_rsa kex make_cert dsa dsa sign make_cert delegator_ecdsa256 delegator_p256 sign make_cert delegator_rsae2048 delegator_rsae2048 sign } ############################## ssl_gtest_init ########################## # local shell function to initialize this script ######################################################################## ssl_gtest_init() { SCRIPTNAME=ssl_gtest.sh # sourced - $0 would point to all.sh if [ -z "${CLEANUP}" ] ; then # if nobody else is responsible for CLEANUP="${SCRIPTNAME}" # cleaning this script will do it fi if [ -z "${INIT_SOURCED}" -o "${INIT_SOURCED}" != "TRUE" ]; then cd ../common . ./init.sh fi SCRIPTNAME=ssl_gtest.sh html_head SSL Gtests if [ ! -d "${SSLGTESTDIR}" ]; then ssl_gtest_certs fi cd "${SSLGTESTDIR}" } ########################## ssl_gtest_start ######################### # Local function to actually start the test #################################################################### ssl_gtest_start() { if [ ! -f ${BINDIR}/ssl_gtest ]; then html_unknown "Skipping ssl_gtest (not built)" return fi SSLGTESTREPORT="${SSLGTESTDIR}/report.xml" local nshards=1 local prefix="" local postfix="" export -f parallel_fallback # Determine the number of chunks. if [ -n "$GTESTFILTER" ]; then echo "DEBUG: Not parallelizing ssl_gtests because \$GTESTFILTER is set" elif type parallel 2>/dev/null; then nshards=$(parallel --number-of-cores || 1) fi if [ "$nshards" != 1 ]; then local indices=$(for ((i=0; i<$nshards; i++)); do echo $i; done) prefix="parallel -j$nshards --line-buffer --halt soon,fail=1" postfix="\&\& exit 0 \|\| exit 1 ::: $indices" fi echo "DEBUG: ssl_gtests will be divided into $nshards chunk(s)" # Run tests. ${prefix:-parallel_fallback} \ GTEST_SHARD_INDEX={} \ GTEST_TOTAL_SHARDS=$nshards \ DYLD_LIBRARY_PATH="${DIST}/${OBJDIR}/lib" \ ${BINDIR}/ssl_gtest -d "${SSLGTESTDIR}" \ --gtest_output=xml:"${SSLGTESTREPORT}.{}" \ --gtest_filter="${GTESTFILTER-*}" \ $postfix html_msg $? 0 "ssl_gtests ran successfully" # Parse XML report(s). if type xmllint &>/dev/null; then echo "DEBUG: Using xmllint to parse GTest XML report(s)" parse_report else echo "DEBUG: Falling back to legacy XML report parsing using only sed" parse_report_legacy fi } # Helper function used when 'parallel' isn't available. parallel_fallback() { eval "${@//\{\}/0}" } parse_report() { # Check XML reports for normal test runs and failures. local successes=$(parse_report_xpath "//testcase[@status='run'][count(*)=0]") local failures=$(parse_report_xpath "//failure/..") # Print all tests that succeeded. while read result name; do html_passed_ignore_core "$name" done <<< "$successes" # Print failing tests. if [ -n "$failures" ]; then printf "\nFAILURES:\n=========\n" while read result name; do html_failed_ignore_core "$name" done <<< "$failures" printf "\n" fi } parse_report_xpath() { # Query the XML report with the given XPath pattern. xmllint --xpath "$1" "${SSLGTESTREPORT}".* 2>/dev/null | \ # Insert newlines to help sed. sed $'s/