зеркало из https://github.com/mozilla/pjs.git
209 строки
6.3 KiB
Bash
Executable File
209 строки
6.3 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# ***** BEGIN LICENSE BLOCK *****
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
#
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
|
# the License. You may obtain a copy of the License at
|
|
# http://www.mozilla.org/MPL/
|
|
#
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
# for the specific language governing rights and limitations under the
|
|
# License.
|
|
#
|
|
# The Original Code is the Netscape security libraries.
|
|
#
|
|
# The Initial Developer of the Original Code is
|
|
# Netscape Communications Corporation.
|
|
# Portions created by the Initial Developer are Copyright (C) 1994-2000
|
|
# the Initial Developer. All Rights Reserved.
|
|
#
|
|
# Contributor(s):
|
|
#
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
# either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
# the provisions above, a recipient may use your version of this file under
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
#
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
########################################################################
|
|
#
|
|
# mozilla/security/nss/tests/all.sh
|
|
#
|
|
# Script to start all available NSS QA suites on one machine
|
|
# this script is called or sourced by nssqa which runs on all required
|
|
# platforms
|
|
#
|
|
# needs to work on all Unix and Windows platforms
|
|
#
|
|
# currently available NSS QA suites:
|
|
# --------------------------------------------------
|
|
# cert.sh - exercises certutil and creates certs necessary for all
|
|
# other tests
|
|
# ssl.sh - tests SSL V2 SSL V3 and TLS
|
|
# smime.sh - S/MIME testing
|
|
# crmf.sh - CRMF/CMMF testing
|
|
# sdr.sh - test NSS SDR
|
|
# cipher.sh - test NSS ciphers
|
|
# perf.sh - Nightly performance measurments
|
|
# tools.sh - Tests the majority of the NSS tools
|
|
# fips.sh - Tests basic functionallity of NSS in FIPS-compliant mode
|
|
#
|
|
# special strings
|
|
# ---------------
|
|
# FIXME ... known problems, search for this string
|
|
# NOTE .... unexpected behavior
|
|
#
|
|
# NOTE:
|
|
# -----
|
|
# Unlike the old QA this is based on files sourcing each other
|
|
# This is done to save time, since a great portion of time is lost
|
|
# in calling and sourcing the same things multiple times over the
|
|
# network. Also, this way all scripts have all shell function available
|
|
# and a completely common environment
|
|
#
|
|
# file tells the test suite that the output is going to a log, so any
|
|
# forked() children need to redirect their output to prevent them from
|
|
# being over written.
|
|
#
|
|
########################################################################
|
|
|
|
run_tests()
|
|
{
|
|
for i in ${TESTS}
|
|
do
|
|
SCRIPTNAME=${i}.sh
|
|
if [ "$O_CRON" = "ON" ]; then
|
|
echo "Running tests for $i" >> ${LOGFILE}
|
|
echo "TIMESTAMP $i BEGIN: `date`" >> ${LOGFILE}
|
|
(cd ${QADIR}/$i ; . ./$SCRIPTNAME all file >> ${LOGFILE} 2>&1)
|
|
echo "TIMESTAMP $i END: `date`" >> ${LOGFILE}
|
|
else
|
|
echo "Running tests for $i" | tee -a ${LOGFILE}
|
|
echo "TIMESTAMP $i BEGIN: `date`" | tee -a ${LOGFILE}
|
|
(cd ${QADIR}/$i ; . ./$SCRIPTNAME all file 2>&1 | tee -a ${LOGFILE})
|
|
echo "TIMESTAMP $i END: `date`" | tee -a ${LOGFILE}
|
|
fi
|
|
done
|
|
}
|
|
|
|
tests="cipher perf libpkix cert dbtests tools fips sdr crmf smime ssl ocsp merge pkits"
|
|
if [ -z "$BUILD_LIBPKIX_TESTS" ] ; then
|
|
tests=`echo "${tests}" | sed -e "s/libpkix//"`
|
|
fi
|
|
TESTS=${TESTS:-$tests}
|
|
ALL_TESTS=${TESTS}
|
|
|
|
SCRIPTNAME=all.sh
|
|
CLEANUP="${SCRIPTNAME}"
|
|
cd `dirname $0` # will cause problems if sourced
|
|
|
|
# all.sh should be the first one to try to source the init
|
|
if [ -z "${INIT_SOURCED}" -o "${INIT_SOURCED}" != "TRUE" ]; then
|
|
cd common
|
|
. ./init.sh
|
|
fi
|
|
|
|
# Since in make at the top level, modutil is the last file
|
|
# created, we check for modutil to know whether the build
|
|
# is complete. If a new file is created after that, the
|
|
# following test for modutil should check for that instead.
|
|
|
|
if [ ! -f ${DIST}/${OBJDIR}/bin/modutil -a \
|
|
! -f ${DIST}/${OBJDIR}/bin/modutil.exe ]; then
|
|
echo "Build Incomplete. Aborting test." >> ${LOGFILE}
|
|
html_head "Testing Initialization"
|
|
Exit "Checking for build"
|
|
fi
|
|
|
|
# backup selected environment variables
|
|
ENV_BACKUP=${HOSTDIR}/env.sh
|
|
env_backup > ${ENV_BACKUP}
|
|
|
|
# standard tests, no pkix, no sharedb
|
|
if [ -z "$NSS_TEST_DISABLE_STANDARD" ] ; then
|
|
TEST_MODE=STANDARD
|
|
run_tests
|
|
fi
|
|
|
|
# PKIX tests
|
|
if [ -z "$NSS_TEST_DISABLE_PKIX" ] ; then
|
|
TABLE_ARGS="bgcolor=cyan"
|
|
html_head "Testing with PKIX"
|
|
html "</TABLE><BR>"
|
|
|
|
HOSTDIR="${HOSTDIR}/pkix"
|
|
mkdir -p "${HOSTDIR}"
|
|
init_directories
|
|
|
|
NSS_TEST_SERVER_CLIENT_BYPASS="1"
|
|
NSS_TEST_DISABLE_FIPS="1"
|
|
NSS_ENABLE_PKIX_VERIFY="1"
|
|
export NSS_ENABLE_PKIX_VERIFY
|
|
|
|
TESTS=`echo "${ALL_TESTS}" | sed -e "s/cipher//" -e "s/libpkix//" \
|
|
-e "s/dbupgrade//"`
|
|
TEST_MODE=PKIX
|
|
run_tests
|
|
|
|
. ${ENV_BACKUP}
|
|
fi
|
|
|
|
# upgrade cert dbs to shared db + run tests there
|
|
if [ -z "$NSS_TEST_DISABLE_UPGRADE_DB" ] ; then
|
|
# upgrade certs dbs to shared db
|
|
TESTS="dbupgrade"
|
|
TEST_MODE=UPGRADE_DB
|
|
run_tests
|
|
|
|
TABLE_ARGS="bgcolor=pink"
|
|
html_head "Testing with upgraded library"
|
|
html "</TABLE><BR>"
|
|
|
|
NSS_DEFAULT_DB_TYPE="sql"
|
|
export NSS_DEFAULT_DB_TYPE
|
|
|
|
# run the subset of tests with the upgraded database
|
|
TESTS=`echo "${ALL_TESTS}" | sed -e "s/cipher//" -e "s/perf//" \
|
|
-e "s/libpkix//" -e "s/cert//" -e "s/dbtests//" -e "s/dbupgrade//"`
|
|
run_tests
|
|
|
|
. ${ENV_BACKUP}
|
|
fi
|
|
|
|
# tests for native sharedb support
|
|
if [ -z "$NSS_TEST_DISABLE_SHARED_DB" ] ; then
|
|
TABLE_ARGS="bgcolor=yellow"
|
|
html_head "Testing with shared library"
|
|
html "</TABLE><BR>"
|
|
|
|
HOSTDIR="${HOSTDIR}/sharedb"
|
|
mkdir -p "${HOSTDIR}"
|
|
init_directories
|
|
|
|
NSS_DEFAULT_DB_TYPE="sql"
|
|
export NSS_DEFAULT_DB_TYPE
|
|
|
|
# run the tests for native sharedb support
|
|
TESTS=`echo "${ALL_TESTS}" | sed -e "s/libpkix//" -e "s/dbupgrade//"`
|
|
TEST_MODE=SHARED_DB
|
|
run_tests
|
|
|
|
. ${ENV_BACKUP}
|
|
fi
|
|
|
|
SCRIPTNAME=all.sh
|
|
|
|
. ${QADIR}/common/cleanup.sh
|
|
|