You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

124 lines
2.9 KiB

#!/bin/bash
# Usage:
# ./run_test.sh <TEST_BINARY>
14 years ago
function yesno()
{
while true; do
read -p "$* (y/n)[y]" yn
if [ "$yn" = '' ]; then yn="y"; fi
case "$yn" in
[Yy]* ) return 0;;
[Nn]* ) return 1;;
* ) echo "Please answer y/n.";;
esac
done
}
pre="\E[00;33m"
fail="\E[00;31m"
post="\E[00;00m"
ulimit -c unlimited
# test=$1
test=./test
# if [ $# -ne 1 ]
# then
# echo "Usage: `basename $0` <TEST_BINARY>"
# exit 1
# fi
if [ ! -e $test ]; then
echo -e "The parameter binary: $test does not exists"
exit 1
fi
echo -e "${pre}Reset & remove lcov, $test.out and core files${post}"
# coverage
lcov --directory . -z
rm -f ./lcov.info
# cores
rm -f ./leak.log.core.*
# cxxtest output
rm -f $test.out
echo -e "${pre}Run tests${post}"
valgrind \
--log-file=leak.log \
--leak-check=full \
--show-reachable=yes \
--show-below-main=no \
--track-origins=yes \
--num-callers=30 \
--malloc-fill=0xaa \
--free-fill=0xdd \
--suppressions=valgrind.supp \
$test | tee $test.out; retval=$PIPESTATUS
# NOTE to gen suppressions run:
# valgrind --leak-check=full --show-reachable=yes --show-below-main=no --track-origins=yes --num-callers=30 --malloc-fill=0xaa --free-fill=0xdd --gen-suppressions=yes ./test
# retval is 0 on success
# or the number of failed cases
# or 137 if segfault happens
if [ $retval -ne 0 ]; then
echo -e "${fail}The executed binary: $test failed.${post}"
if [ $retval -ne 137 ]; then
echo -e "${pre}Failed checks:${post}"
# TODO print the previous line too
cat $test.out | grep "Error:" | awk -F"/test/" '{ print $2 }'
fi
cores=$(ls leak.log.core.* 2>/dev/null)
if [ "$cores" != "" ]; then
echo -e "${pre}Core file generated: ${post}"
echo $cores
14 years ago
# NOTE no need to bt full
gdb $test $cores -ex "set width 1000" -ex "thread apply all bt" -ex q > gdb.out
./gdb_out_parser.pl gdb.out
14 years ago
echo ""
14 years ago
if yesno "run 'gdb $test $cores' ?"; then
gdb $test $cores
fi
fi
exit -1
fi
echo -e "${pre}Capture coverage info${post}"
lcov --directory ../build --capture -o lcov.info
# some classes are not used in the lib yet
lcov --directory ../test --capture -o lcov2.info
cat lcov2.info >> lcov.info
echo -e "${pre}Filtering coverage tracefile${post}"
lcov -r lcov.info "g++-v*" -o lcov.info
lcov -r lcov.info "/usr/include/cxxtest*" -o lcov.info
lcov -r lcov.info "*cpp_utils/test*" -o lcov.info
echo -e "${pre}Generating coverage HTML${post}"
rm -rf ./cov
mkdir cov
genhtml --frames --legend -o ./cov lcov.info
echo -e "${pre}Checking the coverage results${post}"
./cov_check.pl 90 cov/index.html
echo -e "${pre}Checking leak results${post}"
./leak_check.pl leak.log
if [ $? == 1 ]; then
if yesno "run 'vim leak.log' ?"; then
vim leak.log
fi
fi