[rcl action] Makes rcl_action_get_*_name() functions check for empty action names.
This commit is contained in:
parent
a2546fa0b0
commit
d77c9b6965
3 changed files with 43 additions and 17 deletions
|
@ -41,8 +41,8 @@ extern "C"
|
||||||
* Uses Atomics | No
|
* Uses Atomics | No
|
||||||
* Lock-Free | Yes
|
* Lock-Free | Yes
|
||||||
*
|
*
|
||||||
* \param[in] action_name The name of the action whose goal service name is
|
* \param[in] action_name The non-empty name of the action whose goal
|
||||||
* being returned.
|
* service name is being returned.
|
||||||
* \param[in] allocator A valid allocator to be used.
|
* \param[in] allocator A valid allocator to be used.
|
||||||
* \param[out] goal_service_name Either an allocated string with the action
|
* \param[out] goal_service_name Either an allocated string with the action
|
||||||
* goal service name, or `NULL` if the function failed to allocate memory
|
* goal service name, or `NULL` if the function failed to allocate memory
|
||||||
|
@ -73,8 +73,8 @@ rcl_action_get_goal_service_name(
|
||||||
* Uses Atomics | No
|
* Uses Atomics | No
|
||||||
* Lock-Free | Yes
|
* Lock-Free | Yes
|
||||||
*
|
*
|
||||||
* \param[in] action_name The name of the action whose cancel service name is
|
* \param[in] action_name The non-empty name of the action whose cancel
|
||||||
* being returned.
|
* service name is being returned.
|
||||||
* \param[in] allocator A valid allocator to be used.
|
* \param[in] allocator A valid allocator to be used.
|
||||||
* \param[out] cancel_service_name Either an allocated string with the action
|
* \param[out] cancel_service_name Either an allocated string with the action
|
||||||
* cancel service name, or `NULL` if the function failed to allocate memory
|
* cancel service name, or `NULL` if the function failed to allocate memory
|
||||||
|
@ -105,8 +105,8 @@ rcl_action_get_cancel_service_name(
|
||||||
* Uses Atomics | No
|
* Uses Atomics | No
|
||||||
* Lock-Free | Yes
|
* Lock-Free | Yes
|
||||||
*
|
*
|
||||||
* \param[in] action_name The name of the action whose result service name is
|
* \param[in] action_name The non-empty name of the action whose result service
|
||||||
* being returned.
|
* name is being returned.
|
||||||
* \param[in] allocator A valid allocator to be used.
|
* \param[in] allocator A valid allocator to be used.
|
||||||
* \param[out] result_service_name Either an allocated string with the action
|
* \param[out] result_service_name Either an allocated string with the action
|
||||||
* result service name, or `NULL` if the function failed to allocate memory
|
* result service name, or `NULL` if the function failed to allocate memory
|
||||||
|
@ -137,8 +137,8 @@ rcl_action_get_result_service_name(
|
||||||
* Uses Atomics | No
|
* Uses Atomics | No
|
||||||
* Lock-Free | Yes
|
* Lock-Free | Yes
|
||||||
*
|
*
|
||||||
* \param[in] action_name The name of the action whose feedback topic name is
|
* \param[in] action_name The non-empty name of the action whose feedback
|
||||||
* being returned.
|
* topic name is being returned.
|
||||||
* \param[in] allocator A valid allocator to be used.
|
* \param[in] allocator A valid allocator to be used.
|
||||||
* \param[out] result_service_name Either an allocated string with the action
|
* \param[out] result_service_name Either an allocated string with the action
|
||||||
* feedback topic name, or `NULL` if the function failed to allocate memory
|
* feedback topic name, or `NULL` if the function failed to allocate memory
|
||||||
|
@ -169,8 +169,8 @@ rcl_action_get_feedback_topic_name(
|
||||||
* Uses Atomics | No
|
* Uses Atomics | No
|
||||||
* Lock-Free | Yes
|
* Lock-Free | Yes
|
||||||
*
|
*
|
||||||
* \param[in] action_name The name of the action whose status topic name is
|
* \param[in] action_name The non-empty name of the action whose status topic
|
||||||
* being returned.
|
* name is being returned.
|
||||||
* \param[in] allocator A valid allocator to be used.
|
* \param[in] allocator A valid allocator to be used.
|
||||||
* \param[out] result_service_name Either an allocated string with the action
|
* \param[out] result_service_name Either an allocated string with the action
|
||||||
* status topic name, or `NULL` if the function failed to allocate memory
|
* status topic name, or `NULL` if the function failed to allocate memory
|
||||||
|
|
|
@ -19,6 +19,8 @@ extern "C"
|
||||||
|
|
||||||
#include "rcl_action/names.h"
|
#include "rcl_action/names.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#include "rcl/error_handling.h"
|
#include "rcl/error_handling.h"
|
||||||
#include "rcutils/format_string.h"
|
#include "rcutils/format_string.h"
|
||||||
|
|
||||||
|
@ -30,6 +32,10 @@ rcl_action_get_goal_service_name(
|
||||||
{
|
{
|
||||||
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
if (0 == strlen(action_name)) {
|
||||||
|
RCL_SET_ERROR_MSG("invalid empty action name");
|
||||||
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
|
}
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(goal_service_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(goal_service_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
if (NULL != *goal_service_name) {
|
if (NULL != *goal_service_name) {
|
||||||
RCL_SET_ERROR_MSG("writing action goal service name may leak memory");
|
RCL_SET_ERROR_MSG("writing action goal service name may leak memory");
|
||||||
|
@ -51,6 +57,11 @@ rcl_action_get_cancel_service_name(
|
||||||
{
|
{
|
||||||
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
if (0 == strlen(action_name)) {
|
||||||
|
RCL_SET_ERROR_MSG("invalid empty action name");
|
||||||
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
|
}
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(cancel_service_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(cancel_service_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
if (NULL != *cancel_service_name) {
|
if (NULL != *cancel_service_name) {
|
||||||
RCL_SET_ERROR_MSG("writing action cancel service name may leak memory");
|
RCL_SET_ERROR_MSG("writing action cancel service name may leak memory");
|
||||||
|
@ -72,12 +83,15 @@ rcl_action_get_result_service_name(
|
||||||
{
|
{
|
||||||
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
if (0 == strlen(action_name)) {
|
||||||
|
RCL_SET_ERROR_MSG("invalid empty action name");
|
||||||
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
|
}
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(result_service_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(result_service_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
if (NULL != *result_service_name) {
|
if (NULL != *result_service_name) {
|
||||||
RCL_SET_ERROR_MSG("writing action result service name may leak memory");
|
RCL_SET_ERROR_MSG("writing action result service name may leak memory");
|
||||||
return RCL_RET_INVALID_ARGUMENT;
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
*result_service_name = rcutils_format_string(allocator, "%s/_action/get_result", action_name);
|
*result_service_name = rcutils_format_string(allocator, "%s/_action/get_result", action_name);
|
||||||
if (NULL == *result_service_name) {
|
if (NULL == *result_service_name) {
|
||||||
RCL_SET_ERROR_MSG("failed to allocate memory for action result service name");
|
RCL_SET_ERROR_MSG("failed to allocate memory for action result service name");
|
||||||
|
@ -94,6 +108,10 @@ rcl_action_get_feedback_topic_name(
|
||||||
{
|
{
|
||||||
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
if (0 == strlen(action_name)) {
|
||||||
|
RCL_SET_ERROR_MSG("invalid empty action name");
|
||||||
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
|
}
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(feedback_topic_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(feedback_topic_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
if (NULL != *feedback_topic_name) {
|
if (NULL != *feedback_topic_name) {
|
||||||
RCL_SET_ERROR_MSG("writing action feedback topic name may leak memory");
|
RCL_SET_ERROR_MSG("writing action feedback topic name may leak memory");
|
||||||
|
@ -115,6 +133,10 @@ rcl_action_get_status_topic_name(
|
||||||
{
|
{
|
||||||
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ALLOCATOR_WITH_MSG(&allocator, "allocator is invalid", return RCL_RET_INVALID_ARGUMENT);
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(action_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
|
if (0 == strlen(action_name)) {
|
||||||
|
RCL_SET_ERROR_MSG("invalid empty action name");
|
||||||
|
return RCL_RET_INVALID_ARGUMENT;
|
||||||
|
}
|
||||||
RCL_CHECK_ARGUMENT_FOR_NULL(status_topic_name, RCL_RET_INVALID_ARGUMENT);
|
RCL_CHECK_ARGUMENT_FOR_NULL(status_topic_name, RCL_RET_INVALID_ARGUMENT);
|
||||||
if (NULL != *status_topic_name) {
|
if (NULL != *status_topic_name) {
|
||||||
RCL_SET_ERROR_MSG("writing action status topic name may leak memory");
|
RCL_SET_ERROR_MSG("writing action status topic name may leak memory");
|
||||||
|
|
|
@ -48,14 +48,17 @@ protected:
|
||||||
|
|
||||||
TEST_P(TestActionDerivedName, validate_action_derived_getter)
|
TEST_P(TestActionDerivedName, validate_action_derived_getter)
|
||||||
{
|
{
|
||||||
rcl_ret_t ret;
|
rcl_allocator_t default_allocator = rcl_get_default_allocator();
|
||||||
char dummy_char;
|
|
||||||
char * action_derived_name;
|
char * action_derived_name = NULL;
|
||||||
rcl_allocator_t default_allocator =
|
const char * const null_action_name = NULL;
|
||||||
rcl_get_default_allocator();
|
rcl_ret_t ret = test_subject.get_action_derived_name(
|
||||||
|
null_action_name, default_allocator,
|
||||||
|
&action_derived_name);
|
||||||
|
EXPECT_EQ(RCL_RET_INVALID_ARGUMENT, ret);
|
||||||
|
|
||||||
action_derived_name = NULL;
|
action_derived_name = NULL;
|
||||||
const char * const invalid_action_name = NULL;
|
const char * const invalid_action_name = "";
|
||||||
ret = test_subject.get_action_derived_name(
|
ret = test_subject.get_action_derived_name(
|
||||||
invalid_action_name, default_allocator,
|
invalid_action_name, default_allocator,
|
||||||
&action_derived_name);
|
&action_derived_name);
|
||||||
|
@ -76,6 +79,7 @@ TEST_P(TestActionDerivedName, validate_action_derived_getter)
|
||||||
invalid_ptr_to_action_derived_name);
|
invalid_ptr_to_action_derived_name);
|
||||||
EXPECT_EQ(RCL_RET_INVALID_ARGUMENT, ret);
|
EXPECT_EQ(RCL_RET_INVALID_ARGUMENT, ret);
|
||||||
|
|
||||||
|
char dummy_char = '\0';
|
||||||
action_derived_name = &dummy_char;
|
action_derived_name = &dummy_char;
|
||||||
ret = test_subject.get_action_derived_name(
|
ret = test_subject.get_action_derived_name(
|
||||||
test_subject.action_name, default_allocator,
|
test_subject.action_name, default_allocator,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue