Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
# CMakeLists.txt -- Build system for the pybind11 test suite
|
|
|
|
#
|
|
|
|
# Copyright (c) 2015 Wenzel Jakob <wenzel@inf.ethz.ch>
|
|
|
|
#
|
|
|
|
# All rights reserved. Use of this source code is governed by a
|
|
|
|
# BSD-style license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
cmake_minimum_required(VERSION 2.8.12)
|
|
|
|
|
|
|
|
option(PYBIND11_WERROR "Report all warnings as errors" OFF)
|
|
|
|
|
|
|
|
if (CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR)
|
|
|
|
# We're being loaded directly, i.e. not via add_subdirectory, so make this
|
|
|
|
# work as its own project and load the pybind11Config to get the tools we need
|
|
|
|
project(pybind11_tests)
|
|
|
|
|
|
|
|
find_package(pybind11 REQUIRED CONFIG)
|
|
|
|
endif()
|
|
|
|
|
2016-08-12 11:50:00 +00:00
|
|
|
if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
|
|
|
|
message(STATUS "Setting tests build type to MinSizeRel as none was specified")
|
2016-09-17 10:58:18 +00:00
|
|
|
set(CMAKE_BUILD_TYPE MinSizeRel CACHE STRING "Choose the type of build." FORCE)
|
|
|
|
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release"
|
|
|
|
"MinSizeRel" "RelWithDebInfo")
|
2016-08-12 11:50:00 +00:00
|
|
|
endif()
|
|
|
|
|
2016-11-13 00:10:53 +00:00
|
|
|
# Full set of test files (you can override these; see below)
|
2016-08-12 11:50:00 +00:00
|
|
|
set(PYBIND11_TEST_FILES
|
Implement py::init_alias<>() constructors
This commit adds support for forcing alias type initialization by
defining constructors with `py::init_alias<arg1, arg2>()` instead of
`py::init<arg1, arg2>()`. Currently py::init<> only results in Alias
initialization if the type is extended in python, or the given
arguments can't be used to construct the base type, but can be used to
construct the alias. py::init_alias<>, in contrast, always invokes the
constructor of the alias type.
It looks like this was already the intention of
`py::detail::init_alias`, which was forward-declared in
86d825f3302701d81414ddd3d38bcd09433076bc, but was apparently never
finished: despite the existance of a .def method accepting it, the
`detail::init_alias` class isn't actually defined anywhere.
This commit completes the feature (or possibly repurposes it), allowing
declaration of classes that will always initialize the trampoline which
is (as I argued in #397) sometimes useful.
2016-09-09 06:42:51 +00:00
|
|
|
test_alias_initialization.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_buffers.cpp
|
2017-03-16 10:22:26 +00:00
|
|
|
test_call_policies.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_callbacks.cpp
|
2016-08-25 13:08:04 +00:00
|
|
|
test_chrono.cpp
|
Allow arbitrary class_ template option ordering
The current pybind11::class_<Type, Holder, Trampoline> fixed template
ordering results in a requirement to repeat the Holder with its default
value (std::unique_ptr<Type>) argument, which is a little bit annoying:
it needs to be specified not because we want to override the default,
but rather because we need to specify the third argument.
This commit removes this limitation by making the class_ template take
the type name plus a parameter pack of options. It then extracts the
first valid holder type and the first subclass type for holder_type and
trampoline type_alias, respectively. (If unfound, both fall back to
their current defaults, `std::unique_ptr<type>` and `type`,
respectively). If any unmatched template arguments are provided, a
static assertion fails.
What this means is that you can specify or omit the arguments in any
order:
py::class_<A, PyA> c1(m, "A");
py::class_<B, PyB, std::shared_ptr<B>> c2(m, "B");
py::class_<C, std::shared_ptr<C>, PyB> c3(m, "C");
It also allows future class attributes (such as base types in the next
commit) to be passed as class template types rather than needing to use
a py::base<> wrapper.
2016-09-06 16:17:06 +00:00
|
|
|
test_class_args.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_constants_and_functions.cpp
|
2017-05-14 19:57:26 +00:00
|
|
|
test_copy_move.cpp
|
2016-11-15 11:38:05 +00:00
|
|
|
test_docstring_options.cpp
|
2016-09-03 18:54:22 +00:00
|
|
|
test_eigen.cpp
|
2016-08-12 22:57:24 +00:00
|
|
|
test_enum.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_eval.cpp
|
|
|
|
test_exceptions.cpp
|
|
|
|
test_inheritance.cpp
|
|
|
|
test_issues.cpp
|
|
|
|
test_kwargs_and_defaults.cpp
|
|
|
|
test_methods_and_attributes.cpp
|
|
|
|
test_modules.cpp
|
2016-09-20 09:52:25 +00:00
|
|
|
test_multiple_inheritance.cpp
|
2016-08-29 01:41:05 +00:00
|
|
|
test_numpy_array.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_numpy_dtypes.cpp
|
|
|
|
test_numpy_vectorize.cpp
|
|
|
|
test_opaque_types.cpp
|
|
|
|
test_operator_overloading.cpp
|
|
|
|
test_pickling.cpp
|
|
|
|
test_python_types.cpp
|
|
|
|
test_sequences_and_iterators.cpp
|
2016-09-20 09:52:25 +00:00
|
|
|
test_smart_ptr.cpp
|
2016-08-12 11:50:00 +00:00
|
|
|
test_stl_binders.cpp
|
|
|
|
test_virtual_functions.cpp
|
|
|
|
)
|
|
|
|
|
2016-11-13 00:10:53 +00:00
|
|
|
# Invoking cmake with something like:
|
|
|
|
# cmake -DPYBIND11_TEST_OVERRIDE="test_issues.cpp;test_picking.cpp" ..
|
|
|
|
# lets you override the tests that get compiled and run. You can restore to all tests with:
|
|
|
|
# cmake -DPYBIND11_TEST_OVERRIDE= ..
|
|
|
|
if (PYBIND11_TEST_OVERRIDE)
|
|
|
|
set(PYBIND11_TEST_FILES ${PYBIND11_TEST_OVERRIDE})
|
|
|
|
endif()
|
|
|
|
|
2016-09-03 18:54:22 +00:00
|
|
|
string(REPLACE ".cpp" ".py" PYBIND11_PYTEST_FILES "${PYBIND11_TEST_FILES}")
|
2016-08-12 11:50:00 +00:00
|
|
|
|
2016-09-03 18:54:22 +00:00
|
|
|
# Check if Eigen is available; if not, remove from PYBIND11_TEST_FILES (but
|
|
|
|
# keep it in PYBIND11_PYTEST_FILES, so that we get the "eigen is not installed"
|
|
|
|
# skip message).
|
|
|
|
list(FIND PYBIND11_TEST_FILES test_eigen.cpp PYBIND11_TEST_FILES_EIGEN_I)
|
|
|
|
if(PYBIND11_TEST_FILES_EIGEN_I GREATER -1)
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
# Try loading via newer Eigen's Eigen3Config first (bypassing tools/FindEigen3.cmake).
|
|
|
|
# Eigen 3.3.1+ exports a cmake 3.0+ target for handling dependency requirements, but also
|
|
|
|
# produces a fatal error if loaded from a pre-3.0 cmake.
|
|
|
|
if (NOT CMAKE_VERSION VERSION_LESS 3.0)
|
|
|
|
find_package(Eigen3 QUIET CONFIG)
|
|
|
|
if (EIGEN3_FOUND)
|
|
|
|
if (EIGEN3_VERSION_STRING AND NOT EIGEN3_VERSION_STRING VERSION_LESS 3.3.1)
|
|
|
|
set(PYBIND11_EIGEN_VIA_TARGET 1)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if (NOT EIGEN3_FOUND)
|
|
|
|
# Couldn't load via target, so fall back to allowing module mode finding, which will pick up
|
|
|
|
# tools/FindEigen3.cmake
|
|
|
|
find_package(Eigen3 QUIET)
|
|
|
|
endif()
|
2016-09-03 18:54:22 +00:00
|
|
|
|
|
|
|
if(EIGEN3_FOUND)
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
# Eigen 3.3.1+ cmake sets EIGEN3_VERSION_STRING (and hard codes the version when installed
|
|
|
|
# rather than looking it up in the cmake script); older versions, and the
|
|
|
|
# tools/FindEigen3.cmake, set EIGEN3_VERSION instead.
|
|
|
|
if(NOT EIGEN3_VERSION AND EIGEN3_VERSION_STRING)
|
|
|
|
set(EIGEN3_VERSION ${EIGEN3_VERSION_STRING})
|
|
|
|
endif()
|
2016-09-03 18:54:22 +00:00
|
|
|
message(STATUS "Building tests with Eigen v${EIGEN3_VERSION}")
|
|
|
|
else()
|
|
|
|
list(REMOVE_AT PYBIND11_TEST_FILES ${PYBIND11_TEST_FILES_EIGEN_I})
|
|
|
|
message(STATUS "Building tests WITHOUT Eigen")
|
|
|
|
endif()
|
2016-08-12 11:50:00 +00:00
|
|
|
endif()
|
|
|
|
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
# Compile with compiler warnings turned on
|
|
|
|
function(pybind11_enable_warnings target_name)
|
|
|
|
if(MSVC)
|
|
|
|
target_compile_options(${target_name} PRIVATE /W4)
|
|
|
|
else()
|
|
|
|
target_compile_options(${target_name} PRIVATE -Wall -Wextra -Wconversion -Wcast-qual)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(PYBIND11_WERROR)
|
|
|
|
if(MSVC)
|
|
|
|
target_compile_options(${target_name} PRIVATE /WX)
|
|
|
|
else()
|
|
|
|
target_compile_options(${target_name} PRIVATE -Werror)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
2016-08-12 11:50:00 +00:00
|
|
|
# Create the binding library
|
2017-01-17 07:13:11 +00:00
|
|
|
pybind11_add_module(pybind11_tests THIN_LTO pybind11_tests.cpp
|
2016-09-29 19:30:00 +00:00
|
|
|
${PYBIND11_TEST_FILES} ${PYBIND11_HEADERS})
|
|
|
|
|
2016-08-12 11:50:00 +00:00
|
|
|
pybind11_enable_warnings(pybind11_tests)
|
|
|
|
|
|
|
|
if(EIGEN3_FOUND)
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
if (PYBIND11_EIGEN_VIA_TARGET)
|
|
|
|
target_link_libraries(pybind11_tests PRIVATE Eigen3::Eigen)
|
|
|
|
else()
|
|
|
|
target_include_directories(pybind11_tests PRIVATE ${EIGEN3_INCLUDE_DIR})
|
|
|
|
endif()
|
2016-08-12 11:50:00 +00:00
|
|
|
target_compile_definitions(pybind11_tests PRIVATE -DPYBIND11_TEST_EIGEN)
|
|
|
|
endif()
|
|
|
|
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
set(testdir ${CMAKE_CURRENT_SOURCE_DIR})
|
2016-08-12 11:50:00 +00:00
|
|
|
|
|
|
|
# Always write the output file directly into the 'tests' directory (even on MSVC)
|
|
|
|
if(NOT CMAKE_LIBRARY_OUTPUT_DIRECTORY)
|
|
|
|
set_target_properties(pybind11_tests PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${testdir})
|
|
|
|
foreach(config ${CMAKE_CONFIGURATION_TYPES})
|
|
|
|
string(TOUPPER ${config} config)
|
|
|
|
set_target_properties(pybind11_tests PROPERTIES LIBRARY_OUTPUT_DIRECTORY_${config} ${testdir})
|
|
|
|
endforeach()
|
|
|
|
endif()
|
|
|
|
|
2016-08-26 21:11:40 +00:00
|
|
|
# Make sure pytest is found or produce a fatal error
|
2016-08-13 00:44:56 +00:00
|
|
|
if(NOT PYBIND11_PYTEST_FOUND)
|
2017-03-10 14:42:42 +00:00
|
|
|
execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "import pytest; print(pytest.__version__)"
|
|
|
|
RESULT_VARIABLE pytest_not_found OUTPUT_VARIABLE pytest_version ERROR_QUIET)
|
|
|
|
if(pytest_not_found)
|
|
|
|
message(FATAL_ERROR "Running the tests requires pytest. Please install it manually"
|
|
|
|
" (try: ${PYTHON_EXECUTABLE} -m pip install pytest)")
|
|
|
|
elseif(pytest_version VERSION_LESS 3.0)
|
|
|
|
message(FATAL_ERROR "Running the tests requires pytest >= 3.0. Found: ${pytest_version}"
|
|
|
|
"Please update it (try: ${PYTHON_EXECUTABLE} -m pip install -U pytest)")
|
2016-08-13 00:44:56 +00:00
|
|
|
endif()
|
2016-10-09 11:51:05 +00:00
|
|
|
set(PYBIND11_PYTEST_FOUND TRUE CACHE INTERNAL "")
|
2016-08-13 00:44:56 +00:00
|
|
|
endif()
|
|
|
|
|
2017-04-28 20:43:14 +00:00
|
|
|
if(CMAKE_VERSION VERSION_LESS 3.2)
|
|
|
|
set(PYBIND11_USES_TERMINAL "")
|
|
|
|
else()
|
|
|
|
set(PYBIND11_USES_TERMINAL "USES_TERMINAL")
|
|
|
|
endif()
|
|
|
|
|
2016-08-12 11:50:00 +00:00
|
|
|
# A single command to compile and run the tests
|
2017-03-10 14:42:42 +00:00
|
|
|
add_custom_target(pytest COMMAND ${PYTHON_EXECUTABLE} -m pytest ${PYBIND11_PYTEST_FILES}
|
2017-04-28 20:43:14 +00:00
|
|
|
DEPENDS pybind11_tests WORKING_DIRECTORY ${testdir} ${PYBIND11_USES_TERMINAL})
|
2016-11-04 13:47:41 +00:00
|
|
|
|
2016-11-13 00:10:53 +00:00
|
|
|
if(PYBIND11_TEST_OVERRIDE)
|
|
|
|
add_custom_command(TARGET pytest POST_BUILD
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E echo "Note: not all tests run: -DPYBIND11_TEST_OVERRIDE is in effect")
|
|
|
|
endif()
|
|
|
|
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
# Add a check target to run all the tests, starting with pytest (we add dependencies to this below)
|
|
|
|
add_custom_target(check DEPENDS pytest)
|
|
|
|
|
|
|
|
# The remaining tests only apply when being built as part of the pybind11 project, but not if the
|
|
|
|
# tests are being built independently.
|
|
|
|
if (NOT PROJECT_NAME STREQUAL "pybind11")
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Add a post-build comment to show the .so size and, if a previous size, compare it:
|
2016-12-14 00:43:39 +00:00
|
|
|
add_custom_command(TARGET pybind11_tests POST_BUILD
|
2017-02-08 22:43:23 +00:00
|
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/libsize.py
|
2016-12-14 00:43:39 +00:00
|
|
|
$<TARGET_FILE:pybind11_tests> ${CMAKE_CURRENT_BINARY_DIR}/sosize-$<TARGET_FILE_NAME:pybind11_tests>.txt)
|
|
|
|
|
|
|
|
# Test CMake build using functions and targets from subdirectory or installed location
|
|
|
|
add_custom_target(test_cmake_build)
|
|
|
|
if(NOT CMAKE_VERSION VERSION_LESS 3.1)
|
|
|
|
# 3.0 needed for interface library for subdirectory_target/installed_target
|
2016-12-13 16:02:37 +00:00
|
|
|
# 3.1 needed for cmake -E env for testing
|
2016-12-14 00:43:39 +00:00
|
|
|
|
|
|
|
include(CMakeParseArguments)
|
|
|
|
function(pybind11_add_build_test name)
|
|
|
|
cmake_parse_arguments(ARG "INSTALL" "" "" ${ARGN})
|
|
|
|
|
|
|
|
set(build_options "-DCMAKE_PREFIX_PATH=${PROJECT_BINARY_DIR}/mock_install"
|
|
|
|
"-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}"
|
2017-04-06 20:41:24 +00:00
|
|
|
"-DPYTHON_EXECUTABLE:FILEPATH=${PYTHON_EXECUTABLE}"
|
2016-12-14 00:43:39 +00:00
|
|
|
"-DPYBIND11_CPP_STANDARD=${PYBIND11_CPP_STANDARD}")
|
|
|
|
if(NOT ARG_INSTALL)
|
|
|
|
list(APPEND build_options "-DPYBIND11_PROJECT_DIR=${PROJECT_SOURCE_DIR}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
add_custom_target(test_${name} ${CMAKE_CTEST_COMMAND}
|
|
|
|
--quiet --output-log test_cmake_build/${name}.log
|
|
|
|
--build-and-test "${CMAKE_CURRENT_SOURCE_DIR}/test_cmake_build/${name}"
|
|
|
|
"${CMAKE_CURRENT_BINARY_DIR}/test_cmake_build/${name}"
|
|
|
|
--build-config Release
|
|
|
|
--build-noclean
|
|
|
|
--build-generator ${CMAKE_GENERATOR}
|
|
|
|
$<$<BOOL:${CMAKE_GENERATOR_PLATFORM}>:--build-generator-platform> ${CMAKE_GENERATOR_PLATFORM}
|
|
|
|
--build-makeprogram ${CMAKE_MAKE_PROGRAM}
|
|
|
|
--build-target check
|
|
|
|
--build-options ${build_options}
|
2016-12-13 16:02:37 +00:00
|
|
|
)
|
2016-12-14 00:43:39 +00:00
|
|
|
if(ARG_INSTALL)
|
|
|
|
add_dependencies(test_${name} mock_install)
|
|
|
|
endif()
|
|
|
|
add_dependencies(test_cmake_build test_${name})
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
pybind11_add_build_test(subdirectory_function)
|
|
|
|
pybind11_add_build_test(subdirectory_target)
|
|
|
|
|
|
|
|
if(PYBIND11_INSTALL)
|
|
|
|
add_custom_target(mock_install ${CMAKE_COMMAND}
|
|
|
|
"-DCMAKE_INSTALL_PREFIX=${PROJECT_BINARY_DIR}/mock_install"
|
|
|
|
-P "${PROJECT_BINARY_DIR}/cmake_install.cmake"
|
2016-12-13 16:02:37 +00:00
|
|
|
)
|
2016-12-14 00:43:39 +00:00
|
|
|
|
|
|
|
pybind11_add_build_test(installed_function INSTALL)
|
|
|
|
pybind11_add_build_test(installed_target INSTALL)
|
2016-12-13 16:02:37 +00:00
|
|
|
endif()
|
|
|
|
endif()
|
2016-12-17 20:39:17 +00:00
|
|
|
|
Independent tests (#665)
* Make tests buildable independently
This makes "tests" buildable as a separate project that uses
find_package(pybind11 CONFIG) when invoked independently.
This also moves the WERROR option into tests/CMakeLists.txt, as that's
the only place it is used.
* Use Eigen 3.3.1's cmake target, if available
This changes the eigen finding code to attempt to use Eigen's
system-installed Eigen3Config first. In Eigen 3.3.1, it exports a cmake
Eigen3::Eigen target to get dependencies from (rather than setting the
include path directly).
If it fails, we fall back to the trying to load allowing modules (i.e.
allowing our tools/FindEigen3.cmake). If we either fallback, or the
eigen version is older than 3.3.1 (or , we still set the include
directory manually; otherwise, for CONFIG + new Eigen, we get it via
the target.
This is also needed to allow 'tests' to be built independently, when
the find_package(Eigen3) is going to find via the system-installed
Eigen3Config.cmake.
* Add a install-then-build test, using clang on linux
This tests that `make install` to the actual system, followed by a build
of the tests (without the main pybind11 repository available) works as
expected.
To also expand the testing variety a bit, it also builds using
clang-3.9 instead of gcc.
* Don't try loading Eigen3Config in cmake < 3.0
It could FATAL_ERROR as the newer cmake includes a cmake 3.0 required
line.
If doing an independent, out-of-tree "tests" build, the regular
find_package(Eigen3) is likely to fail with the same error, but I think
we can just let that be: if you want a recent Eigen with proper cmake
loading support *and* want to do an independent tests build, you'll
need at least cmake 3.0.
2017-02-24 22:07:53 +00:00
|
|
|
add_dependencies(check test_cmake_build)
|