Skip to content

Commit

Permalink
Fix formatJointPosition handle of cartesian seed
Browse files Browse the repository at this point in the history
  • Loading branch information
Levi-Armstrong committed Dec 25, 2024
1 parent e00ae6f commit ad440a9
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 8 deletions.
14 changes: 9 additions & 5 deletions tesseract_command_language/src/utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -241,11 +241,15 @@ bool formatJointPosition(const std::vector<std::string>& joint_names, WaypointPo
else if (waypoint.isCartesianWaypoint())
{
auto& cwp = waypoint.as<CartesianWaypointPoly>();
if (!cwp.hasSeed())
throw std::runtime_error("Cartesian waypoint does not have a seed.");

jv = &(cwp.getSeed().position);
jn = &(cwp.getSeed().joint_names);
if (cwp.hasSeed())
{
jv = &(cwp.getSeed().position);
jn = &(cwp.getSeed().joint_names);
}
else
{
return false;
}
}
else
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -312,13 +312,13 @@ TEST(TesseractCommandLanguageUtilsUnit, formatJointPositionTests) // NOLINT
EXPECT_FALSE(formatJointPosition(joint_names, wp1u_poly));
EXPECT_TRUE(wp1u_poly.as<CartesianWaypointPoly>().getSeed().position.isApprox(seed_position));

WaypointPoly wp2_poly{ wp2 };
EXPECT_FALSE(formatJointPosition(format_joint_names, wp2_poly)); // NOLINT

// Format is not correct size or invalid joint name
EXPECT_ANY_THROW(formatJointPosition({ "joint_1" }, wp0_poly)); // NOLINT
EXPECT_ANY_THROW(formatJointPosition({ "joint_3", "joint_1" }, wp0_poly)); // NOLINT

WaypointPoly wp2_poly{ wp2 };
EXPECT_ANY_THROW(formatJointPosition(format_joint_names, wp2_poly)); // NOLINT

WaypointPoly error_poly;
EXPECT_ANY_THROW(formatJointPosition(format_joint_names, error_poly)); // NOLINT
}
Expand Down

0 comments on commit ad440a9

Please sign in to comment.