diff options
-rw-r--r-- | host/CMakeLists.txt | 82 | ||||
-rw-r--r-- | host/cmake/Modules/UHDUnitTest.cmake | 24 |
2 files changed, 71 insertions, 35 deletions
diff --git a/host/CMakeLists.txt b/host/CMakeLists.txt index 0cee8582f..23056f90a 100644 --- a/host/CMakeLists.txt +++ b/host/CMakeLists.txt @@ -276,35 +276,6 @@ if(WIN32) endif(WIN32) ######################################################################## -# Option to use QEMU for running unittests -# -# This is useful when cross-compiling UHD for other architectures like arm or -# aarch64 -# -# QEMU_EXECUTABLE must be set to the name of the QEMU executable. When using -# openembedded build environment, this should be set to "qemu-${TUNE_ARCH}" -# or "${WORKDIR}/recipe-sysroot-native/usr/bin/qemu-${TUNE_ARCH}" -# -# QEMU_SYSROOT must be set to the same sysroot of the target architecture that -# was used when compiling UHD. When using openembedded build environment, this -# should be set to "${WORKDIR}/recipe-sysroot" -######################################################################## -option(ENABLE_QEMU_UNITTESTS "Use QEMU for running unittests" OFF) -mark_as_advanced(ENABLE_QEMU_UNITTESTS) -if(ENABLE_QEMU_UNITTESTS) - message(STATUS "") - message(STATUS "Use QEMU for running unittests: ${ENABLE_QEMU_UNITTESTS}") - if("${QEMU_EXECUTABLE}" STREQUAL "") - message(FATAL_ERROR "The variable QEMU_EXECUTABLE is not set") - endif() - if("${QEMU_SYSROOT}" STREQUAL "") - message(FATAL_ERROR "The variable QEMU_SYSROOT is not set") - endif() - message(STATUS " QEMU executable: ${QEMU_EXECUTABLE}") - message(STATUS " QEMU sysroot: ${QEMU_SYSROOT}") -endif(ENABLE_QEMU_UNITTESTS) - -######################################################################## # Setup Boost ######################################################################## message(STATUS "") @@ -369,6 +340,59 @@ PYTHON_CHECK_MODULE( ) ######################################################################## +# Option to use QEMU for running unittests +# +# This is useful when cross-compiling UHD for other architectures like arm or +# aarch64 +# +# QEMU_EXECUTABLE must be set to the name of the QEMU executable. When using +# openembedded build environment, this should be set to "qemu-${TUNE_ARCH}" +# or "${WORKDIR}/recipe-sysroot-native/usr/bin/qemu-${TUNE_ARCH}" +# +# QEMU_SYSROOT must be set to the same sysroot of the target architecture that +# was used when compiling UHD. When using openembedded build environment, this +# should be set to "${WORKDIR}/recipe-sysroot". +# +# QEMU_PYTHON_EXECUTABLE must be set to the path of the python executable +# compiled for the target architecture. If it is included in the target sysroot, +# this is typically ${QEMU_SYSROOT}${PYTHON_RUNTIME_EXECUTABLE}. The variable +# is automatically set to this path if the executable is available. +######################################################################## +option(ENABLE_QEMU_UNITTESTS "Use QEMU for running unittests" OFF) +mark_as_advanced(ENABLE_QEMU_UNITTESTS) +if(ENABLE_QEMU_UNITTESTS) + message(STATUS "") + message(STATUS "Use QEMU for running unittests: ${ENABLE_QEMU_UNITTESTS}") + if("${QEMU_EXECUTABLE}" STREQUAL "") + if(NOT "$ENV{OECORE_NATIVE_SYSROOT}" STREQUAL "" AND + NOT "$ENV{OECORE_TARGET_ARCH}" STREQUAL "" AND + EXISTS "$ENV{OECORE_NATIVE_SYSROOT}/usr/bin/qemu-$ENV{OECORE_TARGET_ARCH}") + set(QEMU_EXECUTABLE "$ENV{OECORE_NATIVE_SYSROOT}/usr/bin/qemu-$ENV{OECORE_TARGET_ARCH}") + else() + message(FATAL_ERROR "The variable QEMU_EXECUTABLE is not set") + endif() + endif() + if("${QEMU_SYSROOT}" STREQUAL "") + if(NOT "$ENV{OECORE_TARGET_SYSROOT}" STREQUAL "" AND + EXISTS "$ENV{OECORE_TARGET_SYSROOT}") + set(QEMU_SYSROOT, "$ENV{OECORE_TARGET_SYSROOT}") + else() + message(FATAL_ERROR "The variable QEMU_SYSROOT is not set") + endif() + endif() + if("${QEMU_PYTHON_EXECUTABLE}" STREQUAL "") + if (EXISTS ${QEMU_SYSROOT}${RUNTIME_PYTHON_EXECUTABLE}) + set(QEMU_PYTHON_EXECUTABLE ${QEMU_SYSROOT}${RUNTIME_PYTHON_EXECUTABLE}) + else() + message(FATAL_ERROR "The variable QEMU_PYTHON_EXECUTABLE is not set") + endif() + endif() + message(STATUS " QEMU executable: ${QEMU_EXECUTABLE}") + message(STATUS " QEMU Python executable: ${QEMU_PYTHON_EXECUTABLE}") + message(STATUS " QEMU sysroot: ${QEMU_SYSROOT}") +endif(ENABLE_QEMU_UNITTESTS) + +######################################################################## # Create Uninstall Target ######################################################################## configure_file( diff --git a/host/cmake/Modules/UHDUnitTest.cmake b/host/cmake/Modules/UHDUnitTest.cmake index 76dfdd029..340279b9b 100644 --- a/host/cmake/Modules/UHDUnitTest.cmake +++ b/host/cmake/Modules/UHDUnitTest.cmake @@ -112,12 +112,24 @@ endfunction(UHD_ADD_TEST) # Add a Python unit test ######################################################################## function(UHD_ADD_PYTEST test_name) - add_test(NAME ${test_name} - COMMAND ${RUNTIME_PYTHON_EXECUTABLE} -m unittest discover - -s ${CMAKE_CURRENT_SOURCE_DIR} - -p "${test_name}.*" - WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/python" - ) + if(ENABLE_QEMU_UNITTESTS) + # use QEMU emulator for executing test + add_test(NAME ${test_name} + COMMAND ${QEMU_EXECUTABLE} -L ${QEMU_SYSROOT} + ${QEMU_PYTHON_EXECUTABLE} + -m unittest discover + -s ${CMAKE_CURRENT_SOURCE_DIR} + -p "${test_name}.*" + WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/python" + ) + else() + add_test(NAME ${test_name} + COMMAND ${RUNTIME_PYTHON_EXECUTABLE} -m unittest discover + -s ${CMAKE_CURRENT_SOURCE_DIR} + -p "${test_name}.*" + WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/python" + ) + endif(ENABLE_QEMU_UNITTESTS) set_tests_properties(${test_name} PROPERTIES ENVIRONMENT PYTHONPATH=${CMAKE_SOURCE_DIR}/tests/common) endfunction(UHD_ADD_PYTEST) |