From e9bf9ded0ade23b94a14b963b17c45e9196dfdf8 Mon Sep 17 00:00:00 2001 From: Jaron <13423952+jaron-l@users.noreply.github.com> Date: Thu, 18 Aug 2022 13:03:48 -0500 Subject: [PATCH] test: :white_check_mark: fix and add back joint_trajectory_controller state_topic_consistency (#415) --- .../test/test_trajectory_controller.cpp | 88 ++++++++++--------- 1 file changed, 45 insertions(+), 43 deletions(-) diff --git a/joint_trajectory_controller/test/test_trajectory_controller.cpp b/joint_trajectory_controller/test/test_trajectory_controller.cpp index 576f6a30d7..0d717515cf 100644 --- a/joint_trajectory_controller/test/test_trajectory_controller.cpp +++ b/joint_trajectory_controller/test/test_trajectory_controller.cpp @@ -356,55 +356,57 @@ TEST_P(TrajectoryControllerTestParameterized, correct_initialization_using_param executor.cancel(); } -// TEST_P(TrajectoryControllerTestParameterized, state_topic_consistency) -// { -// rclcpp::executors::SingleThreadedExecutor executor; -// SetUpAndActivateTrajectoryController(true, {}, &executor); -// subscribeToState(); -// updateController(); +TEST_P(TrajectoryControllerTestParameterized, state_topic_consistency) +{ + rclcpp::executors::SingleThreadedExecutor executor; + SetUpAndActivateTrajectoryController(true, {}, &executor); + subscribeToState(); + updateController(); -// // Spin to receive latest state -// executor.spin_some(); -// auto state = getState(); + // Spin to receive latest state + executor.spin_some(); + auto state = getState(); -// size_t n_joints = joint_names_.size(); + size_t n_joints = joint_names_.size(); -// for (unsigned int i = 0; i < n_joints; ++i) -// { -// EXPECT_EQ(joint_names_[i], state->joint_names[i]); -// } + for (unsigned int i = 0; i < n_joints; ++i) + { + EXPECT_EQ(joint_names_[i], state->joint_names[i]); + } -// // No trajectory by default, no desired state or error -// EXPECT_TRUE(state->desired.positions.empty()); -// EXPECT_TRUE(state->desired.velocities.empty()); -// EXPECT_TRUE(state->desired.accelerations.empty()); + // No trajectory by default, no desired state or error + EXPECT_TRUE(state->desired.positions.empty() || state->desired.positions == INITIAL_POS_JOINTS); + EXPECT_TRUE(state->desired.velocities.empty() || state->desired.velocities == INITIAL_VEL_JOINTS); + EXPECT_TRUE( + state->desired.accelerations.empty() || state->desired.accelerations == INITIAL_EFF_JOINTS); -// EXPECT_EQ(n_joints, state->actual.positions.size()); -// if ( -// std::find(state_interface_types_.begin(), state_interface_types_.end(), "velocity") == -// state_interface_types_.end()) -// { -// EXPECT_TRUE(state->actual.velocities.empty()); -// } -// else -// { -// EXPECT_EQ(n_joints, state->actual.velocities.size()); -// } -// if ( -// std::find(state_interface_types_.begin(), state_interface_types_.end(), "acceleration") == -// state_interface_types_.end()) -// { -// EXPECT_TRUE(state->actual.accelerations.empty()); -// } -// else -// { -// EXPECT_EQ(n_joints, state->actual.accelerations.size()); -// } + EXPECT_EQ(n_joints, state->actual.positions.size()); + if ( + std::find(state_interface_types_.begin(), state_interface_types_.end(), "velocity") == + state_interface_types_.end()) + { + EXPECT_TRUE(state->actual.velocities.empty()); + } + else + { + EXPECT_EQ(n_joints, state->actual.velocities.size()); + } + if ( + std::find(state_interface_types_.begin(), state_interface_types_.end(), "acceleration") == + state_interface_types_.end()) + { + EXPECT_TRUE(state->actual.accelerations.empty()); + } + else + { + EXPECT_EQ(n_joints, state->actual.accelerations.size()); + } -// EXPECT_TRUE(state->error.positions.empty()); -// EXPECT_TRUE(state->error.velocities.empty()); -// EXPECT_TRUE(state->error.accelerations.empty()); -// } + std::vector zeros(3, 0); + EXPECT_EQ(state->error.positions, zeros); + EXPECT_TRUE(state->error.velocities.empty() || state->error.velocities == zeros); + EXPECT_TRUE(state->error.accelerations.empty() || state->error.accelerations == zeros); +} // void TrajectoryControllerTest::test_state_publish_rate_target(int target_msg_count) // {