Skip to content

Commit

Permalink
Fix Task's move constructor (moveit#371)
Browse files Browse the repository at this point in the history
* Add unit test
* Fix TaskPrivate's move assignment operator
* Slightly simplify code

Co-authored-by: Robert Haschke <[email protected]>
  • Loading branch information
JafarAbdi and rhaschke committed Jun 15, 2022
1 parent 3b3dd14 commit 01e36b0
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 6 deletions.
14 changes: 8 additions & 6 deletions core/src/task.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -79,10 +79,12 @@ TaskPrivate::TaskPrivate(Task* me, const std::string& ns)
TaskPrivate& TaskPrivate::operator=(TaskPrivate&& other) {
this->WrapperBasePrivate::operator=(std::move(other));
ns_ = std::move(other.ns_);
introspection_ = std::move(other.introspection_);
robot_model_ = std::move(other.robot_model_);
robot_model_loader_ = std::move(other.robot_model_loader_);
task_cbs_ = std::move(other.task_cbs_);
// Ensure same introspection status, but keep the existing introspection instance,
// which stores this task pointer and includes it in its task_id_
static_cast<Task*>(me_)->enableIntrospection(static_cast<bool>(other.introspection_));
return *this;
}

Expand Down Expand Up @@ -211,17 +213,17 @@ void Task::init() {
stages()->pimpl()->resolveInterface(InterfaceFlags({ GENERATE }));

// provide introspection instance to all stages
impl->setIntrospection(impl->introspection_.get());
auto* introspection = impl->introspection_.get();
impl->traverseStages(
[impl](Stage& stage, int /*depth*/) {
stage.pimpl()->setIntrospection(impl->introspection_.get());
[introspection](Stage& stage, int /*depth*/) {
stage.pimpl()->setIntrospection(introspection);
return true;
},
1, UINT_MAX);

// first time publish task
if (impl->introspection_)
impl->introspection_->publishTaskDescription();
if (introspection)
introspection->publishTaskDescription();
}

bool Task::canCompute() const {
Expand Down
29 changes: 29 additions & 0 deletions core/test/test_move_to.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#include "models.h"
#include "stage_mockups.h"

#include <moveit/task_constructor/task.h>
#include <moveit/task_constructor/stages/move_to.h>
Expand Down Expand Up @@ -156,6 +157,34 @@ TEST_F(PandaMoveTo, poseIKFrameAttachedSubframeTarget) {
EXPECT_ONE_SOLUTION;
}

// This test require a running rosmaster
TEST(Task, taskMoveConstructor) {
auto create_task = [] {
moveit::core::RobotModelConstPtr robot_model = getModel();
Task t("first");
t.setRobotModel(robot_model);
auto ref = new stages::FixedState("fixed");
auto scene = std::make_shared<planning_scene::PlanningScene>(t.getRobotModel());
ref->setState(scene);

t.add(Stage::pointer(ref));
t.add(std::make_unique<ConnectMockup>());
t.add(std::make_unique<MonitoringGeneratorMockup>(ref));
return t;
};

// Segfaults when introspection is enabled
Task t;
t = create_task();

try {
t.init();
EXPECT_TRUE(t.plan(1));
} catch (const InitStageException& e) {
ADD_FAILURE() << "InitStageException:" << std::endl << e << t;
}
}

int main(int argc, char** argv) {
testing::InitGoogleTest(&argc, argv);
rclcpp::init(argc, argv);
Expand Down

0 comments on commit 01e36b0

Please sign in to comment.