2016-12-14 09:29:27 -08:00
|
|
|
// Copyright 2015 Open Source Robotics Foundation, Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
|
|
|
#include <utility>
|
|
|
|
|
|
|
|
#include "lifecycle_msgs/msg/state.hpp"
|
|
|
|
#include "lifecycle_msgs/msg/transition.hpp"
|
|
|
|
|
|
|
|
#include "rclcpp/rclcpp.hpp"
|
|
|
|
#include "rclcpp_lifecycle/lifecycle_node.hpp"
|
|
|
|
|
|
|
|
using lifecycle_msgs::msg::State;
|
|
|
|
using lifecycle_msgs::msg::Transition;
|
|
|
|
|
|
|
|
class TestCallbackExceptions : public ::testing::Test
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
static void SetUpTestCase()
|
|
|
|
{
|
|
|
|
rclcpp::init(0, nullptr);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class PositiveCallbackExceptionNode : public rclcpp_lifecycle::LifecycleNode
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit PositiveCallbackExceptionNode(std::string node_name)
|
|
|
|
: rclcpp_lifecycle::LifecycleNode(std::move(node_name))
|
|
|
|
{}
|
|
|
|
|
|
|
|
size_t number_of_callbacks = 0;
|
|
|
|
|
|
|
|
protected:
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t
|
|
|
|
on_configure(const rclcpp_lifecycle::State &)
|
2016-12-14 09:29:27 -08:00
|
|
|
{
|
|
|
|
++number_of_callbacks;
|
|
|
|
throw std::runtime_error("custom exception raised in configure callback");
|
|
|
|
}
|
|
|
|
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t
|
|
|
|
on_error(const rclcpp_lifecycle::State &)
|
2016-12-14 09:29:27 -08:00
|
|
|
{
|
|
|
|
++number_of_callbacks;
|
2017-08-02 14:04:34 -07:00
|
|
|
return lifecycle_msgs::msg::Transition::TRANSITION_CALLBACK_SUCCESS;
|
2016-12-14 09:29:27 -08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(TestCallbackExceptions, positive_on_error) {
|
|
|
|
auto test_node = std::make_shared<PositiveCallbackExceptionNode>("testnode");
|
|
|
|
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_UNCONFIGURED, test_node->get_current_state().id());
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_UNCONFIGURED, test_node->trigger_transition(
|
|
|
|
rclcpp_lifecycle::Transition(Transition::TRANSITION_CONFIGURE)).id());
|
|
|
|
// check if all callbacks were successfully overwritten
|
|
|
|
EXPECT_EQ(static_cast<size_t>(2), test_node->number_of_callbacks);
|
|
|
|
}
|
|
|
|
|
2017-07-27 07:55:15 -07:00
|
|
|
TEST_F(TestCallbackExceptions, positive_on_error_with_code) {
|
|
|
|
auto test_node = std::make_shared<PositiveCallbackExceptionNode>("testnode");
|
|
|
|
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_UNCONFIGURED, test_node->get_current_state().id());
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t ret = lifecycle_msgs::msg::Transition::TRANSITION_CALLBACK_SUCCESS;
|
2017-07-27 07:55:15 -07:00
|
|
|
test_node->configure(ret);
|
2017-08-02 14:04:34 -07:00
|
|
|
EXPECT_EQ(lifecycle_msgs::msg::Transition::TRANSITION_CALLBACK_ERROR, ret);
|
2017-07-27 07:55:15 -07:00
|
|
|
}
|
|
|
|
|
2016-12-14 09:29:27 -08:00
|
|
|
class NegativeCallbackExceptionNode : public rclcpp_lifecycle::LifecycleNode
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit NegativeCallbackExceptionNode(std::string node_name)
|
|
|
|
: rclcpp_lifecycle::LifecycleNode(std::move(node_name))
|
|
|
|
{}
|
|
|
|
|
|
|
|
size_t number_of_callbacks = 0;
|
|
|
|
|
|
|
|
protected:
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t
|
|
|
|
on_configure(const rclcpp_lifecycle::State &)
|
2016-12-14 09:29:27 -08:00
|
|
|
{
|
|
|
|
++number_of_callbacks;
|
|
|
|
throw std::runtime_error("custom exception raised in configure callback");
|
|
|
|
}
|
|
|
|
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t
|
|
|
|
on_error(const rclcpp_lifecycle::State &)
|
2016-12-14 09:29:27 -08:00
|
|
|
{
|
|
|
|
++number_of_callbacks;
|
2017-08-02 14:04:34 -07:00
|
|
|
return lifecycle_msgs::msg::Transition::TRANSITION_CALLBACK_FAILURE;
|
2016-12-14 09:29:27 -08:00
|
|
|
}
|
|
|
|
};
|
2017-07-27 07:55:15 -07:00
|
|
|
|
2016-12-14 09:29:27 -08:00
|
|
|
TEST_F(TestCallbackExceptions, negative_on_error) {
|
|
|
|
auto test_node = std::make_shared<NegativeCallbackExceptionNode>("testnode");
|
|
|
|
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_UNCONFIGURED, test_node->get_current_state().id());
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_FINALIZED, test_node->trigger_transition(
|
|
|
|
rclcpp_lifecycle::Transition(Transition::TRANSITION_CONFIGURE)).id());
|
|
|
|
// check if all callbacks were successfully overwritten
|
|
|
|
EXPECT_EQ(static_cast<size_t>(2), test_node->number_of_callbacks);
|
|
|
|
}
|
2017-07-27 07:55:15 -07:00
|
|
|
|
|
|
|
TEST_F(TestCallbackExceptions, negative_on_error_with_code) {
|
|
|
|
auto test_node = std::make_shared<NegativeCallbackExceptionNode>("testnode");
|
|
|
|
|
|
|
|
EXPECT_EQ(State::PRIMARY_STATE_UNCONFIGURED, test_node->get_current_state().id());
|
2017-08-02 14:04:34 -07:00
|
|
|
rcl_lifecycle_transition_key_t ret = RCL_RET_OK;
|
2017-07-27 07:55:15 -07:00
|
|
|
test_node->configure(ret);
|
2017-08-02 14:04:34 -07:00
|
|
|
EXPECT_EQ(lifecycle_msgs::msg::Transition::TRANSITION_CALLBACK_ERROR, ret);
|
2017-07-27 07:55:15 -07:00
|
|
|
}
|