Skip to content
Merged
3 changes: 3 additions & 0 deletions rcl/src/rcl/subscription.c
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,7 @@ rcl_take(
// If message_info is NULL, use a place holder which can be discarded.
rmw_message_info_t dummy_message_info;
rmw_message_info_t * message_info_local = message_info ? message_info : &dummy_message_info;
*message_info_local = rmw_get_zero_initialized_message_info();
// Call rmw_take_with_info.
bool taken = false;
rmw_ret_t ret = rmw_take_with_info(
Expand Down Expand Up @@ -298,6 +299,7 @@ rcl_take_serialized_message(
// If message_info is NULL, use a place holder which can be discarded.
rmw_message_info_t dummy_message_info;
rmw_message_info_t * message_info_local = message_info ? message_info : &dummy_message_info;
*message_info_local = rmw_get_zero_initialized_message_info();
// Call rmw_take_with_info.
bool taken = false;
rmw_ret_t ret = rmw_take_serialized_message_with_info(
Expand Down Expand Up @@ -335,6 +337,7 @@ rcl_take_loaned_message(
// If message_info is NULL, use a place holder which can be discarded.
rmw_message_info_t dummy_message_info;
rmw_message_info_t * message_info_local = message_info ? message_info : &dummy_message_info;
*message_info_local = rmw_get_zero_initialized_message_info();
// Call rmw_take_with_info.
bool taken = false;
rmw_ret_t ret = rmw_take_loaned_message_with_info(
Expand Down
6 changes: 6 additions & 0 deletions rcl/test/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,12 @@ function(test_target_function)
LIBRARIES ${PROJECT_NAME}
AMENT_DEPENDENCIES ${rmw_implementation} "osrf_testing_tools_cpp" "test_msgs"
)
if(rmw_implementation STREQUAL "rmw_fastrtps_cpp")
message(STATUS "Enabling message timestamp test for ${rmw_implementation}")
target_compile_definitions(test_subscription${target_suffix} PUBLIC "RMW_TIMESTAMPS_SUPPORTED=1")
else()
message(STATUS "Disabling message timestamp test for ${rmw_implementation}")
endif()

rcl_add_custom_gtest(test_events${target_suffix}
SRCS rcl/test_events.cpp
Expand Down
24 changes: 23 additions & 1 deletion rcl/test/rcl/test_subscription.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,8 @@ TEST_F(CLASSNAME(TestSubscriptionFixture, RMW_IMPLEMENTATION), test_subscription
// probably using the count_subscriptions busy wait mechanism
// until then we will sleep for a short period of time
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
timespec pre_publish_time;
EXPECT_EQ(0, clock_gettime(CLOCK_REALTIME, &pre_publish_time)) << " clock_gettime failed";
{
test_msgs__msg__BasicTypes msg;
test_msgs__msg__BasicTypes__init(&msg);
Expand All @@ -197,9 +199,29 @@ TEST_F(CLASSNAME(TestSubscriptionFixture, RMW_IMPLEMENTATION), test_subscription
{
test_msgs__msg__BasicTypes__fini(&msg);
});
ret = rcl_take(&subscription, &msg, nullptr, nullptr);
rmw_message_info_t message_info = rmw_get_zero_initialized_message_info();
ret = rcl_take(&subscription, &msg, &message_info, nullptr);
ASSERT_EQ(RCL_RET_OK, ret) << rcl_get_error_string().str;
ASSERT_EQ(42, msg.int64_value);
#ifdef RMW_TIMESTAMPS_SUPPORTED
EXPECT_NE(0u, message_info.source_timestamp.sec);
EXPECT_TRUE(pre_publish_time.tv_sec <= (time_t)message_info.source_timestamp.sec) <<
pre_publish_time.tv_sec << " > " << (time_t)message_info.source_timestamp.sec;
EXPECT_NE(0u, message_info.source_timestamp.nsec);
EXPECT_TRUE(pre_publish_time.tv_nsec <= (long)message_info.source_timestamp.nsec) <<
pre_publish_time.tv_nsec << " > " << (time_t)message_info.source_timestamp.nsec;
EXPECT_NE(0u, message_info.received_timestamp.sec);
EXPECT_TRUE(pre_publish_time.tv_sec <= (time_t)message_info.received_timestamp.sec);
EXPECT_TRUE(message_info.source_timestamp.sec <= message_info.received_timestamp.sec);
EXPECT_NE(0u, message_info.received_timestamp.nsec);
EXPECT_TRUE(pre_publish_time.tv_nsec <= (long)message_info.received_timestamp.nsec);
EXPECT_TRUE(message_info.source_timestamp.nsec <= message_info.received_timestamp.nsec);
#else
EXPECT_EQ(0u, message_info.source_timestamp.sec);
EXPECT_EQ(0u, message_info.source_timestamp.nsec);
EXPECT_EQ(0u, message_info.received_timestamp.sec);
EXPECT_EQ(0u, message_info.received_timestamp.nsec);
#endif
}
}

Expand Down