From 9c4ee99ca7f9b157ccbead463596b00cc93c30e0 Mon Sep 17 00:00:00 2001 From: Stefan Fabian Date: Tue, 3 Dec 2024 11:13:05 +0100 Subject: [PATCH] Fixes service server segfaulting (#10) and adds a new test to cover this. --- ros_babel_fish/CMakeLists.txt | 6 ++-- .../detail/babel_fish_service.hpp | 3 +- .../src/detail/babel_fish_service.cpp | 3 +- .../test/{service_client.cpp => service.cpp} | 29 +++++++++++++------ 4 files changed, 26 insertions(+), 15 deletions(-) rename ros_babel_fish/test/{service_client.cpp => service.cpp} (65%) diff --git a/ros_babel_fish/CMakeLists.txt b/ros_babel_fish/CMakeLists.txt index 2e2ef88..7067279 100644 --- a/ros_babel_fish/CMakeLists.txt +++ b/ros_babel_fish/CMakeLists.txt @@ -155,9 +155,9 @@ if (BUILD_TESTING) ament_target_dependencies(test_message_encoding geometry_msgs ros_babel_fish_test_msgs) target_link_libraries(test_message_encoding ${PROJECT_NAME}) - ament_add_gtest(test_service_client test/service_client.cpp) - ament_target_dependencies(test_service_client example_interfaces ros_babel_fish_test_msgs) - target_link_libraries(test_service_client ${PROJECT_NAME}) + ament_add_gtest(test_service test/service.cpp) + ament_target_dependencies(test_service example_interfaces ros_babel_fish_test_msgs) + target_link_libraries(test_service ${PROJECT_NAME}) ament_add_gtest(test_action_client test/action_client.cpp) ament_target_dependencies(test_action_client action_tutorials_interfaces example_interfaces ros_babel_fish_test_msgs) diff --git a/ros_babel_fish/include/ros_babel_fish/detail/babel_fish_service.hpp b/ros_babel_fish/include/ros_babel_fish/detail/babel_fish_service.hpp index 24772f0..6d267ab 100644 --- a/ros_babel_fish/include/ros_babel_fish/detail/babel_fish_service.hpp +++ b/ros_babel_fish/include/ros_babel_fish/detail/babel_fish_service.hpp @@ -19,7 +19,8 @@ struct BabelFishService { }; } // namespace impl -class BabelFishService : public rclcpp::ServiceBase, std::enable_shared_from_this +class BabelFishService : public rclcpp::ServiceBase, + public std::enable_shared_from_this { public: RCLCPP_SMART_PTR_DEFINITIONS( BabelFishService ) diff --git a/ros_babel_fish/src/detail/babel_fish_service.cpp b/ros_babel_fish/src/detail/babel_fish_service.cpp index f95d7be..232aa19 100644 --- a/ros_babel_fish/src/detail/babel_fish_service.cpp +++ b/ros_babel_fish/src/detail/babel_fish_service.cpp @@ -5,7 +5,6 @@ #include "ros_babel_fish/idl/serialization.hpp" #include -#include namespace ros_babel_fish { @@ -76,7 +75,7 @@ std::shared_ptr BabelFishService::create_request() std::shared_ptr BabelFishService::create_request_header() { - return std::shared_ptr(); + return std::make_shared(); } void BabelFishService::handle_request( std::shared_ptr request_header, diff --git a/ros_babel_fish/test/service_client.cpp b/ros_babel_fish/test/service.cpp similarity index 65% rename from ros_babel_fish/test/service_client.cpp rename to ros_babel_fish/test/service.cpp index 00b33fc..ac3f021 100644 --- a/ros_babel_fish/test/service_client.cpp +++ b/ros_babel_fish/test/service.cpp @@ -33,7 +33,7 @@ TEST( ServiceClientTest, tests ) ( *req )["a"] = 512; ( *req )["b"] = 314; BabelFishServiceClient::SharedPtr client = fish.create_service_client( - *node, "/test_service_client/two_ints", "example_interfaces/srv/AddTwoInts" ); + *node, "/test_service_client/two_ints_client", "example_interfaces/srv/AddTwoInts" ); ASSERT_TRUE( client->wait_for_service( 5s ) ); std::shared_future response_future = client->async_send_request( req ); ASSERT_EQ( response_future.wait_for( 5s ), std::future_status::ready ); @@ -45,13 +45,24 @@ TEST( ServiceClientTest, tests ) TEST( ServiceTest, server ) { - // ros::service::waitForService( "/test_service_server/subscribers" ); - // rosapi::Subscribers subscribers; - // subscribers.request_template.topic = "First test"; - // EXPECT_TRUE( ros::service::call( "/test_service_server/subscribers", subscribers )); - // ASSERT_EQ( subscribers.response.subscribers.size(), 2UL ); - // EXPECT_EQ( subscribers.response.subscribers[0], "First test" ); - // EXPECT_EQ( subscribers.response.subscribers[1], "The answer to everything is:" ); + BabelFish fish; + auto server = fish.create_service( + *node, "/test_service_server/two_ints_server", "example_interfaces/srv/AddTwoInts", + []( CompoundMessage::SharedPtr req, CompoundMessage::SharedPtr resp ) { + resp->set( "sum", req->get( "a" ) + req->get( "b" ) + 1337 ); + return true; + } ); + auto req2 = std::make_shared(); + req2->a = 512; + req2->b = 314; + auto client = node->create_client( + "test_service_server/two_ints_server" ); + ASSERT_TRUE( client->wait_for_service( 5s ) ); + auto response = client->async_send_request( req2 ); + ASSERT_TRUE( response.wait_for( 5s ) == std::future_status::ready ); + auto result = response.get(); + ASSERT_NE( result, nullptr ); + EXPECT_EQ( result->sum, 512 + 314 + 1337 ); } int main( int argc, char **argv ) @@ -61,7 +72,7 @@ int main( int argc, char **argv ) node = std::make_shared( "service_client_test" ); std::thread spinner( []() { rclcpp::spin( node ); } ); auto service_two_ints = node->create_service( - "/test_service_client/two_ints", &twoIntServiceCallback ); + "/test_service_client/two_ints_client", &twoIntServiceCallback ); int result = RUN_ALL_TESTS(); rclcpp::shutdown(); spinner.join();