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()
|
|
|
|
|
|
|
|
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
|
|
|
|
test_callbacks.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
|
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_keep_alive.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-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)
|
|
|
|
find_package(Eigen3 QUIET)
|
|
|
|
|
|
|
|
if(EIGEN3_FOUND)
|
|
|
|
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()
|
|
|
|
|
|
|
|
# Create the binding library
|
|
|
|
pybind11_add_module(pybind11_tests pybind11_tests.cpp ${PYBIND11_TEST_FILES})
|
|
|
|
pybind11_enable_warnings(pybind11_tests)
|
|
|
|
|
|
|
|
if(EIGEN3_FOUND)
|
|
|
|
target_include_directories(pybind11_tests PRIVATE ${EIGEN3_INCLUDE_DIR})
|
|
|
|
target_compile_definitions(pybind11_tests PRIVATE -DPYBIND11_TEST_EIGEN)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(testdir ${PROJECT_SOURCE_DIR}/tests)
|
|
|
|
|
|
|
|
# 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
|
|
|
macro(pybind11_execute_python)
|
|
|
|
execute_process(COMMAND ${PYTHON_EXECUTABLE} -m ${ARGN} OUTPUT_QUIET ERROR_QUIET
|
|
|
|
RESULT_VARIABLE pybind11_execute_python_error)
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
if(NOT PYBIND11_PYTEST_FOUND)
|
|
|
|
pybind11_execute_python(pytest --version --noconftest)
|
|
|
|
if(pybind11_execute_python_error)
|
2016-08-26 21:11:40 +00:00
|
|
|
message(FATAL_ERROR "Running the tests requires pytest. Please install it manually (try: ${PYTHON_EXECUTABLE} -m pip install pytest)")
|
2016-08-13 00:44:56 +00:00
|
|
|
endif()
|
|
|
|
|
|
|
|
set(PYBIND11_PYTEST_FOUND TRUE CACHE INTERAL "")
|
|
|
|
endif()
|
|
|
|
|
2016-08-12 11:50:00 +00:00
|
|
|
# A single command to compile and run the tests
|
2016-09-03 18:54:22 +00:00
|
|
|
add_custom_target(pytest COMMAND ${PYTHON_EXECUTABLE} -m pytest -rws ${PYBIND11_PYTEST_FILES}
|
2016-08-12 11:50:00 +00:00
|
|
|
DEPENDS pybind11_tests WORKING_DIRECTORY ${testdir})
|