|
|
8da017 |
#!/bin/bash
|
|
|
8da017 |
# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
|
|
|
8da017 |
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
8da017 |
#
|
|
|
8da017 |
# runtest.sh of tests/Run-internal-BIND-test-suite
|
|
|
8da017 |
# Description: Run internal BIND test suite
|
|
|
8da017 |
# Author: Martin Cermak <mcermak@redhat.com>
|
|
|
8da017 |
#
|
|
|
8da017 |
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
8da017 |
#
|
|
|
8da017 |
# Copyright (c) 2010 Red Hat, Inc. All rights reserved.
|
|
|
8da017 |
#
|
|
|
8da017 |
# This copyrighted material is made available to anyone wishing
|
|
|
8da017 |
# to use, modify, copy, or redistribute it subject to the terms
|
|
|
8da017 |
# and conditions of the GNU General Public License version 2.
|
|
|
8da017 |
#
|
|
|
8da017 |
# This program is distributed in the hope that it will be
|
|
|
8da017 |
# useful, but WITHOUT ANY WARRANTY; without even the implied
|
|
|
8da017 |
# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
8da017 |
# PURPOSE. See the GNU General Public License for more details.
|
|
|
8da017 |
#
|
|
|
8da017 |
# You should have received a copy of the GNU General Public
|
|
|
8da017 |
# License along with this program; if not, write to the Free
|
|
|
8da017 |
# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
8da017 |
# Boston, MA 02110-1301, USA.
|
|
|
8da017 |
#
|
|
|
8da017 |
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
8da017 |
|
|
|
8da017 |
# Include rhts environment
|
|
|
8da017 |
. /usr/bin/rhts-environment.sh
|
|
|
8da017 |
. /usr/lib/beakerlib/beakerlib.sh
|
|
|
8da017 |
|
|
|
8da017 |
PACKAGE="bind"
|
|
|
8da017 |
|
|
|
545e2c |
# Set those variables to n to skip tests on variants
|
|
|
545e2c |
DEFAULT_VARIANTS="normal pkcs11 sdb"
|
|
|
545e2c |
#TEST_VARIANTS="normal"
|
|
|
545e2c |
|
|
|
0983c9 |
#
|
|
|
0983c9 |
# Runs test suite and checks known errors
|
|
|
0983c9 |
# Prepared to be repeated with another variants
|
|
|
0983c9 |
run_testsuite()
|
|
|
0983c9 |
{
|
|
|
0983c9 |
local RESULT_TEXT="$TMPDIR/test${NAMED_VARIANT}.txt"
|
|
|
0983c9 |
local FOUNDERROR=`mktemp found-XXXXXXXX.err`
|
|
|
545e2c |
local KNOWNERROR=/dev/null
|
|
|
0983c9 |
|
|
|
0983c9 |
if [ -f "$ORIG/knownerror${NAMED_VARIANT}.$TAG" ]; then
|
|
|
0983c9 |
KNOWNERROR=`readlink -f $ORIG/knownerror.$TAG`
|
|
|
0983c9 |
elif [ -f "$ORIG/knownerror${NAMED_VARIANT}" ]; then
|
|
|
0983c9 |
KNOWNERROR=`readlink -f $ORIG/knownerror`
|
|
|
0983c9 |
fi
|
|
|
0983c9 |
|
|
|
0983c9 |
# Sometime it can fail. Report just failures that are not known
|
|
|
0983c9 |
rlRun "make test -j${CORES:-1} &> $RESULT_TEXT" 0-255 "Perform the test."
|
|
|
0983c9 |
rlRun "grep -C 10 FAIL $RESULT_TEXT" 0-255 "Quickly show the test error (if any)."
|
|
|
0983c9 |
|
|
|
0983c9 |
rlRun "$FILTER $RESULT_TEXT" 0 "Showing unsuccessful tests"
|
|
|
0983c9 |
rlRun "$FILTER -s $RESULT_TEXT > $FOUNDERROR" 0
|
|
|
0983c9 |
rlRun "ls $KNOWNERROR $FOUNDERROR $RESULT_TEXT" 0 'check if there is needed files'
|
|
|
0983c9 |
rlLog "`cat $FOUNDERROR`"
|
|
|
0983c9 |
|
|
|
0983c9 |
rlAssertLesserOrEqual "Checking number of found errors is in limits" "$(grep '^FAIL' $FOUNDERROR | wc -l)" "$(wc -l <$KNOWNERROR)"
|
|
|
0983c9 |
cat $FOUNDERROR | while read STATUS TEST ; do
|
|
|
0983c9 |
if [ "$STATUS" = FAIL ]; then
|
|
|
0983c9 |
rlRun "grep '$TEST' $KNOWNERROR" 0 "Check $TEST failure is expected"
|
|
|
0983c9 |
else
|
|
|
0983c9 |
rlLog "$STATUS $TEST"
|
|
|
0983c9 |
fi
|
|
|
0983c9 |
done
|
|
|
0983c9 |
}
|
|
|
0983c9 |
|
|
|
8da017 |
rlJournalStart
|
|
|
8da017 |
rlPhaseStartSetup
|
|
|
8da017 |
# package assertions
|
|
|
8da017 |
rlAssertRpm $PACKAGE
|
|
|
8da017 |
rlAssertRpm rpm-build
|
|
|
8da017 |
rlAssertRpm perl-Net-DNS-Nameserver
|
|
|
8da017 |
|
|
|
8da017 |
#pwd
|
|
|
8da017 |
ORIG=`pwd`
|
|
|
8da017 |
SETUP_SOFTHSM=`readlink -f setup-named-softhsm.sh`
|
|
|
8da017 |
FILTER=`readlink -f bind-systest-filter.sh`
|
|
|
0983c9 |
CORES=`grep 'processor\s*:' /proc/cpuinfo | wc -l`
|
|
|
8da017 |
|
|
|
8da017 |
TAG=generic
|
|
|
8da017 |
if [ -f /etc/os-release ]; then
|
|
|
8da017 |
# extract platform tag
|
|
|
8da017 |
TAG=`(source /etc/os-release && echo ${PLATFORM_ID#platform:})`
|
|
|
8da017 |
fi
|
|
|
8da017 |
|
|
|
8da017 |
#tempdir
|
|
|
8da017 |
rlRun "TMPDIR=\`mktemp -d\`" 0 "Creating tmp directory"
|
|
|
8da017 |
rlRun "pushd $TMPDIR"
|
|
|
8da017 |
|
|
|
8da017 |
# topdir
|
|
|
8da017 |
TOPDIR=`rpm -E '%{_topdir}'`
|
|
|
8da017 |
|
|
|
8da017 |
# cleanup in topdir
|
|
|
8da017 |
mkdir -p $TOPDIR/{BUILD,SOURCES,SPECS}
|
|
|
8da017 |
rm -rf $TOPDIR/{BUILD,SOURCES,SPECS}/*
|
|
|
8da017 |
|
|
|
8da017 |
# download src rpm
|
|
|
8da017 |
if ! ls bind*.src.rpm; then
|
|
|
5691e0 |
rlRun "dnf --enablerepo='*-source' download --source bind" 0 "Fetch source from repository"
|
|
|
8da017 |
rlRun "rpm -i bind*.src.rpm"
|
|
|
8da017 |
fi
|
|
|
8da017 |
|
|
|
8da017 |
rlRun "rpm --define '_topdir $TOPDIR' -Uvh *rpm &> $TMPDIR/install.txt"
|
|
|
8da017 |
rlRun "cd $TOPDIR/SPECS"
|
|
|
8da017 |
|
|
|
8da017 |
rlRun "dnf -y builddep *.spec"
|
|
|
8da017 |
|
|
|
8da017 |
# stop bind if it is running
|
|
|
8da017 |
rlServiceStop named
|
|
|
8da017 |
rlPhaseEnd
|
|
|
8da017 |
|
|
|
8da017 |
rlPhaseStartTest
|
|
|
8da017 |
# rebuild from source
|
|
|
8da017 |
rlRun "rpmbuild -ba *.spec &> $TMPDIR/build.txt"
|
|
|
8da017 |
|
|
|
8da017 |
# the test
|
|
|
8da017 |
rlRun "cd $TOPDIR/BUILD/bind*"
|
|
|
8da017 |
|
|
|
8da017 |
rlLogInfo "Test takes place in `pwd`"
|
|
|
8da017 |
|
|
|
8da017 |
rlRun "chown -R root ."
|
|
|
8da017 |
|
|
|
8da017 |
if [ -x "$SETUP_SOFTHSM" ]; then
|
|
|
8da017 |
rlRun "eval \"$(bash $SETUP_SOFTHSM -A)\"" 0 "Preparing PKCS#11 token slot"
|
|
|
8da017 |
rlRun "pkcs11-tokens" 0 "Testing token slot availability"
|
|
|
8da017 |
else
|
|
|
8da017 |
rlLog "PKCS#11 not initialized"
|
|
|
8da017 |
fi
|
|
|
8da017 |
|
|
|
8da017 |
if [ -d build ]; then
|
|
|
8da017 |
BUILD=build
|
|
|
8da017 |
else
|
|
|
8da017 |
BUILD=.
|
|
|
8da017 |
fi
|
|
|
8da017 |
|
|
|
8da017 |
rlRun "./bin/tests/system/ifconfig.sh up" 0 "Setup fake network interfaces."
|
|
|
8da017 |
|
|
|
8da017 |
# required by idna test
|
|
|
8da017 |
export LC_ALL=en_US.UTF-8
|
|
|
8da017 |
|
|
|
8da017 |
rlRun "pushd $BUILD"
|
|
|
8da017 |
|
|
|
545e2c |
if echo "${TEST_VARIANTS:-$DEFAULT_VARIANTS}" | grep -q normal; then
|
|
|
545e2c |
rlLog "Running normal variant"
|
|
|
545e2c |
export NAMED_VARIANT= DNSSEC_VARIANT=
|
|
|
545e2c |
run_testsuite
|
|
|
54fa84 |
rlLog "Finished normal variant"
|
|
|
545e2c |
fi
|
|
|
8da017 |
|
|
|
545e2c |
if echo "${TEST_VARIANTS:-$DEFAULT_VARIANTS}" | grep -q sdb; then
|
|
|
545e2c |
rlLog "Running sdb variant"
|
|
|
545e2c |
export NAMED_VARIANT=-sdb DNSSEC_VARIANT=
|
|
|
545e2c |
run_testsuite
|
|
|
54fa84 |
rlLog "Finished sdb variant"
|
|
|
545e2c |
fi
|
|
|
8da017 |
|
|
|
545e2c |
if echo "${TEST_VARIANTS:-$DEFAULT_VARIANTS}" | grep -q pkcs11; then
|
|
|
545e2c |
rlLog "Running pkcs11 variant"
|
|
|
545e2c |
# Unfortunately, PKCS11 variant uses shared key storage
|
|
|
545e2c |
# It cannot use more threads for that reason
|
|
|
545e2c |
export NAMED_VARIANT=-pkcs11 DNSSEC_VARIANT=-pkcs11
|
|
|
545e2c |
CORES=1 run_testsuite
|
|
|
54fa84 |
rlLog "Finished pkcs11 variant"
|
|
|
545e2c |
fi
|
|
|
8da017 |
|
|
|
0983c9 |
rlRun "popd"
|
|
|
0983c9 |
|
|
|
0983c9 |
rlRun "./bin/tests/system/ifconfig.sh down" 0 "Remove fake network interfaces."
|
|
|
8da017 |
|
|
|
8da017 |
rlPhaseEnd
|
|
|
8da017 |
|
|
|
8da017 |
rlPhaseStartCleanup
|
|
|
0983c9 |
rlBundleLogs "BUILD_LOGS" "$TMPDIR/install.txt" "$TMPDIR/builddeps.txt" "$TMPDIR/build.txt"
|
|
|
0983c9 |
rlBundleLogs "TEST_LOGS" "$TMPDIR"/test*.txt
|
|
|
8da017 |
rlRun "popd"
|
|
|
8da017 |
rlRun "rm -r $TMPDIR" 0 "Removing tmp directory"
|
|
|
8da017 |
rlPhaseEnd
|
|
|
8da017 |
rlJournalEnd
|