blob: a00f8c5c08cabdabf3e71867c754783db463e312 [file] [log] [blame]
# AUTHORS: Dan Liew, Ryan Gvostes, Mate Soos
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
# -----------------------------------------------------------------------------
# Check we can find the lit tool
# -----------------------------------------------------------------------------
find_program(LIT_TOOL
lit
DOC "Path to lit tool"
)
if(NOT LIT_TOOL)
message(FATAL_ERROR "Could not find 'lit' tool. You need to install it by e.g. 'pip install lit' If it's already installed, set LIT_TOOL to the full path for lit")
endif()
# Checking absolute path because if(EXISTS ...) behaviour only well
# defined if path is absolute
IF(NOT IS_ABSOLUTE "${LIT_TOOL}")
message(FATAL_ERROR "LIT_TOOL must be set to an absolute PATH")
endif()
if(NOT EXISTS "${LIT_TOOL}")
# Can happen if users environment changes after initial configure
message(FATAL_ERROR "LIT_TOOL is set but the path does not seem to exist. Try deleting the LIT_TOOL cache variable and reconfiguring")
endif()
set(LIT_ARGS -s CACHE STRING "Arguments to pass to lit")
# -----------------------------------------------------------------------------
# Find GTest library which will be used to drive tests
# -----------------------------------------------------------------------------
# GoogleTest devs don't recommend using a pre-built GTest library
# ( https://code.google.com/p/googletest/wiki/FAQ#Why_is_it_not_recommended_to_install_a_pre-compiled_copy_of_Goog ).
# Because of this, distros like Ubuntu don't provide a pre-built GTest library
# so ``find_package(GTest REQUIRED)`` fails.
#
# Instead it is recommended that projects build their own copy of GTest. Detecting
# the location of GTest source code is probably error prone so using a copy in the
# repository seems like the easiest thing to do. This also has the added benefit that
# everyone uses the same version of GTest.
set(GTEST_PREFIX ${PROJECT_SOURCE_DIR}/deps/gtest)
if (NOT EXISTS "${GTEST_PREFIX}/CMakeLists.txt")
message(FATAL_ERROR "Could not find GTest. Did you run scripts/deps/setup-gtest.sh?")
endif()
if (MSVC)
# STP is built with the shared version of the CRT, gtest defaults to the
# static one, and they can't be mixed. Foring gtest to use the dynamic one.
set(gtest_force_shared_crt ON CACHE BOOL "" FORCE)
endif()
set(PREV_CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-format-nonliteral -Wno-missing-field-initializers")
add_subdirectory(${GTEST_PREFIX} gtest)
set(CMAKE_CXX_FLAGS "${PREV_CMAKE_CXX_FLAGS}")
set(GTEST_BOTH_LIBRARIES gtest gtest_main)
include_directories(${GTEST_PREFIX}/include)
# Add handy macros/functions
include(AddSTPGTest)
include(AddGTestSuite)
# -----------------------------------------------------------------------------
# Provide option for running unit tests with valgrind
# -----------------------------------------------------------------------------
option(USE_VALGRIND "Use Valgrind when running unit tests" OFF)
if(USE_VALGRIND)
# Make sure valgrind is currently in PATH
find_program(VALGRIND_TOOL valgrind
NO_CMAKE_PATH
NO_CMAKE_ENVIRONMENT_PATH
NO_CMAKE_SYSTEM_PATH
)
if(NOT VALGRIND_TOOL)
message(FATAL_ERROR "Cannot find valgrind in your PATH")
else()
message(STATUS "Found valgrind : ${VALGRIND_TOOL}")
endif()
# Note we don't use the VALGRIND_TOOL variable, we just
# want to make sure it in the user's PATH so that when
# lit tries to use it later it doesn't exit with an unhelpful
# error message
endif()
# -----------------------------------------------------------------------------
# Tests that drive STP by using query files (e.g. smt2, smt and cvc files)
# -----------------------------------------------------------------------------
option(TEST_QUERY_FILES
"Enable tests that use query files to drive STP"
ON
)
if(TEST_QUERY_FILES)
add_subdirectory(query-files)
endif()
# -----------------------------------------------------------------------------
# Tests that test STP's various different public APIs
# -----------------------------------------------------------------------------
# FIXME: Enable by default
option(TEST_APIS
"Enable tests that test STP's public APIs"
ON
)
if(TEST_APIS)
add_subdirectory(api)
endif()
# -----------------------------------------------------------------------------
# Generated tests
# -----------------------------------------------------------------------------
# FIXME: Enable by default
option(TEST_GENERATED_QUERIES
"Enable tests that are driven by automatically generated queries"
OFF
)
if(TEST_GENERATED_QUERIES)
message(FATAL_ERROR "TODO")
add_subdirectory(generated-tests)
endif()
# -----------------------------------------------------------------------------
# Unit tests
# -----------------------------------------------------------------------------
option(TEST_UNITS
"Enable unit tests"
ON
)
if(TEST_UNITS)
add_subdirectory(unit-tests)
endif()