2016-12-14 09:28:54 -08:00
|
|
|
// Copyright 2016 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.
|
|
|
|
|
|
|
|
// testing default transition sequence.
|
|
|
|
// This test requires that the transitions are set
|
|
|
|
// as depicted in design.ros2.org
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <vector>
|
|
|
|
|
2017-07-27 07:55:26 -07:00
|
|
|
#include "lifecycle_msgs/msg/state.h"
|
|
|
|
#include "lifecycle_msgs/msg/transition.h"
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
#include "rcl/error_handling.h"
|
|
|
|
#include "rcl/rcl.h"
|
|
|
|
|
2017-07-27 07:55:26 -07:00
|
|
|
#include "rcutils/logging_macros.h"
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
#include "rcl_lifecycle/rcl_lifecycle.h"
|
2017-07-27 07:55:26 -07:00
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
#include "../src/default_state_machine.h"
|
|
|
|
|
|
|
|
class TestDefaultStateMachine : public ::testing::Test
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
rcl_node_t * node_ptr;
|
2017-06-16 23:44:06 +02:00
|
|
|
const rcl_allocator_t * allocator;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
void SetUp()
|
|
|
|
{
|
|
|
|
rcl_ret_t ret;
|
|
|
|
ret = rcl_init(0, nullptr, rcl_get_default_allocator());
|
|
|
|
ASSERT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
|
|
|
this->node_ptr = new rcl_node_t;
|
|
|
|
*this->node_ptr = rcl_get_zero_initialized_node();
|
2017-05-02 10:25:48 -07:00
|
|
|
const char * name = "test_state_machine_node";
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_node_options_t node_options = rcl_node_get_default_options();
|
2017-04-08 02:04:51 -07:00
|
|
|
ret = rcl_node_init(this->node_ptr, name, "", &node_options);
|
2016-12-14 09:28:54 -08:00
|
|
|
ASSERT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2017-06-16 23:44:06 +02:00
|
|
|
const rcl_node_options_t * node_ops = rcl_node_get_options(this->node_ptr);
|
|
|
|
this->allocator = &node_ops->allocator;
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown()
|
|
|
|
{
|
|
|
|
rcl_ret_t ret = rcl_node_fini(this->node_ptr);
|
|
|
|
delete this->node_ptr;
|
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
|
|
|
ret = rcl_shutdown();
|
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-08-02 14:05:03 -07:00
|
|
|
std::vector<rcl_lifecycle_transition_key_t> keys =
|
2016-12-14 09:28:54 -08:00
|
|
|
{
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR
|
2016-12-14 09:28:54 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
void
|
|
|
|
test_trigger_transition(
|
|
|
|
rcl_lifecycle_state_machine_t * state_machine,
|
|
|
|
int key,
|
|
|
|
unsigned int expected_current_state,
|
|
|
|
unsigned int expected_goal_state)
|
|
|
|
{
|
|
|
|
EXPECT_EQ(
|
|
|
|
expected_current_state, state_machine->current_state->id);
|
|
|
|
EXPECT_EQ(
|
|
|
|
RCL_RET_OK, rcl_lifecycle_trigger_transition(
|
|
|
|
state_machine, key, false));
|
|
|
|
EXPECT_EQ(
|
|
|
|
expected_goal_state, state_machine->current_state->id);
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* Test suite
|
|
|
|
*/
|
|
|
|
TEST_F(TestDefaultStateMachine, zero_init) {
|
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
|
|
|
ASSERT_EQ(rcl_lifecycle_state_machine_is_initialized(&state_machine), RCL_RET_ERROR);
|
2017-08-11 15:06:19 -07:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
const rcl_lifecycle_transition_map_t * transition_map = &state_machine.transition_map;
|
|
|
|
ASSERT_EQ(transition_map->states_size, (unsigned int)0);
|
|
|
|
ASSERT_EQ(transition_map->states, nullptr);
|
|
|
|
ASSERT_EQ(transition_map->transitions_size, (unsigned int)0);
|
|
|
|
ASSERT_EQ(transition_map->transitions, nullptr);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
auto ret = rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator);
|
|
|
|
ASSERT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, default_sequence) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, wrong_default_sequence) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
{ // supposed to stay unconfigured for all invalid
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN) {continue;}
|
|
|
|
|
|
|
|
EXPECT_EQ(
|
|
|
|
RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(
|
|
|
|
state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay configuring for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
2017-08-02 14:05:03 -07:00
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR) {continue;}
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay inactive for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN) {continue;}
|
|
|
|
|
2018-10-05 17:30:27 -04:00
|
|
|
RCUTILS_LOG_INFO_NAMED(ROS_PACKAGE_NAME, "applying key %u", *it);
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(
|
|
|
|
RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay activating for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
2017-08-02 14:05:03 -07:00
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR) {continue;}
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay active for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN)
|
|
|
|
{continue;}
|
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay deactivating for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
2017-08-02 14:05:03 -07:00
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR) {continue;}
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay cleanup for all invalid
|
|
|
|
// skip inactive, we tested that already
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
2017-08-02 14:05:03 -07:00
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR) {continue;}
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay shutting down for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
// shutdown directly, since we tested already unconfigured
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
2017-08-02 14:05:03 -07:00
|
|
|
if (*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE ||
|
|
|
|
*it == lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR) {continue;}
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{ // supposed to stay finalized for all invalid
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
|
|
|
|
|
|
|
for (auto it = keys.begin(); it != keys.end(); ++it) {
|
|
|
|
EXPECT_EQ(RCL_RET_ERROR, rcl_lifecycle_trigger_transition(&state_machine, *it, false));
|
2017-06-16 23:44:06 +02:00
|
|
|
rcl_reset_error();
|
2016-12-14 09:28:54 -08:00
|
|
|
EXPECT_EQ(state_machine.current_state->id,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
|
|
|
}
|
|
|
|
}
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, default_in_a_loop) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
for (auto i = 0; i < 5; ++i) {
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
}
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, default_sequence_failure) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
///////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
//////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
|
|
|
|
//////////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
/////////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, default_sequence_error_resolved) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
rcl_lifecycle_state_machine_t state_machine = rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
///////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
//////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_DEACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_ACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_DEACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
//////////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CLEANUP,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CLEANINGUP,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
|
|
|
|
|
|
|
/////////////////////////////
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_SHUTDOWN,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_SHUTTINGDOWN,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(TestDefaultStateMachine, default_sequence_error_unresolved) {
|
2017-05-25 19:52:25 -07:00
|
|
|
rcl_ret_t ret;
|
|
|
|
|
2016-12-14 09:28:54 -08:00
|
|
|
{
|
|
|
|
rcl_lifecycle_state_machine_t state_machine =
|
|
|
|
rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_FAILURE,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
2017-06-16 23:44:06 +02:00
|
|
|
|
|
|
|
EXPECT_EQ(RCL_RET_OK,
|
|
|
|
rcl_lifecycle_state_machine_fini(&state_machine, this->node_ptr, this->allocator));
|
2016-12-14 09:28:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
rcl_lifecycle_state_machine_t state_machine =
|
|
|
|
rcl_lifecycle_get_zero_initialized_state_machine();
|
2017-06-16 23:44:06 +02:00
|
|
|
ret = rcl_lifecycle_init_default_state_machine(&state_machine, this->allocator);
|
2017-05-25 19:52:25 -07:00
|
|
|
EXPECT_EQ(RCL_RET_OK, ret) << rcl_get_error_string_safe();
|
2016-12-14 09:28:54 -08:00
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CONFIGURE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_UNCONFIGURED,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_SUCCESS,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_CONFIGURING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_ACTIVATE,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_INACTIVE,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ACTIVATING,
|
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING);
|
|
|
|
|
|
|
|
test_trigger_transition(
|
|
|
|
&state_machine,
|
2017-08-02 14:05:03 -07:00
|
|
|
lifecycle_msgs__msg__Transition__TRANSITION_CALLBACK_ERROR,
|
2016-12-14 09:28:54 -08:00
|
|
|
lifecycle_msgs__msg__State__TRANSITION_STATE_ERRORPROCESSING,
|
|
|
|
lifecycle_msgs__msg__State__PRIMARY_STATE_FINALIZED);
|
|
|
|
}
|
|
|
|
}
|