From e791195b1bc7cfa5c77509ef5c2e344c87886750 Mon Sep 17 00:00:00 2001 From: Tomas Baca Date: Sun, 28 Apr 2024 10:12:17 +0200 Subject: [PATCH] updated tests, added print for setting the reference --- src/control_manager/control_manager.cpp | 4 + test/control_manager/CMakeLists.txt | 4 + .../CMakeLists.txt | 16 +++ .../config/mrs_simulator.yaml | 10 ++ .../set_heading_relative_service.test | 36 +++++++ .../set_heading_relative_service/test.cpp | 92 ++++++++++++++++ .../set_heading_service/CMakeLists.txt | 16 +++ .../set_heading_service.test | 35 ++++++ .../set_heading_service/test.cpp | 101 ++++++++++++++++++ 9 files changed, 314 insertions(+) create mode 100644 test/control_manager/set_heading_relative_service/CMakeLists.txt create mode 100644 test/control_manager/set_heading_relative_service/config/mrs_simulator.yaml create mode 100644 test/control_manager/set_heading_relative_service/set_heading_relative_service.test create mode 100644 test/control_manager/set_heading_relative_service/test.cpp create mode 100644 test/control_manager/set_heading_service/CMakeLists.txt create mode 100644 test/control_manager/set_heading_service/set_heading_service.test create mode 100644 test/control_manager/set_heading_service/test.cpp diff --git a/src/control_manager/control_manager.cpp b/src/control_manager/control_manager.cpp index 1d71dfd..9486764 100644 --- a/src/control_manager/control_manager.cpp +++ b/src/control_manager/control_manager.cpp @@ -5674,6 +5674,10 @@ std::tuple ControlManager::setReference(const mrs_msgs::Refer { std::scoped_lock lock(mutex_tracker_list_); + ROS_INFO("[ControlManager]: setting reference to x=%.2f, y=%.2f, z=%.2f, hdg=%.2f (expressed in '%s')", reference_request.reference.position.x, + reference_request.reference.position.y, reference_request.reference.position.z, reference_request.reference.heading, + transformed_reference.header.frame_id.c_str()); + tracker_response = tracker_list_.at(active_tracker_idx_) ->setReference(mrs_msgs::ReferenceSrvRequest::ConstPtr(std::make_unique(reference_request))); diff --git a/test/control_manager/CMakeLists.txt b/test/control_manager/CMakeLists.txt index 7c7ef50..9f58c71 100644 --- a/test/control_manager/CMakeLists.txt +++ b/test/control_manager/CMakeLists.txt @@ -21,3 +21,7 @@ add_subdirectory(trajectory_topic) add_subdirectory(trajectory_start_stop_resume) add_subdirectory(velocity_reference_topic) + +add_subdirectory(set_heading_service) + +add_subdirectory(set_heading_relative_service) diff --git a/test/control_manager/set_heading_relative_service/CMakeLists.txt b/test/control_manager/set_heading_relative_service/CMakeLists.txt new file mode 100644 index 0000000..bf8f985 --- /dev/null +++ b/test/control_manager/set_heading_relative_service/CMakeLists.txt @@ -0,0 +1,16 @@ +get_filename_component(TEST_NAME "${CMAKE_CURRENT_SOURCE_DIR}" NAME) + +catkin_add_executable_with_gtest(test_${TEST_NAME} + test.cpp + ) + +target_link_libraries(test_${TEST_NAME} + ${catkin_LIBRARIES} + ) + +add_dependencies(test_${TEST_NAME} + ${${PROJECT_NAME}_EXPORTED_TARGETS} + ${catkin_EXPORTED_TARGETS} + ) + +add_rostest(${TEST_NAME}.test) diff --git a/test/control_manager/set_heading_relative_service/config/mrs_simulator.yaml b/test/control_manager/set_heading_relative_service/config/mrs_simulator.yaml new file mode 100644 index 0000000..90665f9 --- /dev/null +++ b/test/control_manager/set_heading_relative_service/config/mrs_simulator.yaml @@ -0,0 +1,10 @@ +individual_takeoff_platform: + enabled: true + +uav1: + type: "x500" + spawn: + x: 10.0 + y: 20.0 + z: 2.0 + heading: 4.0 diff --git a/test/control_manager/set_heading_relative_service/set_heading_relative_service.test b/test/control_manager/set_heading_relative_service/set_heading_relative_service.test new file mode 100644 index 0000000..18f13c3 --- /dev/null +++ b/test/control_manager/set_heading_relative_service/set_heading_relative_service.test @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/test/control_manager/set_heading_relative_service/test.cpp b/test/control_manager/set_heading_relative_service/test.cpp new file mode 100644 index 0000000..72243c8 --- /dev/null +++ b/test/control_manager/set_heading_relative_service/test.cpp @@ -0,0 +1,92 @@ +#include + +#include + +class Tester : public mrs_uav_testing::TestGeneric { + +public: + bool test(); +}; + +bool Tester::test() { + + std::shared_ptr uh; + + { + auto [uhopt, message] = getUAVHandler(_uav_name_); + + if (!uhopt) { + ROS_ERROR("[%s]: Failed obtain handler for '%s': '%s'", ros::this_node::getName().c_str(), _uav_name_.c_str(), message.c_str()); + return false; + } + + uh = uhopt.value(); + } + + { + auto [success, message] = uh->activateMidAir(); + + if (!success) { + ROS_ERROR("[%s]: midair activation failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeadingRelative(0.5); + + if (!success) { + ROS_ERROR("[%s]: set heading relative failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeadingRelative(3.14); + + if (!success) { + ROS_ERROR("[%s]: set heading relative failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeadingRelative(0); + + if (!success) { + ROS_ERROR("[%s]: set heading relative failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + this->sleep(5.0); + + if (uh->isFlyingNormally()) { + return true; + } else { + ROS_ERROR("[%s]: not flying normally", ros::this_node::getName().c_str()); + return false; + } +} + +TEST(TESTSuite, test) { + + Tester tester; + + bool result = tester.test(); + + if (result) { + GTEST_SUCCEED(); + } else { + GTEST_FAIL(); + } +} + +int main([[maybe_unused]] int argc, [[maybe_unused]] char** argv) { + + ros::init(argc, argv, "test"); + + testing::InitGoogleTest(&argc, argv); + + return RUN_ALL_TESTS(); +} diff --git a/test/control_manager/set_heading_service/CMakeLists.txt b/test/control_manager/set_heading_service/CMakeLists.txt new file mode 100644 index 0000000..bf8f985 --- /dev/null +++ b/test/control_manager/set_heading_service/CMakeLists.txt @@ -0,0 +1,16 @@ +get_filename_component(TEST_NAME "${CMAKE_CURRENT_SOURCE_DIR}" NAME) + +catkin_add_executable_with_gtest(test_${TEST_NAME} + test.cpp + ) + +target_link_libraries(test_${TEST_NAME} + ${catkin_LIBRARIES} + ) + +add_dependencies(test_${TEST_NAME} + ${${PROJECT_NAME}_EXPORTED_TARGETS} + ${catkin_EXPORTED_TARGETS} + ) + +add_rostest(${TEST_NAME}.test) diff --git a/test/control_manager/set_heading_service/set_heading_service.test b/test/control_manager/set_heading_service/set_heading_service.test new file mode 100644 index 0000000..604b743 --- /dev/null +++ b/test/control_manager/set_heading_service/set_heading_service.test @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/test/control_manager/set_heading_service/test.cpp b/test/control_manager/set_heading_service/test.cpp new file mode 100644 index 0000000..18fe1b6 --- /dev/null +++ b/test/control_manager/set_heading_service/test.cpp @@ -0,0 +1,101 @@ +#include + +#include + +class Tester : public mrs_uav_testing::TestGeneric { + +public: + bool test(); +}; + +bool Tester::test() { + + std::shared_ptr uh; + + { + auto [uhopt, message] = getUAVHandler(_uav_name_); + + if (!uhopt) { + ROS_ERROR("[%s]: Failed obtain handler for '%s': '%s'", ros::this_node::getName().c_str(), _uav_name_.c_str(), message.c_str()); + return false; + } + + uh = uhopt.value(); + } + + { + auto [success, message] = uh->activateMidAir(); + + if (!success) { + ROS_ERROR("[%s]: midair activation failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeading(0.5); + + if (!success) { + ROS_ERROR("[%s]: set heading service failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeading(-0.5); + + if (!success) { + ROS_ERROR("[%s]: set heading service failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeading(-3.14); + + if (!success) { + ROS_ERROR("[%s]: set heading service failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = uh->setHeading(0.0); + + if (!success) { + ROS_ERROR("[%s]: set heading service failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + this->sleep(5.0); + + if (uh->isFlyingNormally()) { + return true; + } else { + ROS_ERROR("[%s]: not flying normally", ros::this_node::getName().c_str()); + return false; + } +} + +TEST(TESTSuite, test) { + + Tester tester; + + bool result = tester.test(); + + if (result) { + GTEST_SUCCEED(); + } else { + GTEST_FAIL(); + } +} + +int main([[maybe_unused]] int argc, [[maybe_unused]] char** argv) { + + ros::init(argc, argv, "test"); + + testing::InitGoogleTest(&argc, argv); + + return RUN_ALL_TESTS(); +}