Merge branch '23-make-users-of-tracetools-automatically-use-rdynamic' into 'master'
Export "-rdynamic" link flag for downstream packages Closes #23 See merge request micro-ROS/ros_tracing/ros2_tracing!156
This commit is contained in:
commit
31f63d2f27
5 changed files with 21 additions and 35 deletions
|
@ -20,6 +20,7 @@ else()
|
||||||
set(DISABLED_DEFAULT OFF)
|
set(DISABLED_DEFAULT OFF)
|
||||||
endif()
|
endif()
|
||||||
option(TRACETOOLS_DISABLED "Explicitly disable support for tracing" ${DISABLED_DEFAULT})
|
option(TRACETOOLS_DISABLED "Explicitly disable support for tracing" ${DISABLED_DEFAULT})
|
||||||
|
option(TRACETOOLS_NO_RDYNAMIC "Disable export of -rdynamic link flag" OFF)
|
||||||
|
|
||||||
if(NOT TRACETOOLS_DISABLED)
|
if(NOT TRACETOOLS_DISABLED)
|
||||||
# Set TRACETOOLS_LTTNG_ENABLED if we can find lttng-ust
|
# Set TRACETOOLS_LTTNG_ENABLED if we can find lttng-ust
|
||||||
|
@ -112,24 +113,23 @@ install(
|
||||||
ament_export_include_directories(include)
|
ament_export_include_directories(include)
|
||||||
if(TRACETOOLS_LTTNG_ENABLED)
|
if(TRACETOOLS_LTTNG_ENABLED)
|
||||||
ament_export_libraries(${PROJECT_NAME} ${LTTNG_LIBRARIES})
|
ament_export_libraries(${PROJECT_NAME} ${LTTNG_LIBRARIES})
|
||||||
|
# Export -rdynamic for downtream packages to use when calling
|
||||||
|
# ament_target_dependencies()
|
||||||
|
# which is needed to resolve function addresses to symbols when
|
||||||
|
# using function pointers directly/without std::bind()
|
||||||
|
# (the flag should not be used on Windows, but TRACETOOLS_LTTNG_ENABLED
|
||||||
|
# should never be true on Windows anyway, so there is no need to check)
|
||||||
|
if(NOT TRACETOOLS_NO_RDYNAMIC)
|
||||||
|
ament_export_link_flags("-rdynamic")
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
ament_export_libraries(${PROJECT_NAME})
|
ament_export_libraries(${PROJECT_NAME})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(BUILD_TESTING)
|
if(BUILD_TESTING)
|
||||||
set(ament_cmake_cppcheck_ADDITIONAL_INCLUDE_DIRS ${LTTNG_INCLUDE_DIRS})
|
set(ament_cmake_cppcheck_ADDITIONAL_INCLUDE_DIRS ${LTTNG_INCLUDE_DIRS})
|
||||||
|
|
||||||
find_package(ament_cmake_gtest REQUIRED)
|
|
||||||
find_package(ament_lint_auto REQUIRED)
|
find_package(ament_lint_auto REQUIRED)
|
||||||
ament_lint_auto_find_test_dependencies()
|
ament_lint_auto_find_test_dependencies()
|
||||||
|
|
||||||
# Only build tracetools utils tests if LTTng is enabled and found
|
|
||||||
if(TRACETOOLS_LTTNG_ENABLED)
|
|
||||||
ament_add_gtest(test_utils test/test_utils.cpp)
|
|
||||||
if(TARGET test_utils)
|
|
||||||
target_link_libraries(test_utils ${PROJECT_NAME} -rdynamic)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
ament_package()
|
ament_package()
|
||||||
|
|
|
@ -13,7 +13,6 @@
|
||||||
<buildtool_depend>ament_cmake_ros</buildtool_depend>
|
<buildtool_depend>ament_cmake_ros</buildtool_depend>
|
||||||
<buildtool_depend>pkg-config</buildtool_depend>
|
<buildtool_depend>pkg-config</buildtool_depend>
|
||||||
|
|
||||||
<test_depend>ament_cmake_gtest</test_depend>
|
|
||||||
<test_depend>ament_lint_auto</test_depend>
|
<test_depend>ament_lint_auto</test_depend>
|
||||||
<test_depend>ament_lint_common</test_depend>
|
<test_depend>ament_lint_common</test_depend>
|
||||||
|
|
||||||
|
|
|
@ -26,17 +26,10 @@ endif()
|
||||||
|
|
||||||
# Tests
|
# Tests
|
||||||
if(BUILD_TESTING)
|
if(BUILD_TESTING)
|
||||||
|
# tracetools is exported by rclcpp
|
||||||
find_package(rclcpp REQUIRED)
|
find_package(rclcpp REQUIRED)
|
||||||
find_package(std_msgs REQUIRED)
|
find_package(std_msgs REQUIRED)
|
||||||
find_package(std_srvs REQUIRED)
|
find_package(std_srvs REQUIRED)
|
||||||
find_package(tracetools REQUIRED)
|
|
||||||
|
|
||||||
# Avoid using -rdynamic on Windows
|
|
||||||
if(NOT WIN32)
|
|
||||||
set(RDYNAMIC_FLAG "-rdynamic")
|
|
||||||
else()
|
|
||||||
set(RDYNAMIC_FLAG "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_executable(test_publisher
|
add_executable(test_publisher
|
||||||
src/test_publisher.cpp
|
src/test_publisher.cpp
|
||||||
|
@ -44,62 +37,48 @@ if(BUILD_TESTING)
|
||||||
ament_target_dependencies(test_publisher
|
ament_target_dependencies(test_publisher
|
||||||
rclcpp
|
rclcpp
|
||||||
std_msgs
|
std_msgs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_publisher "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_intra
|
add_executable(test_intra
|
||||||
src/test_intra.cpp
|
src/test_intra.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_intra
|
ament_target_dependencies(test_intra
|
||||||
rclcpp
|
rclcpp
|
||||||
std_msgs
|
std_msgs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_intra "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_ping
|
add_executable(test_ping
|
||||||
src/test_ping.cpp
|
src/test_ping.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_ping
|
ament_target_dependencies(test_ping
|
||||||
rclcpp
|
rclcpp
|
||||||
std_msgs
|
std_msgs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_ping "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_pong
|
add_executable(test_pong
|
||||||
src/test_pong.cpp
|
src/test_pong.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_pong
|
ament_target_dependencies(test_pong
|
||||||
rclcpp
|
rclcpp
|
||||||
std_msgs
|
std_msgs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_pong "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_timer
|
add_executable(test_timer
|
||||||
src/test_timer.cpp
|
src/test_timer.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_timer
|
ament_target_dependencies(test_timer
|
||||||
rclcpp
|
rclcpp
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_timer "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_service_ping
|
add_executable(test_service_ping
|
||||||
src/test_service_ping.cpp
|
src/test_service_ping.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_service_ping
|
ament_target_dependencies(test_service_ping
|
||||||
rclcpp
|
rclcpp
|
||||||
std_srvs
|
std_srvs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_service_ping "${RDYNAMIC_FLAG}")
|
|
||||||
add_executable(test_service_pong
|
add_executable(test_service_pong
|
||||||
src/test_service_pong.cpp
|
src/test_service_pong.cpp
|
||||||
)
|
)
|
||||||
ament_target_dependencies(test_service_pong
|
ament_target_dependencies(test_service_pong
|
||||||
rclcpp
|
rclcpp
|
||||||
std_srvs
|
std_srvs
|
||||||
tracetools
|
|
||||||
)
|
)
|
||||||
target_link_libraries(test_service_pong "${RDYNAMIC_FLAG}")
|
|
||||||
|
|
||||||
install(TARGETS
|
install(TARGETS
|
||||||
test_intra
|
test_intra
|
||||||
|
@ -117,8 +96,16 @@ if(BUILD_TESTING)
|
||||||
|
|
||||||
# Only build tracing tests if LTTng is enabled and found
|
# Only build tracing tests if LTTng is enabled and found
|
||||||
if(TRACING_ENABLED)
|
if(TRACING_ENABLED)
|
||||||
find_package(ament_cmake_pytest REQUIRED)
|
find_package(tracetools REQUIRED)
|
||||||
|
find_package(ament_cmake_gtest REQUIRED)
|
||||||
|
ament_add_gtest(test_utils test/test_utils.cpp)
|
||||||
|
if(TARGET test_utils)
|
||||||
|
ament_target_dependencies(test_utils
|
||||||
|
tracetools
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
find_package(ament_cmake_pytest REQUIRED)
|
||||||
# Run each test in its own pytest invocation
|
# Run each test in its own pytest invocation
|
||||||
set(_tracetools_test_pytest_tests
|
set(_tracetools_test_pytest_tests
|
||||||
test/test_intra.py
|
test/test_intra.py
|
||||||
|
@ -128,7 +115,6 @@ if(BUILD_TESTING)
|
||||||
test/test_subscription.py
|
test/test_subscription.py
|
||||||
test/test_timer.py
|
test/test_timer.py
|
||||||
)
|
)
|
||||||
|
|
||||||
foreach(_test_path ${_tracetools_test_pytest_tests})
|
foreach(_test_path ${_tracetools_test_pytest_tests})
|
||||||
get_filename_component(_test_name ${_test_path} NAME_WE)
|
get_filename_component(_test_name ${_test_path} NAME_WE)
|
||||||
ament_add_pytest_test(${_test_name} ${_test_path}
|
ament_add_pytest_test(${_test_name} ${_test_path}
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
<exec_depend>std_msgs</exec_depend>
|
<exec_depend>std_msgs</exec_depend>
|
||||||
<exec_depend>std_srvs</exec_depend>
|
<exec_depend>std_srvs</exec_depend>
|
||||||
|
|
||||||
|
<test_depend>ament_cmake_gtest</test_depend>
|
||||||
<test_depend>ament_cmake_mypy</test_depend>
|
<test_depend>ament_cmake_mypy</test_depend>
|
||||||
<test_depend>ament_cmake_pytest</test_depend>
|
<test_depend>ament_cmake_pytest</test_depend>
|
||||||
<test_depend>ament_lint_auto</test_depend>
|
<test_depend>ament_lint_auto</test_depend>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue