diff --git a/rosbag2_test_common/include/rosbag2_test_common/subscription_manager.hpp b/rosbag2_test_common/include/rosbag2_test_common/subscription_manager.hpp index f37fa75477..9fe9bc3a88 100644 --- a/rosbag2_test_common/include/rosbag2_test_common/subscription_manager.hpp +++ b/rosbag2_test_common/include/rosbag2_test_common/subscription_manager.hpp @@ -117,13 +117,15 @@ class SubscriptionManager return matched; } - std::future spin_subscriptions() + std::future spin_subscriptions(int maximum_time_spinning_sec = 10) { return async( - std::launch::async, [this]() { + std::launch::async, [this, maximum_time_spinning_sec]() { rclcpp::executors::SingleThreadedExecutor exec; auto start = std::chrono::high_resolution_clock::now(); - while (rclcpp::ok() && continue_spinning(expected_topics_with_size_, start)) { + while (rclcpp::ok() && + continue_spinning(expected_topics_with_size_, start, maximum_time_spinning_sec)) + { exec.spin_node_some(subscriber_node_); } }); @@ -132,10 +134,11 @@ class SubscriptionManager private: bool continue_spinning( const std::unordered_map & expected_topics_with_sizes, - std::chrono::time_point start_time) + std::chrono::time_point start_time, + int maximum_time_spinning_sec = 10) { auto current = std::chrono::high_resolution_clock::now(); - if (current - start_time > std::chrono::seconds(10)) { + if (current - start_time > std::chrono::seconds(maximum_time_spinning_sec)) { return false; } diff --git a/rosbag2_transport/test/rosbag2_transport/test_play_for.cpp b/rosbag2_transport/test/rosbag2_transport/test_play_for.cpp index fec27e8433..75c151754d 100644 --- a/rosbag2_transport/test/rosbag2_transport/test_play_for.cpp +++ b/rosbag2_transport/test/rosbag2_transport/test_play_for.cpp @@ -53,6 +53,8 @@ constexpr bool kBool1Value{false}; constexpr bool kBool2Value{true}; constexpr bool kBool3Value{false}; +constexpr int kMaximumTimeSpinningSec{1}; + #define EVAL_REPLAYED_PRIMITIVES(replayed_primitives) \ EXPECT_THAT( \ replayed_primitives, \ @@ -104,12 +106,12 @@ class RosBag2PlayForTestFixture : public RosBag2PlayTestFixture // around without any knowledge about message chronology. It just picks // the next one Make sure to keep the list in order or sort it! std::vector> messages = - {serialize_test_message(kTopic1Name, 500, primitive_message1), - serialize_test_message(kTopic2Name, 550, complex_message1), - serialize_test_message(kTopic1Name, 700, primitive_message1), - serialize_test_message(kTopic2Name, 750, complex_message1), - serialize_test_message(kTopic1Name, 900, primitive_message1), - serialize_test_message(kTopic2Name, 950, complex_message1)}; + {serialize_test_message(kTopic1Name, 100, primitive_message1), + serialize_test_message(kTopic2Name, 120, complex_message1), + serialize_test_message(kTopic1Name, 200, primitive_message1), + serialize_test_message(kTopic2Name, 220, complex_message1), + serialize_test_message(kTopic1Name, 300, primitive_message1), + serialize_test_message(kTopic2Name, 320, complex_message1)}; // @} return messages; } @@ -128,11 +130,12 @@ class RosBag2PlayForTestFixture : public RosBag2PlayTestFixture play_options_.playback_duration = rclcpp::Duration(std::chrono::milliseconds(milliseconds)); player_ = std::make_shared(std::move(reader), storage_options_, play_options_); + // Wait for discovery to match publishers with subscribers ASSERT_TRUE( sub_->spin_and_wait_for_matched(player_->get_list_of_publishers(), std::chrono::seconds(5))); - auto await_received_messages = sub_->spin_subscriptions(); + auto await_received_messages = sub_->spin_subscriptions(kMaximumTimeSpinningSec); ASSERT_TRUE(player_->play()); @@ -145,7 +148,7 @@ class RosBag2PlayForTestFixture : public RosBag2PlayTestFixture TEST_F(RosBag2PlayForTestFixture, play_for_all_are_played_due_to_duration) { - InitPlayerWithPlaybackDurationAndPlay(1000); + InitPlayerWithPlaybackDurationAndPlay(350); auto replayed_test_primitives = sub_->get_received_messages( kTopic1); @@ -161,7 +164,7 @@ TEST_F(RosBag2PlayForTestFixture, play_for_all_are_played_due_to_duration) TEST_F(RosBag2PlayForTestFixture, play_for_none_are_played_due_to_duration) { - InitPlayerWithPlaybackDurationAndPlay(300); + InitPlayerWithPlaybackDurationAndPlay(50); auto replayed_test_primitives = sub_->get_received_messages( kTopic1); @@ -174,7 +177,7 @@ TEST_F(RosBag2PlayForTestFixture, play_for_none_are_played_due_to_duration) TEST_F(RosBag2PlayForTestFixture, play_for_less_than_the_total_duration) { - InitPlayerWithPlaybackDurationAndPlay(800); + InitPlayerWithPlaybackDurationAndPlay(270); auto replayed_test_primitives = sub_->get_received_messages( kTopic1); @@ -202,7 +205,7 @@ TEST_F( RosBag2PlayForFilteredTopicTestFixture, play_for_full_duration_recorded_messages_with_filtered_topics) { - InitPlayerWithPlaybackDurationAndPlay(1000); + InitPlayerWithPlaybackDurationAndPlay(400); auto replayed_test_primitives = sub_->get_received_messages("/topic1"); @@ -220,7 +223,7 @@ TEST_F( RosBag2PlayForFilteredTopicTestFixture, play_for_short_duration_recorded_messages_with_filtered_topics) { - InitPlayerWithPlaybackDurationAndPlay(300); + InitPlayerWithPlaybackDurationAndPlay(50); auto replayed_test_primitives = sub_->get_received_messages("/topic1"); @@ -236,7 +239,7 @@ TEST_F( RosBag2PlayForFilteredTopicTestFixture, play_for_intermediate_duration_recorded_messages_with_filtered_topics) { - InitPlayerWithPlaybackDurationAndPlay(800); + InitPlayerWithPlaybackDurationAndPlay(270); auto replayed_test_primitives = sub_->get_received_messages("/topic1"); @@ -301,7 +304,7 @@ TEST_F( ASSERT_TRUE( sub_->spin_and_wait_for_matched(player_->get_list_of_publishers(), std::chrono::seconds(5))); - auto await_received_messages = sub_->spin_subscriptions(); + auto await_received_messages = sub_->spin_subscriptions(kMaximumTimeSpinningSec); player_->pause(); auto player_future = std::async(std::launch::async, [player_]() {return player_->play();}); player_->wait_for_playback_to_start();