aboutsummaryrefslogtreecommitdiff
path: root/projects/CMake
diff options
context:
space:
mode:
authorSzczepan Zalega <szczepan@nitrokey.com>2017-12-22 16:53:56 +0100
committerSzczepan Zalega <szczepan@nitrokey.com>2017-12-22 16:53:56 +0100
commit48b3d82ffe1ed19db9ba3cf7e6536ecf92e27391 (patch)
tree83645ddf58fd9514e1fe6d566839bb2747ee4706 /projects/CMake
downloadlibnitrokey-48b3d82ffe1ed19db9ba3cf7e6536ecf92e27391.tar.gz
libnitrokey-48b3d82ffe1ed19db9ba3cf7e6536ecf92e27391.tar.bz2
Squashed 'unittest/Catch/' content from commit ae5ee2cf
git-subtree-dir: unittest/Catch git-subtree-split: ae5ee2cf63d6d67bd1369b512d2a7b60b571c907
Diffstat (limited to 'projects/CMake')
-rw-r--r--projects/CMake/CMakeLists.txt48
1 files changed, 48 insertions, 0 deletions
diff --git a/projects/CMake/CMakeLists.txt b/projects/CMake/CMakeLists.txt
new file mode 100644
index 0000000..960d9fb
--- /dev/null
+++ b/projects/CMake/CMakeLists.txt
@@ -0,0 +1,48 @@
+cmake_minimum_required(VERSION 2.8)
+
+project(Catch)
+
+# define some folders
+get_filename_component(CATCH_DIR "${CMAKE_CURRENT_SOURCE_DIR}" PATH)
+get_filename_component(CATCH_DIR "${CATCH_DIR}" PATH)
+set(SELF_TEST_DIR ${CATCH_DIR}/projects/SelfTest)
+if(USE_CPP11)
+ ## We can't turn this on by default, since it breaks on travis
+ message(STATUS "Enabling C++11")
+ set(CMAKE_CXX_FLAGS "-std=c++11 ${CMAKE_CXX_FLAGS}")
+endif()
+
+# define the sources of the self test
+set(SOURCES
+ ${SELF_TEST_DIR}/ApproxTests.cpp
+ ${SELF_TEST_DIR}/BDDTests.cpp
+ ${SELF_TEST_DIR}/ClassTests.cpp
+ ${SELF_TEST_DIR}/ConditionTests.cpp
+ ${SELF_TEST_DIR}/ExceptionTests.cpp
+ ${SELF_TEST_DIR}/GeneratorTests.cpp
+ ${SELF_TEST_DIR}/MessageTests.cpp
+ ${SELF_TEST_DIR}/MiscTests.cpp
+ ${SELF_TEST_DIR}/PartTrackerTests.cpp
+ ${SELF_TEST_DIR}/TestMain.cpp
+ ${SELF_TEST_DIR}/TrickyTests.cpp
+ ${SELF_TEST_DIR}/VariadicMacrosTests.cpp
+ ${SELF_TEST_DIR}/EnumToString.cpp
+ ${SELF_TEST_DIR}/ToStringPair.cpp
+ ${SELF_TEST_DIR}/ToStringVector.cpp
+ ${SELF_TEST_DIR}/ToStringWhich.cpp
+ ${SELF_TEST_DIR}/ToStringTuple.cpp
+)
+
+# configure the executable
+include_directories(${CATCH_DIR}/include)
+add_executable(SelfTest ${SOURCES})
+
+# configure unit tests via CTest
+enable_testing()
+add_test(NAME RunTests COMMAND SelfTest)
+
+add_test(NAME ListTests COMMAND SelfTest --list-tests)
+set_tests_properties(ListTests PROPERTIES PASS_REGULAR_EXPRESSION "[0-9]+ test cases")
+
+add_test(NAME ListTags COMMAND SelfTest --list-tags)
+set_tests_properties(ListTags PROPERTIES PASS_REGULAR_EXPRESSION "[0-9]+ tags")