| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506 | #!/bin/sh# all.sh## This file is part of mbed TLS (https://tls.mbed.org)## Copyright (c) 2014-2016, ARM Limited, All Rights Reserved## Purpose## To run all tests possible or available on the platform.## Warning: the test is destructive. It includes various build modes and# configurations, and can and will arbitrarily change the current CMake# configuration. After this script has been run, the CMake cache will be lost# and CMake will no longer be initialised.## The script assumes the presence of gcc and clang (recent enough for using# ASan with gcc and MemSan with clang, or valgrind) are available, as well as# cmake and a "good" find.# Abort on errors (and uninitialised variables)set -euif [ -d library -a -d include -a -d tests ]; then :; else    err_msg "Must be run from mbed TLS root"    exit 1fiCONFIG_H='include/mbedtls/config.h'CONFIG_BAK="$CONFIG_H.bak"MEMORY=0FORCE=0RELEASE=0# Default commands, can be overriden by the environment: ${OPENSSL:="openssl"}: ${OPENSSL_LEGACY:="$OPENSSL"}: ${GNUTLS_CLI:="gnutls-cli"}: ${GNUTLS_SERV:="gnutls-serv"}: ${GNUTLS_LEGACY_CLI:="$GNUTLS_CLI"}: ${GNUTLS_LEGACY_SERV:="$GNUTLS_SERV"}: ${OUT_OF_SOURCE_DIR:=./mbedtls_out_of_source_build}usage(){    printf "Usage: $0\n"    printf "  -h|--help\t\tPrint this help.\n"    printf "  -m|--memory\t\tAdditional optional memory tests.\n"    printf "  -f|--force\t\tForce the tests to overwrite any modified files.\n"    printf "  -s|--seed\t\tInteger seed value to use for this test run.\n"    printf "  -r|--release-test\t\tRun this script in release mode. This fixes the seed value to 1.\n"    printf "     --out-of-source-dir=<path>\t\tDirectory used for CMake out-of-source build tests."    printf "     --openssl=<OpenSSL_path>\t\tPath to OpenSSL executable to use for most tests.\n"    printf "     --openssl-legacy=<OpenSSL_path>\t\tPath to OpenSSL executable to use for legacy tests e.g. SSLv3.\n"    printf "     --gnutls-cli=<GnuTLS_cli_path>\t\tPath to GnuTLS client executable to use for most tests.\n"    printf "     --gnutls-serv=<GnuTLS_serv_path>\t\tPath to GnuTLS server executable to use for most tests.\n"    printf "     --gnutls-legacy-cli=<GnuTLS_cli_path>\t\tPath to GnuTLS client executable to use for legacy tests.\n"    printf "     --gnutls-legacy-serv=<GnuTLS_serv_path>\t\tPath to GnuTLS server executable to use for legacy tests.\n"}# remove built files as well as the cmake cache/configcleanup(){    make clean    find . -name yotta -prune -o -iname '*cmake*' -not -name CMakeLists.txt -exec rm -rf {} \+    rm -f include/Makefile include/mbedtls/Makefile programs/*/Makefile    git update-index --no-skip-worktree Makefile library/Makefile programs/Makefile tests/Makefile    git checkout -- Makefile library/Makefile programs/Makefile tests/Makefile    if [ -f "$CONFIG_BAK" ]; then        mv "$CONFIG_BAK" "$CONFIG_H"    fi}trap cleanup INT TERM HUPmsg(){    echo ""    echo "******************************************************************"    echo "* $1 "    printf "* "; date    echo "******************************************************************"}err_msg(){    echo "$1" >&2}check_tools(){    for TOOL in "$@"; do        if ! `hash "$TOOL" >/dev/null 2>&1`; then            err_msg "$TOOL not found!"            exit 1        fi    done}while [ $# -gt 0 ]; do    case "$1" in        --memory|-m*)            MEMORY=${1#-m}            ;;        --force|-f)            FORCE=1            ;;        --seed|-s)            shift            SEED="$1"            ;;        --release-test|-r)            RELEASE=1            ;;        --out-of-source-dir)            shift            OUT_OF_SOURCE_DIR="$1"            ;;        --openssl)            shift            OPENSSL="$1"            ;;        --openssl-legacy)            shift            OPENSSL_LEGACY="$1"            ;;        --gnutls-cli)            shift            GNUTLS_CLI="$1"            ;;        --gnutls-serv)            shift            GNUTLS_SERV="$1"            ;;        --gnutls-legacy-cli)            shift            GNUTLS_LEGACY_CLI="$1"            ;;        --gnutls-legacy-serv)            shift            GNUTLS_LEGACY_SERV="$1"            ;;        --help|-h|*)            usage            exit 1            ;;    esac    shiftdoneif [ $FORCE -eq 1 ]; then    rm -rf yotta/module "$OUT_OF_SOURCE_DIR"    git checkout-index -f -q $CONFIG_H    cleanupelse    if [ -d yotta/module ]; then        err_msg "Warning - there is an existing yotta module in the directory 'yotta/module'"        echo "You can either delete your work and retry, or force the test to overwrite the"        echo "test by rerunning the script as: $0 --force"        exit 1    fi    if [ -d "$OUT_OF_SOURCE_DIR" ]; then        echo "Warning - there is an existing directory at '$OUT_OF_SOURCE_DIR'" >&2        echo "You can either delete this directory manually, or force the test by rerunning"        echo "the script as: $0 --force --out-of-source-dir $OUT_OF_SOURCE_DIR"        exit 1    fi    if ! git diff-files --quiet include/mbedtls/config.h; then        echo $?        err_msg "Warning - the configuration file 'include/mbedtls/config.h' has been edited. "        echo "You can either delete or preserve your work, or force the test by rerunning the"        echo "script as: $0 --force"        exit 1    fifiif [ $RELEASE -eq 1 ]; then    # Fix the seed value to 1 to ensure that the tests are deterministic.    SEED=1fimsg "info: $0 configuration"echo "MEMORY: $MEMORY"echo "FORCE: $FORCE"echo "SEED: ${SEED-"UNSET"}"echo "OPENSSL: $OPENSSL"echo "OPENSSL_LEGACY: $OPENSSL_LEGACY"echo "GNUTLS_CLI: $GNUTLS_CLI"echo "GNUTLS_SERV: $GNUTLS_SERV"echo "GNUTLS_LEGACY_CLI: $GNUTLS_LEGACY_CLI"echo "GNUTLS_LEGACY_SERV: $GNUTLS_LEGACY_SERV"# To avoid setting OpenSSL and GnuTLS for each call to compat.sh and ssl-opt.sh# we just export the variables they requireexport OPENSSL_CMD="$OPENSSL"export GNUTLS_CLI="$GNUTLS_CLI"export GNUTLS_SERV="$GNUTLS_SERV"# Avoid passing --seed flag in every call to ssl-opt.sh[ ! -z ${SEED+set} ] && export SEED# Make sure the tools we need are available.check_tools "$OPENSSL" "$OPENSSL_LEGACY" "$GNUTLS_CLI" "$GNUTLS_SERV" \    "$GNUTLS_LEGACY_CLI" "$GNUTLS_LEGACY_SERV" "doxygen" "dot" \    "arm-none-eabi-gcc" "armcc"## Test Suites to be executed## The test ordering tries to optimize for the following criteria:# 1. Catch possible problems early, by running first tests that run quickly#    and/or are more likely to fail than others (eg I use Clang most of the#    time, so start with a GCC build).# 2. Minimize total running time, by avoiding useless rebuilds## Indicative running times are given for reference.msg "info: output_env.sh"OPENSSL="$OPENSSL" OPENSSL_LEGACY="$OPENSSL_LEGACY" GNUTLS_CLI="$GNUTLS_CLI" \    GNUTLS_SERV="$GNUTLS_SERV" GNUTLS_LEGACY_CLI="$GNUTLS_LEGACY_CLI" \    GNUTLS_LEGACY_SERV="$GNUTLS_LEGACY_SERV" scripts/output_env.shmsg "test: recursion.pl" # < 1stests/scripts/recursion.pl library/*.cmsg "test: freshness of generated source files" # < 1stests/scripts/check-generated-files.shmsg "test: doxygen markup outside doxygen blocks" # < 1stests/scripts/check-doxy-blocks.plmsg "test/build: declared and exported names" # < 3scleanuptests/scripts/check-names.shmsg "test: doxygen warnings" # ~ 3scleanuptests/scripts/doxygen.shmsg "build: create and build yotta module" # ~ 30scleanuptests/scripts/yotta-build.shmsg "build: cmake, gcc, ASan" # ~ 1 min 50scleanupCC=gcc cmake -D CMAKE_BUILD_TYPE:String=Asan .makemsg "test: main suites (inc. selftests) (ASan build)" # ~ 50smake testmsg "test: ssl-opt.sh (ASan build)" # ~ 1 mintests/ssl-opt.shmsg "test/build: ref-configs (ASan build)" # ~ 6 min 20stests/scripts/test-ref-configs.plmsg "build: with ASan (rebuild after ref-configs)" # ~ 1 minmakemsg "test: compat.sh (ASan build)" # ~ 6 mintests/compat.shmsg "build: Default + SSLv3 (ASan build)" # ~ 6 mincleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl set MBEDTLS_SSL_PROTO_SSL3CC=gcc cmake -D CMAKE_BUILD_TYPE:String=Asan .makemsg "test: SSLv3 - main suites (inc. selftests) (ASan build)" # ~ 50smake testmsg "build: SSLv3 - compat.sh (ASan build)" # ~ 6 mintests/compat.sh -m 'tls1 tls1_1 tls1_2 dtls1 dtls1_2'OPENSSL_CMD="$OPENSSL_LEGACY" tests/compat.sh -m 'ssl3'msg "build: SSLv3 - ssl-opt.sh (ASan build)" # ~ 6 mintests/ssl-opt.shmsg "build: cmake, full config, clang" # ~ 50scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_MEMORY_BACKTRACE # too slow for testsCC=clang cmake -D CMAKE_BUILD_TYPE:String=Check .makemsg "test: main suites (full config)" # ~ 5smake testmsg "test: ssl-opt.sh default (full config)" # ~ 1stests/ssl-opt.sh -f Defaultmsg "test: compat.sh RC4, DES & NULL (full config)" # ~ 2 minOPENSSL_CMD="$OPENSSL_LEGACY" GNUTLS_CLI="$GNUTLS_LEGACY_CLI" GNUTLS_SERV="$GNUTLS_LEGACY_SERV" tests/compat.sh -e '3DES\|DES-CBC3' -f 'NULL\|DES\|RC4\|ARCFOUR'msg "test/build: curves.pl (gcc)" # ~ 4 mincleanupcmake -D CMAKE_BUILD_TYPE:String=Debug .tests/scripts/curves.plmsg "test/build: key-exchanges (gcc)" # ~ 1 mincleanupcmake -D CMAKE_BUILD_TYPE:String=Check .tests/scripts/key-exchanges.plmsg "build: Unix make, -Os (gcc)" # ~ 30scleanupCC=gcc CFLAGS='-Werror -Os' make# this is meant to cath missing #define mbedtls_printf etc# disable fsio to catch some more missing #include <stdio.h>msg "build: full config except platform/fsio, make, gcc" # ~ 30scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_PLATFORM_Cscripts/config.pl unset MBEDTLS_PLATFORM_MEMORYscripts/config.pl unset MBEDTLS_PLATFORM_PRINTF_ALTscripts/config.pl unset MBEDTLS_PLATFORM_FPRINTF_ALTscripts/config.pl unset MBEDTLS_PLATFORM_SNPRINTF_ALTscripts/config.pl unset MBEDTLS_PLATFORM_TIME_ALTscripts/config.pl unset MBEDTLS_PLATFORM_EXIT_ALTscripts/config.pl unset MBEDTLS_ENTROPY_NV_SEEDscripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_Cscripts/config.pl unset MBEDTLS_FS_IOCC=gcc CFLAGS='-Werror -O0' make# catch compile bugs in _uninit functionsmsg "build: full config with NO_STD_FUNCTION, make, gcc" # ~ 30scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl set MBEDTLS_PLATFORM_NO_STD_FUNCTIONSscripts/config.pl unset MBEDTLS_ENTROPY_NV_SEEDCC=gcc CFLAGS='-Werror -O0' makemsg "build: full config except ssl_srv.c, make, gcc" # ~ 30scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_SSL_SRV_CCC=gcc CFLAGS='-Werror -O0' makemsg "build: full config except ssl_cli.c, make, gcc" # ~ 30scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_SSL_CLI_CCC=gcc CFLAGS='-Werror -O0' makemsg "build: full config except net_sockets.c, make, gcc -std=c99 -pedantic" # ~ 30scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_NET_C # getaddrinfo() undeclared, etc.scripts/config.pl set MBEDTLS_NO_PLATFORM_ENTROPY # uses syscall() on GNU/LinuxCC=gcc CFLAGS='-Werror -O0 -std=c99 -pedantic' make libmsg "build: default config with  MBEDTLS_TEST_NULL_ENTROPY (ASan build)"cleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl set MBEDTLS_TEST_NULL_ENTROPYscripts/config.pl set MBEDTLS_NO_DEFAULT_ENTROPY_SOURCESscripts/config.pl set MBEDTLS_ENTROPY_Cscripts/config.pl unset MBEDTLS_ENTROPY_NV_SEEDscripts/config.pl unset MBEDTLS_ENTROPY_HARDWARE_ALTscripts/config.pl unset MBEDTLS_HAVEGE_CCC=gcc cmake  -D UNSAFE_BUILD=ON -D CMAKE_C_FLAGS:String="-fsanitize=address -fno-common -O3" .makemsg "test: MBEDTLS_TEST_NULL_ENTROPY - main suites (inc. selftests) (ASan build)"make testif uname -a | grep -F Linux >/dev/null; thenmsg "build/test: make shared" # ~ 40scleanupmake SHARED=1 all checkfiif uname -a | grep -F x86_64 >/dev/null; thenmsg "build: i386, make, gcc" # ~ 30scleanupCC=gcc CFLAGS='-Werror -m32' makefi # x86_64msg "build: arm-none-eabi-gcc, make" # ~ 10scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_NET_Cscripts/config.pl unset MBEDTLS_TIMING_Cscripts/config.pl unset MBEDTLS_FS_IOscripts/config.pl unset MBEDTLS_ENTROPY_NV_SEEDscripts/config.pl set MBEDTLS_NO_PLATFORM_ENTROPY# following things are not in the default configscripts/config.pl unset MBEDTLS_HAVEGE_C # depends on timing.cscripts/config.pl unset MBEDTLS_THREADING_PTHREADscripts/config.pl unset MBEDTLS_THREADING_Cscripts/config.pl unset MBEDTLS_MEMORY_BACKTRACE # execinfo.hscripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C # calls exitCC=arm-none-eabi-gcc AR=arm-none-eabi-ar LD=arm-none-eabi-ld CFLAGS=-Werror make libmsg "build: armcc, make"cleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl fullscripts/config.pl unset MBEDTLS_NET_Cscripts/config.pl unset MBEDTLS_TIMING_Cscripts/config.pl unset MBEDTLS_FS_IOscripts/config.pl unset MBEDTLS_ENTROPY_NV_SEEDscripts/config.pl unset MBEDTLS_HAVE_TIMEscripts/config.pl unset MBEDTLS_HAVE_TIME_DATEscripts/config.pl set MBEDTLS_NO_PLATFORM_ENTROPY# following things are not in the default configscripts/config.pl unset MBEDTLS_DEPRECATED_WARNINGscripts/config.pl unset MBEDTLS_HAVEGE_C # depends on timing.cscripts/config.pl unset MBEDTLS_THREADING_PTHREADscripts/config.pl unset MBEDTLS_THREADING_Cscripts/config.pl unset MBEDTLS_MEMORY_BACKTRACE # execinfo.hscripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C # calls exitscripts/config.pl unset MBEDTLS_PLATFORM_TIME_ALT # depends on MBEDTLS_HAVE_TIMECC=armcc AR=armar WARNING_CFLAGS= make libif which i686-w64-mingw32-gcc >/dev/null; thenmsg "build: cross-mingw64, make" # ~ 30scleanupCC=i686-w64-mingw32-gcc AR=i686-w64-mingw32-ar LD=i686-w64-minggw32-ld CFLAGS=-Werror WINDOWS_BUILD=1 makeWINDOWS_BUILD=1 make cleanCC=i686-w64-mingw32-gcc AR=i686-w64-mingw32-ar LD=i686-w64-minggw32-ld CFLAGS=-Werror WINDOWS_BUILD=1 SHARED=1 makeWINDOWS_BUILD=1 make cleanfi# MemSan currently only available on Linux 64 bitsif uname -a | grep 'Linux.*x86_64' >/dev/null; thenmsg "build: MSan (clang)" # ~ 1 min 20scleanupcp "$CONFIG_H" "$CONFIG_BAK"scripts/config.pl unset MBEDTLS_AESNI_C # memsan doesn't grok asmCC=clang cmake -D CMAKE_BUILD_TYPE:String=MemSan .makemsg "test: main suites (MSan)" # ~ 10smake testmsg "test: ssl-opt.sh (MSan)" # ~ 1 mintests/ssl-opt.sh# Optional part(s)if [ "$MEMORY" -gt 0 ]; then    msg "test: compat.sh (MSan)" # ~ 6 min 20s    tests/compat.shfielse # no MemSanmsg "build: Release (clang)"cleanupCC=clang cmake -D CMAKE_BUILD_TYPE:String=Release .makemsg "test: main suites valgrind (Release)"make memcheck# Optional part(s)# Currently broken, programs don't seem to receive signals# under valgrind on OS Xif [ "$MEMORY" -gt 0 ]; then    msg "test: ssl-opt.sh --memcheck (Release)"    tests/ssl-opt.sh --memcheckfiif [ "$MEMORY" -gt 1 ]; then    msg "test: compat.sh --memcheck (Release)"    tests/compat.sh --memcheckfifi # MemSanmsg "build: cmake 'out-of-source' build"cleanupMBEDTLS_ROOT_DIR="$PWD"mkdir "$OUT_OF_SOURCE_DIR"cd "$OUT_OF_SOURCE_DIR"cmake "$MBEDTLS_ROOT_DIR"makemsg "test: cmake 'out-of-source' build"make testcd "$MBEDTLS_ROOT_DIR"rm -rf "$OUT_OF_SOURCE_DIR"msg "Done, cleaning up"cleanup
 |