Skip to content

Commit

Permalink
Fix constant generation for C++ floats (#772)
Browse files Browse the repository at this point in the history
* Update the generator code to properly set float constants.

* Small cleanups to rosidl_generator_tests.

Get rid of some unnecessary macros, refactor the
header includes, and make things static where possible.

* Add in a new tests for assigning constants.

In particular, we want to test float constants.

Signed-off-by: Chris Lalancette <[email protected]>
  • Loading branch information
clalancette authored Oct 11, 2023
1 parent f9b25a9 commit 2f90010
Show file tree
Hide file tree
Showing 5 changed files with 119 additions and 117 deletions.
10 changes: 8 additions & 2 deletions rosidl_generator_cpp/resource/msg__struct.hpp.em
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Expand Down
1 change: 1 addition & 0 deletions rosidl_generator_tests/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -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
)
Expand Down
1 change: 1 addition & 0 deletions rosidl_generator_tests/msg/SmallConstant.msg
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
float32 FLOAT32_CONST=0.05
182 changes: 86 additions & 96 deletions rosidl_generator_tests/test/rosidl_generator_c/test_interfaces.c
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@
// See the License for the specific language governing permissions and
// limitations under the License.


#include <assert.h>
#include <stdio.h>
#include <stdbool.h>
Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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);
Expand All @@ -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();
Expand Down Expand Up @@ -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();
Expand Down Expand Up @@ -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();
Expand Down Expand Up @@ -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();
Expand Down Expand Up @@ -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();
Expand Down Expand Up @@ -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];
Expand Down Expand Up @@ -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();
Expand Down Expand Up @@ -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;
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,15 @@
// limitations under the License.

#include <gtest/gtest.h>
#include <iostream>
#include <climits>

#include <algorithm>
#include <array>
#include <cfloat>
#include <climits>
#include <cstdint>
#include <string>
#include <vector>
#include <algorithm>

#include "test_array_generator.hpp"

#include "rosidl_generator_tests/msg/arrays.hpp"
Expand All @@ -30,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"
Expand Down Expand Up @@ -146,10 +149,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
Expand Down Expand Up @@ -470,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;
Expand Down Expand Up @@ -522,20 +527,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<PrimitiveType, ArraySize> pattern_ ## FieldName; \
test_vector_fill<decltype(pattern_ ## FieldName)>( \
&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<std::string, ARRAY_SIZE> pattern_string_values_default;

test_vector_fill<std::array<std::string, ARRAY_SIZE>>(
&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);
}

0 comments on commit 2f90010

Please sign in to comment.