Move the CMake unit tests to auto/
authorStephen Kelly <stephen.kelly@kdab.com>
Wed, 18 Apr 2012 14:46:26 +0000 (16:46 +0200)
committerQt by Nokia <qt-info@nokia.com>
Mon, 23 Apr 2012 15:03:56 +0000 (17:03 +0200)
This will allow the CI system to run the tests. The tests are only
run if cmake is found.

Change-Id: Ie73a56114c151871160bafcbf0b90b2d54620855
Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com>
Reviewed-by: Stephen Kelly <stephen.kelly@kdab.com>
Reviewed-by: Sergio Ahumada <sergio.ahumada@nokia.com>
35 files changed:
tests/auto/auto.pro
tests/auto/cmake/CMakeLists.txt [moved from tests/manual/cmake/CMakeLists.txt with 100% similarity]
tests/auto/cmake/cmake.pro [new file with mode: 0644]
tests/auto/cmake/fail4/CMakeLists.txt [moved from tests/manual/cmake/fail4/CMakeLists.txt with 100% similarity]
tests/auto/cmake/fail4/myobject.cpp [moved from tests/manual/cmake/fail5/myobject.cpp with 100% similarity]
tests/auto/cmake/fail4/myobject.h [moved from tests/manual/cmake/pass2/myobject.h with 100% similarity]
tests/auto/cmake/fail4/pass4.qrc [moved from tests/manual/cmake/fail4/pass4.qrc with 100% similarity]
tests/auto/cmake/fail4/resource_file.txt [moved from tests/manual/cmake/pass2/resource_file.txt with 100% similarity]
tests/auto/cmake/fail5/CMakeLists.txt [moved from tests/manual/cmake/fail5/CMakeLists.txt with 100% similarity]
tests/auto/cmake/fail5/myobject.cpp [moved from tests/manual/cmake/fail4/myobject.cpp with 100% similarity]
tests/auto/cmake/fail5/myobject.h [moved from tests/manual/cmake/fail5/myobject.h with 100% similarity]
tests/auto/cmake/pass(needsquoting)6/CMakeLists.txt [moved from tests/manual/cmake/pass(needsquoting)6/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass(needsquoting)6/mywidget.cpp [moved from tests/manual/cmake/pass3/mywidget.cpp with 100% similarity]
tests/auto/cmake/pass(needsquoting)6/mywidget.h [moved from tests/manual/cmake/pass3/mywidget.h with 100% similarity]
tests/auto/cmake/pass(needsquoting)6/mywidget.ui [moved from tests/manual/cmake/pass3/mywidget.ui with 100% similarity]
tests/auto/cmake/pass1/CMakeLists.txt [moved from tests/manual/cmake/pass1/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass1/three.cpp [moved from tests/manual/cmake/pass1/three.cpp with 100% similarity]
tests/auto/cmake/pass1/two.cpp [moved from tests/manual/cmake/pass1/two.cpp with 100% similarity]
tests/auto/cmake/pass2/CMakeLists.txt [moved from tests/manual/cmake/pass2/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass2/myobject.cpp [moved from tests/manual/cmake/pass2/myobject.cpp with 100% similarity]
tests/auto/cmake/pass2/myobject.h [moved from tests/manual/cmake/fail4/myobject.h with 100% similarity]
tests/auto/cmake/pass2/pass2.qrc [moved from tests/manual/cmake/pass2/pass2.qrc with 100% similarity]
tests/auto/cmake/pass2/resource_file.txt [moved from tests/manual/cmake/fail4/resource_file.txt with 100% similarity]
tests/auto/cmake/pass3/CMakeLists.txt [moved from tests/manual/cmake/pass3/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass3/mywidget.cpp [moved from tests/manual/cmake/pass(needsquoting)6/mywidget.cpp with 100% similarity]
tests/auto/cmake/pass3/mywidget.h [moved from tests/manual/cmake/pass(needsquoting)6/mywidget.h with 100% similarity]
tests/auto/cmake/pass3/mywidget.ui [moved from tests/manual/cmake/pass(needsquoting)6/mywidget.ui with 100% similarity]
tests/auto/cmake/pass7/CMakeLists.txt [moved from tests/manual/cmake/pass7/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass7/main.cpp [moved from tests/manual/cmake/pass7/main.cpp with 100% similarity]
tests/auto/cmake/pass8/CMakeLists.txt [moved from tests/manual/cmake/pass8/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass8/myobject.cpp [moved from tests/manual/cmake/pass8/myobject.cpp with 100% similarity]
tests/auto/cmake/pass8/myobject.h [moved from tests/manual/cmake/pass8/myobject.h with 100% similarity]
tests/auto/cmake/pass9/CMakeLists.txt [moved from tests/manual/cmake/pass9/CMakeLists.txt with 100% similarity]
tests/auto/cmake/pass9/mydbusobject.cpp [moved from tests/manual/cmake/pass9/mydbusobject.cpp with 100% similarity]
tests/auto/cmake/pass9/mydbusobject.h [moved from tests/manual/cmake/pass9/mydbusobject.h with 100% similarity]

index 2322112..bd69fa1 100644 (file)
@@ -14,6 +14,7 @@ SUBDIRS += \
     other \
     widgets \
     printsupport \
+    cmake
 
 cross_compile:                              SUBDIRS -= tools
 !contains(QT_CONFIG, opengl):               SUBDIRS -= opengl
diff --git a/tests/auto/cmake/cmake.pro b/tests/auto/cmake/cmake.pro
new file mode 100644 (file)
index 0000000..9767914
--- /dev/null
@@ -0,0 +1,50 @@
+
+CMAKE_VERSION = $$system(cmake --version)
+
+# Cause make to do nothing.
+TEMPLATE = subdirs
+
+check.commands =
+isEmpty(CMAKE_VERSION) {
+    message("cmake executable not found. Not running CMake unit tests")
+} else {
+    CTEST_VERSION = $$system(ctest --version)
+    isEmpty(CTEST_VERSION) {
+        message("ctest executable not found. Not running CMake unit tests")
+    } else {
+        CMAKE_VERSION = $$last(CMAKE_VERSION)
+        CMAKE_VERSION_MAJOR = $$section(CMAKE_VERSION, ., 0, 0)
+        CMAKE_VERSION_MINOR = $$section(CMAKE_VERSION, ., 1, 1)
+        CMAKE_VERSION_PATCH = $$section(CMAKE_VERSION, ., 2, 2)
+
+        VERSION_OK =
+        greaterThan(CMAKE_VERSION_MAJOR, 2) {
+            VERSION_OK = 1
+        } else:greaterThan(CMAKE_VERSION_MAJOR, 1):greaterThan(CMAKE_VERSION_MINOR, 8) {
+            VERSION_OK = 1
+        } else:greaterThan(CMAKE_VERSION_MAJOR, 1):greaterThan(CMAKE_VERSION_MINOR, 7):greaterThan(CMAKE_VERSION_PATCH, 2) {
+            VERSION_OK = 1
+        }
+
+        isEmpty(VERSION_OK) {
+            message("cmake $$CMAKE_VERSION is too old for this test.")
+        } else {
+            SET = set
+            equals(QMAKE_DIR_SEP, "/"):SET = export
+
+            CMAKE_BUILD_TYPE = Debug
+            CONFIG(release, debug|release):CMAKE_BUILD_TYPE = Release
+
+            BUILD_DIR = $$replace($$list($$OUT_PWD/build), /, $$QMAKE_DIR_SEP)
+
+            check.commands = \
+                cd . && $$SET CMAKE_PREFIX_PATH=$$[QT_INSTALL_PREFIX] && \
+                $(MKDIR) $$BUILD_DIR && cd $$BUILD_DIR && \
+                cmake $$_PRO_FILE_PWD_ -DCMAKE_BUILD_TYPE=$${CMAKE_BUILD_TYPE} && \
+                $(TESTRUNNER) ctest --output-on-failure
+
+        }
+    }
+}
+
+QMAKE_EXTRA_TARGETS *= check