blob: eed956e9920ee7fd0aa65210f2f82d2007a90088 [file] [log] [blame]
Reid Spencer5f016e22007-07-11 17:01:13 +00001#!/bin/sh
2#
3# TestRunner.sh - This script is used to run arbitrary unit tests. Unit
4# tests must contain the command used to run them in the input file, starting
5# immediately after a "RUN:" string.
6#
7# This runner recognizes and replaces the following strings in the command:
8#
9# %s - Replaced with the input name of the program, or the program to
10# execute, as appropriate.
11# %llvmgcc - llvm-gcc command
12# %llvmgxx - llvm-g++ command
13# %prcontext - prcontext.tcl script
Gabor Greif1e2db032008-03-20 22:50:54 +000014# %t - temporary file name (derived from testcase name)
Reid Spencer5f016e22007-07-11 17:01:13 +000015#
16
17FILENAME=$1
18TESTNAME=$1
19SUBST=$1
Ted Kremenek6a18c762007-11-28 19:16:54 +000020
21OUTPUT=Output/$1.out
Reid Spencer5f016e22007-07-11 17:01:13 +000022
23# create the output directory if it does not already exist
Ted Kremenek6a18c762007-11-28 19:16:54 +000024mkdir -p `dirname $OUTPUT` > /dev/null 2>&1
Reid Spencer5f016e22007-07-11 17:01:13 +000025
26if test $# != 1; then
27 # If more than one parameter is passed in, there must be three parameters:
28 # The filename to read from (already processed), the command used to execute,
29 # and the file to output to.
30 SUBST=$2
31 OUTPUT=$3
32 TESTNAME=$3
33fi
34
35ulimit -t 40
36
Chris Lattner32a39992007-12-12 06:19:22 +000037# Verify the script contains a run line.
38grep -q 'RUN:' $FILENAME || (
39 echo "******************** TEST '$TESTNAME' HAS NO RUN LINE! ********************"
40 exit 1
41)
42
Gabor Greif1e2db032008-03-20 22:50:54 +000043# Run under valgrind if the VG environment variable has been set.
Daniel Dunbar5e380732008-07-25 01:05:44 +000044CLANG=$CLANG
Eli Friedmanfde9fe72008-07-27 05:05:07 +000045if [ ! -n "$CLANG" ]; then
Daniel Dunbar5e380732008-07-25 01:05:44 +000046 CLANG="clang"
47fi
Gabor Greif1e2db032008-03-20 22:50:54 +000048if [ -n "$VG" ]; then
Nuno Lopesf557fb72008-09-04 18:33:57 +000049 rm -f $OUTPUT.vg
50 CLANG="valgrind --leak-check=full --quiet --log-file=$OUTPUT.vg $CLANG"
Gabor Greif1e2db032008-03-20 22:50:54 +000051fi
52
Reid Spencer5f016e22007-07-11 17:01:13 +000053SCRIPT=$OUTPUT.script
Gabor Greif0f233032008-03-17 13:45:47 +000054TEMPOUTPUT=$OUTPUT.tmp
Gabor Greif1e2db032008-03-20 22:50:54 +000055grep 'RUN:' $FILENAME | \
56 sed -e "s|^.*RUN:\(.*\)$|\1|g" \
Nuno Lopesf557fb72008-09-04 18:33:57 +000057 -e "s|clang|$CLANG|g" \
Gabor Greif1e2db032008-03-20 22:50:54 +000058 -e "s|%s|$SUBST|g" \
59 -e "s|%llvmgcc|llvm-gcc -emit-llvm|g" \
60 -e "s|%llvmgxx|llvm-g++ -emit-llvm|g" \
61 -e "s|%prcontext|prcontext.tcl|g" \
Nuno Lopesf557fb72008-09-04 18:33:57 +000062 -e "s|%t|$TEMPOUTPUT|g" > $SCRIPT
Reid Spencer5f016e22007-07-11 17:01:13 +000063
Daniel Dunbar607b17b2008-09-04 00:30:11 +000064IS_XFAIL=0
65if (grep -q XFAIL $FILENAME); then
66 IS_XFAIL=1
67 printf "XFAILED '$TESTNAME': "
68 grep XFAIL $FILENAME
69fi
Reid Spencer5f016e22007-07-11 17:01:13 +000070
Nuno Lopes8bdd8802008-09-06 16:42:14 +000071if (grep -q "%llvmgcc" $FILENAME); then
72 if [ -z "$(llvm-gcc --version 2> /dev/null)" ]; then
73 IS_XFAIL=1
74 echo "llvm-gcc not found"
75 fi
76fi
77
78if (grep -q "%llvmgxx" $FILENAME); then
79 if [ -z "$(llvm-g++ --version 2> /dev/null)" ]; then
80 IS_XFAIL=1
81 echo "llvm-g++ not found"
82 fi
83fi
84
Gabor Greif1e2db032008-03-20 22:50:54 +000085/bin/sh $SCRIPT > $OUTPUT 2>&1
86SCRIPT_STATUS=$?
87
88if [ -n "$VG" ]; then
Nuno Lopesf557fb72008-09-04 18:33:57 +000089 [ ! -s $OUTPUT.vg ]
90 VG_STATUS=$?
Gabor Greif1e2db032008-03-20 22:50:54 +000091else
92 VG_STATUS=0
93fi
94
Daniel Dunbar607b17b2008-09-04 00:30:11 +000095if [ $IS_XFAIL -ne 0 ]; then
96 if [ $SCRIPT_STATUS -ne 0 ]; then
97 SCRIPT_STATUS=0
98 else
99 SCRIPT_STATUS=1
100 fi
101fi
102
Gabor Greif1e2db032008-03-20 22:50:54 +0000103if [ $SCRIPT_STATUS -ne 0 -o $VG_STATUS -ne 0 ]; then
Reid Spencer5f016e22007-07-11 17:01:13 +0000104 echo "******************** TEST '$TESTNAME' FAILED! ********************"
105 echo "Command: "
106 cat $SCRIPT
Gabor Greif1e2db032008-03-20 22:50:54 +0000107 if [ $SCRIPT_STATUS -eq 0 ]; then
108 echo "Output:"
Daniel Dunbar607b17b2008-09-04 00:30:11 +0000109 elif [ $IS_XFAIL -ne 0 ]; then
110 echo "Incorrect Output (Expected Failure):"
Gabor Greif1e2db032008-03-20 22:50:54 +0000111 else
112 echo "Incorrect Output:"
113 fi
Reid Spencer5f016e22007-07-11 17:01:13 +0000114 cat $OUTPUT
Gabor Greif1e2db032008-03-20 22:50:54 +0000115 if [ $VG_STATUS -ne 0 ]; then
116 echo "Valgrind Output:"
Nuno Lopesf557fb72008-09-04 18:33:57 +0000117 cat $OUTPUT.vg
Gabor Greif1e2db032008-03-20 22:50:54 +0000118 fi
Reid Spencer5f016e22007-07-11 17:01:13 +0000119 echo "******************** TEST '$TESTNAME' FAILED! ********************"
Gabor Greif5ca1b5a2008-03-17 12:35:00 +0000120 exit 1
Gabor Greif1e2db032008-03-20 22:50:54 +0000121fi
Reid Spencer5f016e22007-07-11 17:01:13 +0000122