2017-02-18 23:32:22 +00:00
|
|
|
#!/bin/bash -e
|
|
|
|
|
|
|
|
export EXPECTFAIL=${EXPECTFAIL:-0}
|
|
|
|
|
2017-02-19 11:13:49 +00:00
|
|
|
starttime=$SECONDS
|
2017-02-18 23:32:22 +00:00
|
|
|
failed=""
|
|
|
|
for t in $TOOL;
|
|
|
|
do
|
|
|
|
set +e
|
2017-02-19 11:13:49 +00:00
|
|
|
toolstarttime=$SECONDS
|
|
|
|
echo "[-] TOOL $t TEST STARTED: $((SECONDS - starttime)) seconds since start of script"
|
2017-02-18 23:32:22 +00:00
|
|
|
if ! docker run -e EXPECTFAIL="$EXPECTFAIL" -e TOOL="$t" --rm ctftools bash -ic 'manage-tools -s -f -v test $TOOL';
|
|
|
|
then
|
|
|
|
failed="$failed$t "
|
|
|
|
fi
|
2017-02-19 11:13:49 +00:00
|
|
|
echo "[-] TOOL $t TEST ENDED: $((SECONDS - toolstarttime)) seconds, $((SECONDS - starttime)) seconds since start of script"
|
2017-02-18 23:32:22 +00:00
|
|
|
set -e
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "$failed" != "" ];
|
|
|
|
then
|
|
|
|
echo "==================================================="
|
|
|
|
failcount=$(echo "$failed" | wc -w)
|
|
|
|
totalcount=$(echo "$TOOL" | wc -w)
|
|
|
|
if [ "$EXPECTFAIL" -eq "1" ];
|
|
|
|
then
|
|
|
|
echo "ERROR: $failcount/$totalcount tools succeeded while they were expected to fail: $failed"
|
|
|
|
else
|
|
|
|
echo "ERROR: $failcount/$totalcount tools failed while they should have succeeded: $failed"
|
|
|
|
fi
|
|
|
|
echo "==================================================="
|
|
|
|
exit 1
|
|
|
|
fi
|
2017-02-19 13:46:22 +00:00
|
|
|
|
|
|
|
if [ "$EXPECTFAIL" -eq "1" ];
|
|
|
|
then
|
|
|
|
echo "DONE: $totalcount tools failed as expected."
|
|
|
|
else
|
|
|
|
echo "DONE: $totalcount tools succeeded as expected."
|
|
|
|
fi
|
|
|
|
|
2017-02-18 23:32:22 +00:00
|
|
|
exit 0
|