From 1747f4a1bb9971465d65dab0fdd784566554fa7f Mon Sep 17 00:00:00 2001 From: Chris Lalancette Date: Tue, 10 Oct 2023 14:07:44 +0000 Subject: [PATCH 1/3] Small cleanups to rosidl_generator_tests. Get rid of some unnecessary macros, refactor the header includes, and make things static where possible. Signed-off-by: Chris Lalancette --- .../test/rosidl_generator_c/test_interfaces.c | 182 +++++++++--------- .../rosidl_generator_cpp/test_interfaces.cpp | 35 ++-- 2 files changed, 102 insertions(+), 115 deletions(-) diff --git a/rosidl_generator_tests/test/rosidl_generator_c/test_interfaces.c b/rosidl_generator_tests/test/rosidl_generator_c/test_interfaces.c index 72b1a56cb..5cb72ca20 100644 --- a/rosidl_generator_tests/test/rosidl_generator_c/test_interfaces.c +++ b/rosidl_generator_tests/test/rosidl_generator_c/test_interfaces.c @@ -12,7 +12,6 @@ // See the License for the specific language governing permissions and // limitations under the License. - #include #include #include @@ -63,97 +62,28 @@ } #define EXPECT_NE(arg1, arg2) if ((arg1) == (arg2)) return 1 -const uint8_t test_values_byte[ARR_SIZE] = {0, 57, 110}; -const char test_values_char[ARR_SIZE] = {'a', '5', '#'}; -const float test_values_float32[ARR_SIZE] = {-3.000001f, 22143.541325f, 6331.00432f}; -const double test_values_float64[ARR_SIZE] = { +static const uint8_t test_values_byte[ARR_SIZE] = {0, 57, 110}; +static const char test_values_char[ARR_SIZE] = {'a', '5', '#'}; +static const float test_values_float32[ARR_SIZE] = {-3.000001f, 22143.541325f, 6331.00432f}; +static const double test_values_float64[ARR_SIZE] = { -120310.00843902140001, 22143.54483920141325, 6331.0048392104432 }; -const int8_t test_values_int8[ARR_SIZE] = {-50, 13, 110}; -const uint8_t test_values_uint8[ARR_SIZE] = {0, 125, 250}; -const int16_t test_values_int16[ARR_SIZE] = {-22222, 0, 32767}; -const uint16_t test_values_uint16[ARR_SIZE] = {0U, 33333U, 65535U}; -const int32_t test_values_int32[ARR_SIZE] = {INT32_MIN / 2, 0L, INT32_MAX / 2}; -const uint32_t test_values_uint32[ARR_SIZE] = {0UL, 444444UL, 4294967295UL}; -const int64_t test_values_int64[ARR_SIZE] = {-9223372036854775807LL, 0, 9223372036854775807ULL}; -const uint64_t test_values_uint64[ARR_SIZE] = {0ULL, 567890123456789ULL, 18446744073709551615ULL}; -const char * test_values_string[ARR_SIZE] = {"", "max value", "min value"}; - -int test_arrays(void); -int test_basic_types(void); -int test_bounded_sequences(void); -int test_constants(void); -int test_defaults(void); -int test_multi_nested(void); -int test_nested(void); -int test_strings(void); -int test_unbounded_sequences(void); -int test_wstrings(void); - -int main(void) -{ - int rc = 0; - printf("Testing rosidl_generator_tests basic types...\n"); - if (test_basic_types()) { - fprintf(stderr, "test_basic_types() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests constant types...\n"); - if (test_constants()) { - fprintf(stderr, "test_constant() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests default types...\n"); - if (test_defaults()) { - fprintf(stderr, "test_defaults() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests string types...\n"); - if (test_strings()) { - fprintf(stderr, "test_strings() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests array types\n"); - if (test_arrays()) { - fprintf(stderr, "test_arrays() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests wstring types\n"); - if (test_wstrings()) { - fprintf(stderr, "test_wstrings() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests bounded_sequences types\n"); - if (test_bounded_sequences()) { - fprintf(stderr, "test_bounded_sequences() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests nested types\n"); - if (test_nested()) { - fprintf(stderr, "test_nested() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests unbounded_sequences types\n"); - if (test_unbounded_sequences()) { - fprintf(stderr, "test_unbounded_sequences() FAILED\n"); - rc++; - } - printf("Testing rosidl_generator_tests multi_nested type\n"); - if (test_multi_nested()) { - fprintf(stderr, "test_multi_nested() FAILED\n"); - rc++; - } - if (rc != 0) { - fprintf(stderr, "Some tests failed!\n"); - } else { - printf("All tests were good!\n"); - } - return rc != 0; -} +static const int8_t test_values_int8[ARR_SIZE] = {-50, 13, 110}; +static const uint8_t test_values_uint8[ARR_SIZE] = {0, 125, 250}; +static const int16_t test_values_int16[ARR_SIZE] = {-22222, 0, 32767}; +static const uint16_t test_values_uint16[ARR_SIZE] = {0U, 33333U, 65535U}; +static const int32_t test_values_int32[ARR_SIZE] = {INT32_MIN / 2, 0L, INT32_MAX / 2}; +static const uint32_t test_values_uint32[ARR_SIZE] = {0UL, 444444UL, 4294967295UL}; +static const int64_t test_values_int64[ARR_SIZE] = { + -9223372036854775807LL, 0, 9223372036854775807ULL +}; +static const uint64_t test_values_uint64[ARR_SIZE] = { + 0ULL, 567890123456789ULL, 18446744073709551615ULL +}; +static const char * test_values_string[ARR_SIZE] = {"", "max value", "min value"}; -int test_basic_types(void) +static int test_basic_types(void) { - // rosidl_generator_tests__msg__BasicTypes basic; rosidl_generator_tests__msg__BasicTypes * basic = NULL; basic = rosidl_generator_tests__msg__BasicTypes__create(); EXPECT_NE(basic, NULL); @@ -214,7 +144,7 @@ int test_basic_types(void) return 0; } -int test_constants(void) +static int test_constants(void) { EXPECT_EQ(true, rosidl_generator_tests__msg__Constants__BOOL_CONST); EXPECT_EQ(50, rosidl_generator_tests__msg__Constants__BYTE_CONST); @@ -233,7 +163,7 @@ int test_constants(void) return 0; } -int test_defaults() +static int test_defaults(void) { rosidl_generator_tests__msg__Defaults * def = NULL; def = rosidl_generator_tests__msg__Defaults__create(); @@ -271,7 +201,7 @@ int test_defaults() return 0; } -int test_bounded_sequences() +static int test_bounded_sequences(void) { rosidl_generator_tests__msg__BoundedSequences * seq = NULL; seq = rosidl_generator_tests__msg__BoundedSequences__create(); @@ -728,7 +658,7 @@ int test_unbounded_sequences() return 0; } -int test_strings() +static int test_strings(void) { rosidl_generator_tests__msg__Strings * str = NULL; str = rosidl_generator_tests__msg__Strings__create(); @@ -772,7 +702,7 @@ int test_strings() return 0; } -int test_nested() +static int test_nested(void) { rosidl_generator_tests__msg__Nested * nested = NULL; nested = rosidl_generator_tests__msg__Nested__create(); @@ -823,7 +753,7 @@ int test_nested() return 0; } -int test_multi_nested() +static int test_multi_nested(void) { rosidl_generator_tests__msg__MultiNested * msg = NULL; msg = rosidl_generator_tests__msg__MultiNested__create(); @@ -872,7 +802,6 @@ int test_multi_nested() } // char_values - char test_values_char[ARR_SIZE] = {'a', '5', '#'}; for (i = 0; i < ARR_SIZE; i++) { for (j = 0; j < ARR_SIZE; j++) { msg->array_of_arrays[i].char_values[j] = test_values_char[j]; @@ -1099,7 +1028,7 @@ int test_wstrings() return 0; } -int test_arrays() +static int test_arrays(void) { rosidl_generator_tests__msg__Arrays * arr = NULL; arr = rosidl_generator_tests__msg__Arrays__create(); @@ -1298,3 +1227,64 @@ int test_arrays() rosidl_generator_tests__msg__Arrays__destroy(arr); return 0; } + +int main(void) +{ + int rc = 0; + printf("Testing rosidl_generator_tests basic types...\n"); + if (test_basic_types()) { + fprintf(stderr, "test_basic_types() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests constant types...\n"); + if (test_constants()) { + fprintf(stderr, "test_constant() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests default types...\n"); + if (test_defaults()) { + fprintf(stderr, "test_defaults() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests string types...\n"); + if (test_strings()) { + fprintf(stderr, "test_strings() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests array types\n"); + if (test_arrays()) { + fprintf(stderr, "test_arrays() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests wstring types\n"); + if (test_wstrings()) { + fprintf(stderr, "test_wstrings() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests bounded_sequences types\n"); + if (test_bounded_sequences()) { + fprintf(stderr, "test_bounded_sequences() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests nested types\n"); + if (test_nested()) { + fprintf(stderr, "test_nested() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests unbounded_sequences types\n"); + if (test_unbounded_sequences()) { + fprintf(stderr, "test_unbounded_sequences() FAILED\n"); + rc++; + } + printf("Testing rosidl_generator_tests multi_nested type\n"); + if (test_multi_nested()) { + fprintf(stderr, "test_multi_nested() FAILED\n"); + rc++; + } + if (rc != 0) { + fprintf(stderr, "Some tests failed!\n"); + } else { + printf("All tests were good!\n"); + } + return rc != 0; +} diff --git a/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp b/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp index 9405d6238..d8135cebd 100644 --- a/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp +++ b/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp @@ -13,13 +13,15 @@ // limitations under the License. #include -#include -#include + +#include +#include #include +#include #include #include #include -#include + #include "test_array_generator.hpp" #include "rosidl_generator_tests/msg/arrays.hpp" @@ -146,10 +148,6 @@ TEST(Test_rosidl_generator_traits, has_bounded_size) { Message.FieldName = FinalValue; \ ASSERT_STREQ(FinalValue, Message.FieldName.c_str()); -#define TEST_WSTRING_FIELD_ASSIGNMENT(Message, FieldName, InitialValue, FinalValue) \ - Message.FieldName = InitialValue; \ - Message.FieldName = FinalValue; - void test_message_basic_types(rosidl_generator_tests::msg::BasicTypes message) { // workaround for https://github.com/google/googletest/issues/322 @@ -522,20 +520,19 @@ TEST(Test_messages, Test_string) { TEST(Test_messages, Test_wstring) { rosidl_generator_tests::msg::WStrings message; - TEST_WSTRING_FIELD_ASSIGNMENT(message, wstring_value, u"", u"wstring_value_\u2122") + message.wstring_value = u""; + message.wstring_value = u"wstring_value_\u2122"; } -#define TEST_STATIC_ARRAY_STRING( \ - Message, FieldName, PrimitiveType, ArraySize, MinVal, MaxVal, MinLength, MaxLength) \ - std::array pattern_ ## FieldName; \ - test_vector_fill( \ - &pattern_ ## FieldName, ArraySize, MinVal, MaxVal, MinLength, MaxLength); \ - std::copy_n(pattern_ ## FieldName.begin(), Message.FieldName.size(), Message.FieldName.begin()); \ - ASSERT_EQ(pattern_ ## FieldName, Message.FieldName); \ - TEST(Test_messages, Test_string_array_static) { rosidl_generator_tests::msg::Arrays message; - TEST_STATIC_ARRAY_STRING( - message, string_values_default, std::string, ARRAY_SIZE, \ - 0, UINT32_MAX, 0, UINT16_MAX) + std::array pattern_string_values_default; + + test_vector_fill>( + &pattern_string_values_default, ARRAY_SIZE, 0, UINT32_MAX, 0, UINT16_MAX); + std::copy_n( + pattern_string_values_default.begin(), + message.string_values_default.size(), + message.string_values_default.begin()); + ASSERT_EQ(pattern_string_values_default, message.string_values_default); } From 84c78d501df8bfc1cda63273c24aa30f99d0a993 Mon Sep 17 00:00:00 2001 From: Chris Lalancette Date: Tue, 10 Oct 2023 14:21:29 +0000 Subject: [PATCH 2/3] Add in a new tests for assigning constants. In particular, we want to test float constants. Signed-off-by: Chris Lalancette --- rosidl_generator_tests/CMakeLists.txt | 1 + rosidl_generator_tests/msg/SmallConstant.msg | 1 + .../test/rosidl_generator_cpp/test_interfaces.cpp | 7 +++++++ 3 files changed, 9 insertions(+) create mode 100644 rosidl_generator_tests/msg/SmallConstant.msg diff --git a/rosidl_generator_tests/CMakeLists.txt b/rosidl_generator_tests/CMakeLists.txt index 514a42853..f36054b70 100644 --- a/rosidl_generator_tests/CMakeLists.txt +++ b/rosidl_generator_tests/CMakeLists.txt @@ -35,6 +35,7 @@ if(BUILD_TESTING) ${test_interface_files_MSG_FILES} ${test_interface_files_SRV_FILES} msg/BasicIdl.idl + msg/SmallConstant.msg ADD_LINTER_TESTS SKIP_INSTALL ) diff --git a/rosidl_generator_tests/msg/SmallConstant.msg b/rosidl_generator_tests/msg/SmallConstant.msg new file mode 100644 index 000000000..a58ff4167 --- /dev/null +++ b/rosidl_generator_tests/msg/SmallConstant.msg @@ -0,0 +1 @@ +float32 FLOAT32_CONST=0.05 diff --git a/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp b/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp index d8135cebd..e41230221 100644 --- a/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp +++ b/rosidl_generator_tests/test/rosidl_generator_cpp/test_interfaces.cpp @@ -32,6 +32,7 @@ #include "rosidl_generator_tests/msg/empty.hpp" #include "rosidl_generator_tests/msg/multi_nested.hpp" #include "rosidl_generator_tests/msg/nested.hpp" +#include "rosidl_generator_tests/msg/small_constant.hpp" #include "rosidl_generator_tests/msg/strings.hpp" #include "rosidl_generator_tests/msg/unbounded_sequences.hpp" #include "rosidl_generator_tests/msg/w_strings.hpp" @@ -468,6 +469,12 @@ TEST(Test_messages, constants) { ASSERT_EQ(50000000ull, message.UINT64_CONST); } +TEST(Test_messages, constants_assign) { + float x = rosidl_generator_tests::msg::SmallConstant::FLOAT32_CONST; + + ASSERT_EQ(x, rosidl_generator_tests::msg::SmallConstant::FLOAT32_CONST); +} + // Defaults TEST(Test_messages, defaults) { rosidl_generator_tests::msg::Defaults message; From fe0b671d00e7ddaa9bc5fd5ee8d797075106fbc1 Mon Sep 17 00:00:00 2001 From: Chris Lalancette Date: Tue, 10 Oct 2023 13:31:42 +0000 Subject: [PATCH 3/3] Update the generator code to properly set float constants. Signed-off-by: Chris Lalancette --- rosidl_generator_cpp/resource/msg__struct.hpp.em | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/rosidl_generator_cpp/resource/msg__struct.hpp.em b/rosidl_generator_cpp/resource/msg__struct.hpp.em index 6d1c1363b..6e583888f 100644 --- a/rosidl_generator_cpp/resource/msg__struct.hpp.em +++ b/rosidl_generator_cpp/resource/msg__struct.hpp.em @@ -280,10 +280,16 @@ non_defaulted_zero_initialized_members = [ static const @(MSG_TYPE_TO_CPP['wstring']) @(constant.name); @[ else]@ static constexpr @(MSG_TYPE_TO_CPP[constant.type.typename]) @(constant.name) = -@[ if isinstance(constant.type, BasicType) and constant.type.typename in (*INTEGER_TYPES, *CHARACTER_TYPES, BOOLEAN_TYPE, OCTET_TYPE)]@ +@[ if isinstance(constant.type, BasicType)]@ +@[ if constant.type.typename in (*INTEGER_TYPES, *CHARACTER_TYPES, BOOLEAN_TYPE, OCTET_TYPE)]@ @(int(constant.value))@ -@[ if constant.type.typename in UNSIGNED_INTEGER_TYPES]@ +@[ if constant.type.typename in UNSIGNED_INTEGER_TYPES]@ u@ +@[ end if]@ +@[ elif constant.type.typename == 'float']@ + @(constant.value)f@ +@[ else]@ + @(constant.value)@ @[ end if]; @[ else]@ @(constant.value);