| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- # Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- # file LICENSE.rst or https://cmake.org/licensing for details.
- #[=======================================================================[.rst:
- FindCxxTest
- -----------
- Finds `CxxTest`_, a C++ unit testing framework suite, and provides a helper
- command to create test runners and integrate them with CTest:
- .. code-block:: cmake
- find_package(CxxTest [...])
- .. _`CxxTest`: https://github.com/CxxTest/cxxtest
- Result Variables
- ^^^^^^^^^^^^^^^^
- This module defines the following variables:
- ``CXXTEST_FOUND``
- Boolean indicating whether the CxxTest framework was found.
- ``CXXTEST_INCLUDE_DIRS``
- Include directories containing headers needed to use CxxTest.
- ``CXXTEST_TESTGEN_EXECUTABLE``
- The path to the found CxxTest test generator script (Perl- or Python-based),
- selected based on the found interpreter or user-specified preference.
- ``CXXTEST_TESTGEN_INTERPRETER``
- The path to the found Perl or Python interpreter used to run the test
- generator script, if needed (e.g., on platforms where script shebang lines are
- not supported).
- Cache Variables
- ^^^^^^^^^^^^^^^
- The following cache variables may also be set:
- ``CXXTEST_PERL_TESTGEN_EXECUTABLE``
- The path to the Perl-based CxxTest test generator script.
- ``CXXTEST_PYTHON_TESTGEN_EXECUTABLE``
- The path to the Python-based CxxTest test generator script.
- Hints
- ^^^^^
- This module accepts the following variables before calling
- ``find_package(CxxTest)``:
- ``CXXTEST_TESTGEN_ARGS``
- This variable can be set to specify a semicolon-separated list of command-line
- options to pass to the CxxTest code generator. If not set, the default value
- is ``--error-printer``.
- Commands
- ^^^^^^^^
- This module provides the following command if CxxTest is found:
- .. command:: cxxtest_add_test
- Creates a CxxTest runner and adds it to the CTest testing suite:
- .. code-block:: cmake
- cxxtest_add_test(<test-name> <gen-source-file> <input-files-to-testgen>...)
- Parameters:
- ``<test-name>``
- The name of the test executable target to be created and registered as a
- test in the CTest suite.
- ``<gen-source-file>``
- The name of the source file to be generated by the CxxTest code generator.
- This must be a relative path. It is interpreted relative to the
- current binary directory (:variable:`CMAKE_CURRENT_BINARY_DIR`).
- ``<input-files-to-testgen>``
- A list of header files containing test suite classes derived from the C++
- class ``CxxTest::TestSuite``, to be included in the test runner. These must
- be given as absolute paths.
- Deprecated Variables
- ^^^^^^^^^^^^^^^^^^^^
- The following variables are deprecated and provided for backward compatibility:
- ``CXXTEST_USE_PYTHON``
- .. deprecated:: 2.8.3
- In earlier versions of CMake, this hint variable was used to force the use
- of the Python-based test generator instead of the Perl one, regardless of
- which scripting language was installed. It is now only considered when both
- Perl and Python interpreters are found.
- A boolean hint variable that, when set to true, prefers the Python code
- generator over the Perl one if both interpreters are found. This variable is
- only relevant when using CxxTest version 3.
- Examples
- ^^^^^^^^
- The following example demonstrates how CxxTest can be used in CMake with this
- module. If CxxTest is found:
- * Additional interface :ref:`imported target <Imported Targets>` is created
- manually in the project to encapsulate the CxxTest usage requirements and
- link it to specified tests. Such target is useful, for example, when dealing
- with multiple tests.
- * Test generator is invoked to create ``foo_test.cc`` in the current binary
- directory from the input header ``foo_test.h`` located in the current source
- directory.
- * An executable named ``unit_test_foo`` is built and registered as a test in
- CTest.
- .. code-block:: cmake
- :caption: ``CMakeLists.txt``
- find_package(CxxTest)
- # Create interface imported target:
- if(CXXTEST_FOUND AND NOT TARGET CxxTest::CxxTest)
- add_library(CxxTest::CxxTest INTERFACE IMPORTED)
- set_target_properties(
- CxxTest::CxxTest
- PROPERTIES INTERFACE_INCLUDE_DIRECTORIES "${CXXTEST_INCLUDE_DIRS}"
- )
- endif()
- # Add test:
- if(CXXTEST_FOUND)
- enable_testing()
- cxxtest_add_test(
- unit_test_foo
- foo_test.cc
- ${CMAKE_CURRENT_SOURCE_DIR}/foo_test.h
- )
- target_link_libraries(
- unit_test_foo
- PRIVATE
- CxxTest::CxxTest
- # Link any project targets as needed, if test depends on them:
- foo
- )
- endif()
- .. code-block:: c++
- :caption: ``foo_test.h``
- #include <cxxtest/TestSuite.h>
- class MyTestSuite : public CxxTest::TestSuite
- {
- public:
- void testAddition(void)
- {
- TS_ASSERT(1 + 1 > 1);
- TS_ASSERT_EQUALS(1 + 1, 2);
- }
- };
- #]=======================================================================]
- # Version 1.4 (11/18/10) (CMake 2.8.4)
- # Issue 11384: Added support to the CXX_ADD_TEST macro so header
- # files (containing the tests themselves) show up in
- # Visual Studio and other IDEs.
- #
- # Version 1.3 (8/19/10) (CMake 2.8.3)
- # Included patch by Simone Rossetto to check if either Python or Perl
- # are present in the system. Whichever interpreter that is detected
- # is now used to run the test generator program. If both interpreters
- # are detected, the CXXTEST_USE_PYTHON variable is obeyed.
- #
- # Also added support for CXXTEST_TESTGEN_ARGS, for manually specifying
- # options to the CxxTest code generator.
- # Version 1.2 (3/2/08)
- # Included patch from Tyler Roscoe to have the perl & python binaries
- # detected based on CXXTEST_INCLUDE_DIR
- # Version 1.1 (2/9/08)
- # Clarified example to illustrate need to call target_link_libraries()
- # Changed commands to lowercase
- # Added licensing info
- # Version 1.0 (1/8/08)
- # Fixed CXXTEST_INCLUDE_DIRS so it will work properly
- # Eliminated superfluous CXXTEST_FOUND assignment
- # Cleaned up and added more documentation
- #=============================================================
- # cxxtest_add_test (public macro)
- #=============================================================
- macro(CXXTEST_ADD_TEST _cxxtest_testname _cxxtest_outfname)
- set(_cxxtest_real_outfname ${CMAKE_CURRENT_BINARY_DIR}/${_cxxtest_outfname})
- add_custom_command(
- OUTPUT ${_cxxtest_real_outfname}
- DEPENDS ${ARGN}
- COMMAND ${CXXTEST_TESTGEN_INTERPRETER}
- ${CXXTEST_TESTGEN_EXECUTABLE} ${CXXTEST_TESTGEN_ARGS} -o ${_cxxtest_real_outfname} ${ARGN}
- )
- set_source_files_properties(${_cxxtest_real_outfname} PROPERTIES GENERATED true)
- add_executable(${_cxxtest_testname} ${_cxxtest_real_outfname} ${ARGN})
- # There's no target used for these commands, so we don't need to do
- # anything here for CMP0178.
- if(CMAKE_RUNTIME_OUTPUT_DIRECTORY)
- add_test(${_cxxtest_testname} ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${_cxxtest_testname})
- elseif(EXECUTABLE_OUTPUT_PATH)
- add_test(${_cxxtest_testname} ${EXECUTABLE_OUTPUT_PATH}/${_cxxtest_testname})
- else()
- add_test(${_cxxtest_testname} ${CMAKE_CURRENT_BINARY_DIR}/${_cxxtest_testname})
- endif()
- endmacro()
- #=============================================================
- # main()
- #=============================================================
- if(NOT DEFINED CXXTEST_TESTGEN_ARGS)
- set(CXXTEST_TESTGEN_ARGS --error-printer)
- endif()
- find_package(Python QUIET)
- find_package(Perl QUIET)
- find_path(CXXTEST_INCLUDE_DIR cxxtest/TestSuite.h)
- find_program(CXXTEST_PYTHON_TESTGEN_EXECUTABLE
- NAMES cxxtestgen cxxtestgen.py
- PATHS ${CXXTEST_INCLUDE_DIR})
- find_program(CXXTEST_PERL_TESTGEN_EXECUTABLE cxxtestgen.pl
- PATHS ${CXXTEST_INCLUDE_DIR})
- if(PYTHON_FOUND OR Perl_FOUND)
- include(FindPackageHandleStandardArgs)
- if(PYTHON_FOUND AND (CXXTEST_USE_PYTHON OR NOT Perl_FOUND OR NOT DEFINED CXXTEST_USE_PYTHON))
- set(CXXTEST_TESTGEN_EXECUTABLE ${CXXTEST_PYTHON_TESTGEN_EXECUTABLE})
- execute_process(COMMAND ${CXXTEST_PYTHON_TESTGEN_EXECUTABLE} --version
- OUTPUT_VARIABLE _CXXTEST_OUT ERROR_VARIABLE _CXXTEST_OUT RESULT_VARIABLE _CXXTEST_RESULT)
- if(_CXXTEST_RESULT EQUAL 0)
- set(CXXTEST_TESTGEN_INTERPRETER "")
- else()
- set(CXXTEST_TESTGEN_INTERPRETER ${Python_EXECUTABLE})
- endif()
- find_package_handle_standard_args(CxxTest DEFAULT_MSG
- CXXTEST_INCLUDE_DIR CXXTEST_PYTHON_TESTGEN_EXECUTABLE)
- elseif(Perl_FOUND)
- set(CXXTEST_TESTGEN_EXECUTABLE ${CXXTEST_PERL_TESTGEN_EXECUTABLE})
- set(CXXTEST_TESTGEN_INTERPRETER ${PERL_EXECUTABLE})
- find_package_handle_standard_args(CxxTest DEFAULT_MSG
- CXXTEST_INCLUDE_DIR CXXTEST_PERL_TESTGEN_EXECUTABLE)
- endif()
- if(CXXTEST_FOUND)
- set(CXXTEST_INCLUDE_DIRS ${CXXTEST_INCLUDE_DIR})
- endif()
- else()
- set(CXXTEST_FOUND false)
- if(NOT CxxTest_FIND_QUIETLY)
- if(CxxTest_FIND_REQUIRED)
- message(FATAL_ERROR "Neither Python nor Perl found, cannot use CxxTest, aborting!")
- else()
- message(STATUS "Neither Python nor Perl found, CxxTest will not be used.")
- endif()
- endif()
- endif()
|