aboutsummaryrefslogtreecommitdiffstats
path: root/tests/CMakeLists.txt
diff options
context:
space:
mode:
authorDan Albert <danalbert@google.com>2016-11-02 23:20:44 +0000
committerandroid-build-merger <android-build-merger@google.com>2016-11-02 23:20:44 +0000
commit1f29230e1792466b05064003a719187425ddc581 (patch)
tree58c9c3b6c5838d9f02a7b31cc0401cc006e48e52 /tests/CMakeLists.txt
parent00d43d4dd182cc4ed525f5ac62774bd19b516a95 (diff)
parent9fbbf8bb2f09a49169f819fa4d6651379b9a3ae2 (diff)
downloadplatform_external_Microsoft-GSL-1f29230e1792466b05064003a719187425ddc581.tar.gz
platform_external_Microsoft-GSL-1f29230e1792466b05064003a719187425ddc581.tar.bz2
platform_external_Microsoft-GSL-1f29230e1792466b05064003a719187425ddc581.zip
Merge remote-tracking branch 'aosp/upstream-master' into master am: 65c0aaa266 am: 8141d27f91
am: 9fbbf8bb2f Change-Id: I4fdd1fdabfd50ac696439df64bf93446e610c19c
Diffstat (limited to 'tests/CMakeLists.txt')
-rw-r--r--tests/CMakeLists.txt54
1 files changed, 54 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
new file mode 100644
index 0000000..44db32d
--- /dev/null
+++ b/tests/CMakeLists.txt
@@ -0,0 +1,54 @@
+cmake_minimum_required(VERSION 2.8.7)
+
+project(GSLTests CXX)
+
+if (NOT EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/unittest-cpp/tests)
+ execute_process(COMMAND git submodule update --init WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}")
+endif()
+
+add_subdirectory(unittest-cpp)
+
+include_directories(
+ ..
+ ./unittest-cpp
+)
+
+add_definitions(-DGSL_THROW_ON_CONTRACT_VIOLATION)
+
+if(MSVC14 OR MSVC12) # has the support we need
+ # remove unnecessary warnings about unchecked iterators
+ add_definitions(-D_SCL_SECURE_NO_WARNINGS)
+ add_compile_options(/W4)
+else()
+ include(CheckCXXCompilerFlag)
+ CHECK_CXX_COMPILER_FLAG("-std=c++14" COMPILER_SUPPORTS_CXX14)
+ CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11)
+ if(COMPILER_SUPPORTS_CXX14)
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-strict-aliasing -std=c++14 -O3 -Wall -Wno-missing-braces")
+ elseif(COMPILER_SUPPORTS_CXX11)
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-strict-aliasing -std=c++11 -O3 -Wall -Wno-missing-braces")
+ else()
+ message(STATUS "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.")
+ endif()
+endif()
+
+function(add_gsl_test name)
+ add_executable(${name} ${name}.cpp ../gsl/gsl ../gsl/gsl_assert ../gsl/gsl_util ../gsl/multi_span ../gsl/span ../gsl/string_span)
+ target_link_libraries(${name} UnitTest++)
+ add_test(
+ ${name}
+ ${name}
+ )
+endfunction()
+
+add_gsl_test(span_tests)
+add_gsl_test(multi_span_tests)
+add_gsl_test(strided_span_tests)
+add_gsl_test(string_span_tests)
+add_gsl_test(at_tests)
+add_gsl_test(bounds_tests)
+add_gsl_test(notnull_tests)
+add_gsl_test(assertion_tests)
+add_gsl_test(utils_tests)
+add_gsl_test(owner_tests)
+add_gsl_test(byte_tests)