Fix documentation bugs
[oota-llvm.git] / test / Makefile
index 5483e9ca5eba60fb385c5e46899c53119844e0c5..ad9c6ecbd4783a3a9830f3e6fef1ac5735229761 100644 (file)
@@ -1,12 +1,17 @@
 LEVEL  = ..
 DIRS   = Programs
-include Makefile.tests
 
 #
 # Make QMTest the default for testing features and regressions
+# Do this first to force QMTest to run first
 #
 all:: qmtest
 
+#
+# Include other test rules
+#
+include Makefile.tests
+
 #
 # New QMTest functionality:
 #      The test suite is being transitioned over to QMTest.  Eventually, it
@@ -17,20 +22,32 @@ all:: qmtest
 QMDB= -D $(LLVM_SRC_ROOT)/test
 QMCLASSES=$(LLVM_OBJ_ROOT)/test/QMTest
 
+#
+# Determine which expectations file we will use
+#
+QMEXPECT:=$(LLVM_SRC_ROOT)/test/QMTest/expectations.unknown.qmr
+ifeq ($(OS),Linux)
+QMEXPECT:=$(LLVM_SRC_ROOT)/test/QMTest/expectations.linux.qmr
+endif
+
+ifeq ($(OS),SunOS)
+QMEXPECT:=$(LLVM_SRC_ROOT)/test/QMTest/expectations.sunos.qmr
+endif
+
 #
 # This is configuration information used by the test suite.  In QM Test, it's
 # called a 'context.'
 #
-CONTEXT= -c srcroot=$(LLVM_SRC_ROOT) \
-         -c buildroot=$(LLVM_OBJ_ROOT) \
-         -c buildtype=$(CONFIGURATION) \
-         -c tmpdir=$(LLVM_OBJ_ROOT)/test/tmp \
-         -c coresize=0 \
-         -c cc=$(CC) \
-         -c cxx=$(CXX) \
+CONTEXT= -c "srcroot=$(LLVM_SRC_ROOT)" \
+         -c "buildroot=$(LLVM_OBJ_ROOT)" \
+         -c "buildtype=$(CONFIGURATION)" \
+         -c "tmpdir=$(LLVM_OBJ_ROOT)/test/tmp" \
+         -c "coresize=0" \
+         -c "cc=$(CC)" \
+         -c "cxx=$(CXX)" \
          -c "llvmgcc=$(LLVMGCC)" \
          -c "llvmgxx=$(LLVMGXX)" \
-         -c make=$(MAKE)
+         -c "make=$(MAKE)"
 
 #
 # Location of the QMTest program.
@@ -42,10 +59,10 @@ QMTEST= QMTEST_CLASS_PATH=$(QMCLASSES) qmtest $(QMDB)
 # Execute the tests
 #
 qmtest:: $(LLVM_OBJ_ROOT)/test/tmp register
-       $(QMTEST) run -O $(LLVM_SRC_ROOT)/test/QMTest/expectations.qmr $(CONTEXT)
+       -$(QMTEST) run -O $(QMEXPECT) $(CONTEXT)
 
 %.t:: $(LLVM_OBJ_ROOT)/test/tmp register
-       $(QMTEST) run -O $(LLVM_SRC_ROOT)/test/QMTest/expectations.qmr $(CONTEXT) $*
+       -$(QMTEST) run -O $(QMEXPECT) $(CONTEXT) $*
 
 #
 # Create the temporary directory used by the test suite.
@@ -74,12 +91,17 @@ register:
        $(QMTEST) register test llvm.CXXTest
        $(QMTEST) register database llvmdb.llvmdb
 
-#
 # Start up the QMTest GUI
-#
 gui::
        $(QMTEST) gui --no-browser --daemon
 
-clean::
+# Also get rid of qmtest garbage when we 'make clean' in this directory.
+clean:: qmtest-clean
+
+qmtest-clean:
        $(RM) -rf $(LLVM_OBJ_ROOT)/test/tmp
+       $(RM) -f $(LLVM_SRC_ROOT)/test/QMTest/*.pyo \
+               $(LLVM_OBJ_ROOT)/test/QMTest/*.pyo
+       $(RM) -f $(LLVM_SRC_ROOT)/test/results.qmr \
+               $(LLVM_OBJ_ROOT)/test/results.qmr