blob: f3b9292da80f46d9a3dfc2cff56dd777a550acc1 (
plain) (
tree)
|
|
# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.
#/bin/bash
# A quick port of the travis tests to bash, requires root
# TODO
# * look into using a framework..
# * why --dry-run fails?
# * why --experimental fails?
# * make it better validate archives and contents
PYTHON=${1:-/usr/bin/python3}
SOSPATH=${2:-./bin/sos report}
NUMOFFAILURES=0
summary="Summary\n"
run_expecting_sucess () {
#$1 - is command options
#$2 - kind of check to do, so far only extract
FAIL=false
# Make sure clean
rm -f /dev/shm/stderr /dev/shm/stdout /var/tmp/sosreport*.tar.*
rm -rf /var/tmp/sosreport_test/
start=`date +%s`
echo "######### RUNNING $1 #########"
$PYTHON $SOSPATH $1 2> /dev/shm/stderr 1> /dev/shm/stdout
if [ $? -eq 0 ]; then
echo "### Success"
else
echo "!!! FAILED !!!"
FAIL=true
fi
end=`date +%s`
runtime=$((end-start))
echo "#### Sos Total time (seconds):" $runtime
if [ -s /dev/shm/stderr ]; then
FAIL=true
echo "!!! FAILED !!!"
echo "### start stderr"
cat /dev/shm/stderr
echo "### end stderr"
fi
echo "### start stdout"
cat /dev/shm/stdout
echo "### end stdout"
if [ "extract" = "$2" ]; then
echo "### start extraction"
rm -f /var/tmp/sosreport*md5
mkdir /var/tmp/sosreport_test/
tar xfa /var/tmp/sosreport*.tar* -C /var/tmp/sosreport_test --strip-components=1
if [ -s /var/tmp/sosreport_test/sos_logs/*errors.txt ]; then
FAIL=true
echo "!!! FAILED !!!"
echo "#### *errors.txt output"
ls -alh /var/tmp/sosreport_test/sos_logs/
cat /var/tmp/sosreport_test/sos_logs/*errors.txt
fi
echo "### stop extraction"
fi
size="$(grep Size /dev/shm/stdout)"
summary="${summary} \n failures ${FAIL} \t time ${runtime} \t ${size} \t ${1} "
echo "######### DONE WITH $1 #########"
if $FAIL; then
NUMOFFAILURES=$(($NUMOFFAILURES + 1))
return 1
else
return 0
fi
}
# If /etc/sos/sos.conf doesn't exist let's just make it..
if [ -f /etc/sos/sos.conf ]; then
echo "/etc/sos/sos.conf already exists"
else
echo "Creating /etc/sos.conf"
mkdir /etc/sos
touch /etc/sos/sos.conf
fi
# Runs not generating sosreports
run_expecting_sucess " -l"
run_expecting_sucess " --list-presets"
run_expecting_sucess " --list-profiles"
# Test generating sosreports, 3 (new) options at a time
# Trying to do --batch (1 label/archive/report/verbosity change) (other changes)
run_expecting_sucess " --batch --build --no-env-vars " # Only --build test
run_expecting_sucess " --batch --no-report -o hardware " extract
run_expecting_sucess " --batch --label TEST -a -c never" extract
run_expecting_sucess " --batch --debug --log-size 0 -c always" extract
run_expecting_sucess " --batch -z xz --log-size 1" extract
run_expecting_sucess " --batch -z gzip" extract
run_expecting_sucess " --batch -t 1 -n hardware" extract
run_expecting_sucess " --batch --quiet -e opencl -k kernel.with-timer" extract
run_expecting_sucess " --batch --case-id 10101 --all-logs --since=$(date -d "yesterday 13:00" '+%Y%m%d') " extract
run_expecting_sucess " --batch --verbose --no-postproc" extract
run_expecting_sucess " --batch --mask" extract
echo $summary
if [ $NUMOFFAILURES -gt 0 ]; then
echo "FAILED $NUMOFFAILURES"
exit 1
else
echo "Everything worked!"
exit 0
fi
# vim: set et ts=4 sw=4 :
|