diff --git a/rcldotnet/test/test_messages.cs b/rcldotnet/test/test_messages.cs index f0668fcc..f96e54f2 100644 --- a/rcldotnet/test/test_messages.cs +++ b/rcldotnet/test/test_messages.cs @@ -1,5 +1,6 @@ using System; using System.Collections.Generic; +using System.Linq; using ROS2; using Xunit; @@ -48,10 +49,10 @@ public void TestPublishBuiltins() test_msgs.msg.Builtins msg = new test_msgs.msg.Builtins (); test_msgs.msg.Builtins msg2 = new test_msgs.msg.Builtins (); - msg.Duration_value.Sec = 1; - msg.Duration_value.Nanosec = 2u; - msg.Time_value.Sec = 3; - msg.Time_value.Nanosec = 4u; + msg.DurationValue.Sec = 1; + msg.DurationValue.Nanosec = 2u; + msg.TimeValue.Sec = 3; + msg.TimeValue.Nanosec = 4u; bool received=false; Subscription chatter_sub = node_builtins_2.CreateSubscription ( @@ -70,10 +71,10 @@ public void TestPublishBuiltins() RCLdotnet.SpinOnce(node_builtins_2, 500); } - Assert.Equal(1, msg2.Duration_value.Sec); - Assert.Equal(2u, msg2.Duration_value.Nanosec); - Assert.Equal(3, msg2.Time_value.Sec); - Assert.Equal(4u, msg2.Time_value.Nanosec); + Assert.Equal(1, msg2.DurationValue.Sec); + Assert.Equal(2u, msg2.DurationValue.Nanosec); + Assert.Equal(3, msg2.TimeValue.Sec); + Assert.Equal(4u, msg2.TimeValue.Nanosec); } [Fact] @@ -87,125 +88,125 @@ public void TestPublishArrays() test_msgs.msg.Arrays msg = new test_msgs.msg.Arrays (); test_msgs.msg.Arrays msg2 = new test_msgs.msg.Arrays (); - // bool_values - msg.Bool_values[0] = true; - msg.Bool_values[1] = false; - msg.Bool_values[2] = true; - - // byte_values - msg.Byte_values[0] = 0; - msg.Byte_values[1] = 1; - msg.Byte_values[2] = 2; - - // char_values - msg.Char_values[0] = 3; - msg.Char_values[1] = 4; - msg.Char_values[2] = 5; - - // float32_values - msg.Float32_values[0] = 6.1f; - msg.Float32_values[1] = 7.1f; - msg.Float32_values[2] = 8.1f; - - // float64_values - msg.Float64_values[0] = 9.1; - msg.Float64_values[1] = 10.1; - msg.Float64_values[2] = 11.1; - - // int8_values - msg.Int8_values[0] = 12; - msg.Int8_values[1] = 13; - msg.Int8_values[2] = 14; - - // uint8_values - msg.Uint8_values[0] = 15; - msg.Uint8_values[1] = 16; - msg.Uint8_values[2] = 17; - - // int16_values - msg.Int16_values[0] = 18; - msg.Int16_values[1] = 19; - msg.Int16_values[2] = 20; - - // uint16_values - msg.Uint16_values[0] = 21; - msg.Uint16_values[1] = 22; - msg.Uint16_values[2] = 23; - - // int32_values - msg.Int32_values[0] = 24; - msg.Int32_values[1] = 25; - msg.Int32_values[2] = 26; - - // uint32_values - msg.Uint32_values[0] = 27; - msg.Uint32_values[1] = 28; - msg.Uint32_values[2] = 29; - - // int64_values - msg.Int64_values[0] = 30; - msg.Int64_values[1] = 31; - msg.Int64_values[2] = 32; - - // uint64_values - msg.Uint64_values[0] = 33; - msg.Uint64_values[1] = 34; - msg.Uint64_values[2] = 35; - - // string_values - msg.String_values[0] = "one"; - msg.String_values[1] = "two"; - msg.String_values[2] = "three"; - - // basic_types_values + // boolValues + msg.BoolValues[0] = true; + msg.BoolValues[1] = false; + msg.BoolValues[2] = true; + + // byteValues + msg.ByteValues[0] = 0; + msg.ByteValues[1] = 1; + msg.ByteValues[2] = 2; + + // charValues + msg.CharValues[0] = 3; + msg.CharValues[1] = 4; + msg.CharValues[2] = 5; + + // float32Values + msg.Float32Values[0] = 6.1f; + msg.Float32Values[1] = 7.1f; + msg.Float32Values[2] = 8.1f; + + // float64Values + msg.Float64Values[0] = 9.1; + msg.Float64Values[1] = 10.1; + msg.Float64Values[2] = 11.1; + + // int8Values + msg.Int8Values[0] = 12; + msg.Int8Values[1] = 13; + msg.Int8Values[2] = 14; + + // uint8Values + msg.Uint8Values[0] = 15; + msg.Uint8Values[1] = 16; + msg.Uint8Values[2] = 17; + + // int16Values + msg.Int16Values[0] = 18; + msg.Int16Values[1] = 19; + msg.Int16Values[2] = 20; + + // uint16Values + msg.Uint16Values[0] = 21; + msg.Uint16Values[1] = 22; + msg.Uint16Values[2] = 23; + + // int32Values + msg.Int32Values[0] = 24; + msg.Int32Values[1] = 25; + msg.Int32Values[2] = 26; + + // uint32Values + msg.Uint32Values[0] = 27; + msg.Uint32Values[1] = 28; + msg.Uint32Values[2] = 29; + + // int64Values + msg.Int64Values[0] = 30; + msg.Int64Values[1] = 31; + msg.Int64Values[2] = 32; + + // uint64Values + msg.Uint64Values[0] = 33; + msg.Uint64Values[1] = 34; + msg.Uint64Values[2] = 35; + + // stringValues + msg.StringValues[0] = "one"; + msg.StringValues[1] = "two"; + msg.StringValues[2] = "three"; + + // basicTypesValues test_msgs.msg.BasicTypes basic_type_1 = new test_msgs.msg.BasicTypes(); - basic_type_1.Bool_value = true; - basic_type_1.Byte_value = 36; - basic_type_1.Char_value = 37; - basic_type_1.Float32_value = 38.1f; - basic_type_1.Float64_value = 39.1; - basic_type_1.Int8_value = 40; - basic_type_1.Uint8_value = 41; - basic_type_1.Int16_value = 42; - basic_type_1.Uint16_value = 43; - basic_type_1.Int32_value = 44; - basic_type_1.Uint32_value = 45; - basic_type_1.Int64_value = 46; - basic_type_1.Uint64_value = 47; + basic_type_1.BoolValue = true; + basic_type_1.ByteValue = 36; + basic_type_1.CharValue = 37; + basic_type_1.Float32Value = 38.1f; + basic_type_1.Float64Value = 39.1; + basic_type_1.Int8Value = 40; + basic_type_1.Uint8Value = 41; + basic_type_1.Int16Value = 42; + basic_type_1.Uint16Value = 43; + basic_type_1.Int32Value = 44; + basic_type_1.Uint32Value = 45; + basic_type_1.Int64Value = 46; + basic_type_1.Uint64Value = 47; test_msgs.msg.BasicTypes basic_type_2 = new test_msgs.msg.BasicTypes(); - basic_type_2.Bool_value = false; - basic_type_2.Byte_value = 48; - basic_type_2.Char_value = 49; - basic_type_2.Float32_value = 50.1f; - basic_type_2.Float64_value = 51.1; - basic_type_2.Int8_value = 52; - basic_type_2.Uint8_value = 53; - basic_type_2.Int16_value = 54; - basic_type_2.Uint16_value = 55; - basic_type_2.Int32_value = 56; - basic_type_2.Uint32_value = 57; - basic_type_2.Int64_value = 58; - basic_type_2.Uint64_value = 59; + basic_type_2.BoolValue = false; + basic_type_2.ByteValue = 48; + basic_type_2.CharValue = 49; + basic_type_2.Float32Value = 50.1f; + basic_type_2.Float64Value = 51.1; + basic_type_2.Int8Value = 52; + basic_type_2.Uint8Value = 53; + basic_type_2.Int16Value = 54; + basic_type_2.Uint16Value = 55; + basic_type_2.Int32Value = 56; + basic_type_2.Uint32Value = 57; + basic_type_2.Int64Value = 58; + basic_type_2.Uint64Value = 59; test_msgs.msg.BasicTypes basic_type_3 = new test_msgs.msg.BasicTypes(); - basic_type_3.Bool_value = true; - basic_type_3.Byte_value = 60; - basic_type_3.Char_value = 61; - basic_type_3.Float32_value = 62.1f; - basic_type_3.Float64_value = 63.1; - basic_type_3.Int8_value = 64; - basic_type_3.Uint8_value = 65; - basic_type_3.Int16_value = 66; - basic_type_3.Uint16_value = 67; - basic_type_3.Int32_value = 68; - basic_type_3.Uint32_value = 69; - basic_type_3.Int64_value = 70; - basic_type_3.Uint64_value = 71; - - msg.Basic_types_values[0] = basic_type_1; - msg.Basic_types_values[1] = basic_type_2; - msg.Basic_types_values[2] = basic_type_3; + basic_type_3.BoolValue = true; + basic_type_3.ByteValue = 60; + basic_type_3.CharValue = 61; + basic_type_3.Float32Value = 62.1f; + basic_type_3.Float64Value = 63.1; + basic_type_3.Int8Value = 64; + basic_type_3.Uint8Value = 65; + basic_type_3.Int16Value = 66; + basic_type_3.Uint16Value = 67; + basic_type_3.Int32Value = 68; + basic_type_3.Uint32Value = 69; + basic_type_3.Int64Value = 70; + basic_type_3.Uint64Value = 71; + + msg.BasicTypesValues[0] = basic_type_1; + msg.BasicTypesValues[1] = basic_type_2; + msg.BasicTypesValues[2] = basic_type_3; bool received=false; Subscription chatter_sub = node_array_2.CreateSubscription ( @@ -224,149 +225,149 @@ public void TestPublishArrays() RCLdotnet.SpinOnce(node_array_2, 500); } - // bool_values - Assert.Equal(3, test_msgs.msg.Arrays.Bool_values_Length); - Assert.Equal(3, msg2.Bool_values.Length); - Assert.True(msg2.Bool_values[0]); - Assert.False(msg2.Bool_values[1]); - Assert.True(msg2.Bool_values[2]); - - // byte_values - Assert.Equal(3, test_msgs.msg.Arrays.Byte_values_Length); - Assert.Equal(3, msg2.Byte_values.Length); - Assert.Equal(0, msg2.Byte_values[0]); - Assert.Equal(1, msg2.Byte_values[1]); - Assert.Equal(2, msg2.Byte_values[2]); - - // char_values - Assert.Equal(3, test_msgs.msg.Arrays.Char_values_Length); - Assert.Equal(3, msg2.Char_values.Length); - Assert.Equal(3, msg2.Char_values[0]); - Assert.Equal(4, msg2.Char_values[1]); - Assert.Equal(5, msg2.Char_values[2]); - - // float32_values - Assert.Equal(3, test_msgs.msg.Arrays.Float32_values_Length); - Assert.Equal(3, msg2.Float32_values.Length); - Assert.Equal(6.1f, msg2.Float32_values[0]); - Assert.Equal(7.1f, msg2.Float32_values[1]); - Assert.Equal(8.1f, msg2.Float32_values[2]); - - // float64_values - Assert.Equal(3, test_msgs.msg.Arrays.Float64_values_Length); - Assert.Equal(3, msg2.Float64_values.Length); - Assert.Equal(9.1, msg2.Float64_values[0]); - Assert.Equal(10.1, msg2.Float64_values[1]); - Assert.Equal(11.1, msg2.Float64_values[2]); - - // int8_values - Assert.Equal(3, test_msgs.msg.Arrays.Int8_values_Length); - Assert.Equal(3, msg2.Int8_values.Length); - Assert.Equal(12, msg2.Int8_values[0]); - Assert.Equal(13, msg2.Int8_values[1]); - Assert.Equal(14, msg2.Int8_values[2]); - - // uint8_values - Assert.Equal(3, test_msgs.msg.Arrays.Uint8_values_Length); - Assert.Equal(3, msg2.Uint8_values.Length); - Assert.Equal(15, msg2.Uint8_values[0]); - Assert.Equal(16, msg2.Uint8_values[1]); - Assert.Equal(17, msg2.Uint8_values[2]); - - // int16_values - Assert.Equal(3, test_msgs.msg.Arrays.Int16_values_Length); - Assert.Equal(3, msg2.Int16_values.Length); - Assert.Equal(18, msg2.Int16_values[0]); - Assert.Equal(19, msg2.Int16_values[1]); - Assert.Equal(20, msg2.Int16_values[2]); - - // uint16_values - Assert.Equal(3, test_msgs.msg.Arrays.Uint16_values_Length); - Assert.Equal(3, msg2.Uint16_values.Length); - Assert.Equal(21, msg2.Uint16_values[0]); - Assert.Equal(22, msg2.Uint16_values[1]); - Assert.Equal(23, msg2.Uint16_values[2]); - - // int32_values - Assert.Equal(3, test_msgs.msg.Arrays.Int32_values_Length); - Assert.Equal(3, msg2.Int32_values.Length); - Assert.Equal(24, msg2.Int32_values[0]); - Assert.Equal(25, msg2.Int32_values[1]); - Assert.Equal(26, msg2.Int32_values[2]); - - // uint32_values - Assert.Equal(3, test_msgs.msg.Arrays.Uint32_values_Length); - Assert.Equal(3, msg2.Uint32_values.Length); - Assert.Equal((uint)27, msg2.Uint32_values[0]); - Assert.Equal((uint)28, msg2.Uint32_values[1]); - Assert.Equal((uint)29, msg2.Uint32_values[2]); - - // int64_values - Assert.Equal(3, test_msgs.msg.Arrays.Int64_values_Length); - Assert.Equal(3, msg2.Int64_values.Length); - Assert.Equal(30, msg2.Int64_values[0]); - Assert.Equal(31, msg2.Int64_values[1]); - Assert.Equal(32, msg2.Int64_values[2]); - - // uint64_values - Assert.Equal(3, test_msgs.msg.Arrays.Uint64_values_Length); - Assert.Equal(3, msg2.Uint64_values.Length); - Assert.Equal((ulong)33, msg2.Uint64_values[0]); - Assert.Equal((ulong)34, msg2.Uint64_values[1]); - Assert.Equal((ulong)35, msg2.Uint64_values[2]); - - // string_values - Assert.Equal(3, test_msgs.msg.Arrays.String_values_Length); - Assert.Equal(3, msg2.String_values.Length); - Assert.Equal("one", msg2.String_values[0]); - Assert.Equal("two", msg2.String_values[1]); - Assert.Equal("three", msg2.String_values[2]); - - // basic_types_values - Assert.Equal(3, test_msgs.msg.Arrays.Basic_types_values_Length); - Assert.Equal(3, msg2.Basic_types_values.Length); - - Assert.True(msg2.Basic_types_values[0].Bool_value); - Assert.Equal(36, msg2.Basic_types_values[0].Byte_value); - Assert.Equal(37, msg2.Basic_types_values[0].Char_value); - Assert.Equal(38.1f, msg2.Basic_types_values[0].Float32_value); - Assert.Equal(39.1, msg2.Basic_types_values[0].Float64_value); - Assert.Equal(40, msg2.Basic_types_values[0].Int8_value); - Assert.Equal(41, msg2.Basic_types_values[0].Uint8_value); - Assert.Equal(42, msg2.Basic_types_values[0].Int16_value); - Assert.Equal(43, msg2.Basic_types_values[0].Uint16_value); - Assert.Equal(44, msg2.Basic_types_values[0].Int32_value); - Assert.Equal((uint)45, msg2.Basic_types_values[0].Uint32_value); - Assert.Equal(46, msg2.Basic_types_values[0].Int64_value); - Assert.Equal((ulong)47, msg2.Basic_types_values[0].Uint64_value); - - Assert.False(msg2.Basic_types_values[1].Bool_value); - Assert.Equal(48, msg2.Basic_types_values[1].Byte_value); - Assert.Equal(49, msg2.Basic_types_values[1].Char_value); - Assert.Equal(50.1f, msg2.Basic_types_values[1].Float32_value); - Assert.Equal(51.1, msg2.Basic_types_values[1].Float64_value); - Assert.Equal(52, msg2.Basic_types_values[1].Int8_value); - Assert.Equal(53, msg2.Basic_types_values[1].Uint8_value); - Assert.Equal(54, msg2.Basic_types_values[1].Int16_value); - Assert.Equal(55, msg2.Basic_types_values[1].Uint16_value); - Assert.Equal(56, msg2.Basic_types_values[1].Int32_value); - Assert.Equal((uint)57, msg2.Basic_types_values[1].Uint32_value); - Assert.Equal(58, msg2.Basic_types_values[1].Int64_value); - Assert.Equal((ulong)59, msg2.Basic_types_values[1].Uint64_value); - - Assert.True(msg2.Basic_types_values[2].Bool_value); - Assert.Equal(60, msg2.Basic_types_values[2].Byte_value); - Assert.Equal(61, msg2.Basic_types_values[2].Char_value); - Assert.Equal(62.1f, msg2.Basic_types_values[2].Float32_value); - Assert.Equal(63.1, msg2.Basic_types_values[2].Float64_value); - Assert.Equal(64, msg2.Basic_types_values[2].Int8_value); - Assert.Equal(65, msg2.Basic_types_values[2].Uint8_value); - Assert.Equal(66, msg2.Basic_types_values[2].Int16_value); - Assert.Equal(67, msg2.Basic_types_values[2].Uint16_value); - Assert.Equal(68, msg2.Basic_types_values[2].Int32_value); - Assert.Equal((uint)69, msg2.Basic_types_values[2].Uint32_value); - Assert.Equal(70, msg2.Basic_types_values[2].Int64_value); - Assert.Equal((ulong)71, msg2.Basic_types_values[2].Uint64_value); + // boolValues + Assert.Equal(3, test_msgs.msg.Arrays.BoolValuesLength); + Assert.Equal(3, msg2.BoolValues.Length); + Assert.True(msg2.BoolValues[0]); + Assert.False(msg2.BoolValues[1]); + Assert.True(msg2.BoolValues[2]); + + // byteValues + Assert.Equal(3, test_msgs.msg.Arrays.ByteValuesLength); + Assert.Equal(3, msg2.ByteValues.Length); + Assert.Equal(0, msg2.ByteValues[0]); + Assert.Equal(1, msg2.ByteValues[1]); + Assert.Equal(2, msg2.ByteValues[2]); + + // charValues + Assert.Equal(3, test_msgs.msg.Arrays.CharValuesLength); + Assert.Equal(3, msg2.CharValues.Length); + Assert.Equal(3, msg2.CharValues[0]); + Assert.Equal(4, msg2.CharValues[1]); + Assert.Equal(5, msg2.CharValues[2]); + + // float32Values + Assert.Equal(3, test_msgs.msg.Arrays.Float32ValuesLength); + Assert.Equal(3, msg2.Float32Values.Length); + Assert.Equal(6.1f, msg2.Float32Values[0]); + Assert.Equal(7.1f, msg2.Float32Values[1]); + Assert.Equal(8.1f, msg2.Float32Values[2]); + + // float64Values + Assert.Equal(3, test_msgs.msg.Arrays.Float64ValuesLength); + Assert.Equal(3, msg2.Float64Values.Length); + Assert.Equal(9.1, msg2.Float64Values[0]); + Assert.Equal(10.1, msg2.Float64Values[1]); + Assert.Equal(11.1, msg2.Float64Values[2]); + + // int8Values + Assert.Equal(3, test_msgs.msg.Arrays.Int8ValuesLength); + Assert.Equal(3, msg2.Int8Values.Length); + Assert.Equal(12, msg2.Int8Values[0]); + Assert.Equal(13, msg2.Int8Values[1]); + Assert.Equal(14, msg2.Int8Values[2]); + + // uint8Values + Assert.Equal(3, test_msgs.msg.Arrays.Uint8ValuesLength); + Assert.Equal(3, msg2.Uint8Values.Length); + Assert.Equal(15, msg2.Uint8Values[0]); + Assert.Equal(16, msg2.Uint8Values[1]); + Assert.Equal(17, msg2.Uint8Values[2]); + + // int16Values + Assert.Equal(3, test_msgs.msg.Arrays.Int16ValuesLength); + Assert.Equal(3, msg2.Int16Values.Length); + Assert.Equal(18, msg2.Int16Values[0]); + Assert.Equal(19, msg2.Int16Values[1]); + Assert.Equal(20, msg2.Int16Values[2]); + + // uint16Values + Assert.Equal(3, test_msgs.msg.Arrays.Uint16ValuesLength); + Assert.Equal(3, msg2.Uint16Values.Length); + Assert.Equal(21, msg2.Uint16Values[0]); + Assert.Equal(22, msg2.Uint16Values[1]); + Assert.Equal(23, msg2.Uint16Values[2]); + + // int32Values + Assert.Equal(3, test_msgs.msg.Arrays.Int32ValuesLength); + Assert.Equal(3, msg2.Int32Values.Length); + Assert.Equal(24, msg2.Int32Values[0]); + Assert.Equal(25, msg2.Int32Values[1]); + Assert.Equal(26, msg2.Int32Values[2]); + + // uint32Values + Assert.Equal(3, test_msgs.msg.Arrays.Uint32ValuesLength); + Assert.Equal(3, msg2.Uint32Values.Length); + Assert.Equal((uint)27, msg2.Uint32Values[0]); + Assert.Equal((uint)28, msg2.Uint32Values[1]); + Assert.Equal((uint)29, msg2.Uint32Values[2]); + + // int64Values + Assert.Equal(3, test_msgs.msg.Arrays.Int64ValuesLength); + Assert.Equal(3, msg2.Int64Values.Length); + Assert.Equal(30, msg2.Int64Values[0]); + Assert.Equal(31, msg2.Int64Values[1]); + Assert.Equal(32, msg2.Int64Values[2]); + + // uint64Values + Assert.Equal(3, test_msgs.msg.Arrays.Uint64ValuesLength); + Assert.Equal(3, msg2.Uint64Values.Length); + Assert.Equal((ulong)33, msg2.Uint64Values[0]); + Assert.Equal((ulong)34, msg2.Uint64Values[1]); + Assert.Equal((ulong)35, msg2.Uint64Values[2]); + + // stringValues + Assert.Equal(3, test_msgs.msg.Arrays.StringValuesLength); + Assert.Equal(3, msg2.StringValues.Length); + Assert.Equal("one", msg2.StringValues[0]); + Assert.Equal("two", msg2.StringValues[1]); + Assert.Equal("three", msg2.StringValues[2]); + + // basicTypesValues + Assert.Equal(3, test_msgs.msg.Arrays.BasicTypesValuesLength); + Assert.Equal(3, msg2.BasicTypesValues.Length); + + Assert.True(msg2.BasicTypesValues[0].BoolValue); + Assert.Equal(36, msg2.BasicTypesValues[0].ByteValue); + Assert.Equal(37, msg2.BasicTypesValues[0].CharValue); + Assert.Equal(38.1f, msg2.BasicTypesValues[0].Float32Value); + Assert.Equal(39.1, msg2.BasicTypesValues[0].Float64Value); + Assert.Equal(40, msg2.BasicTypesValues[0].Int8Value); + Assert.Equal(41, msg2.BasicTypesValues[0].Uint8Value); + Assert.Equal(42, msg2.BasicTypesValues[0].Int16Value); + Assert.Equal(43, msg2.BasicTypesValues[0].Uint16Value); + Assert.Equal(44, msg2.BasicTypesValues[0].Int32Value); + Assert.Equal((uint)45, msg2.BasicTypesValues[0].Uint32Value); + Assert.Equal(46, msg2.BasicTypesValues[0].Int64Value); + Assert.Equal((ulong)47, msg2.BasicTypesValues[0].Uint64Value); + + Assert.False(msg2.BasicTypesValues[1].BoolValue); + Assert.Equal(48, msg2.BasicTypesValues[1].ByteValue); + Assert.Equal(49, msg2.BasicTypesValues[1].CharValue); + Assert.Equal(50.1f, msg2.BasicTypesValues[1].Float32Value); + Assert.Equal(51.1, msg2.BasicTypesValues[1].Float64Value); + Assert.Equal(52, msg2.BasicTypesValues[1].Int8Value); + Assert.Equal(53, msg2.BasicTypesValues[1].Uint8Value); + Assert.Equal(54, msg2.BasicTypesValues[1].Int16Value); + Assert.Equal(55, msg2.BasicTypesValues[1].Uint16Value); + Assert.Equal(56, msg2.BasicTypesValues[1].Int32Value); + Assert.Equal((uint)57, msg2.BasicTypesValues[1].Uint32Value); + Assert.Equal(58, msg2.BasicTypesValues[1].Int64Value); + Assert.Equal((ulong)59, msg2.BasicTypesValues[1].Uint64Value); + + Assert.True(msg2.BasicTypesValues[2].BoolValue); + Assert.Equal(60, msg2.BasicTypesValues[2].ByteValue); + Assert.Equal(61, msg2.BasicTypesValues[2].CharValue); + Assert.Equal(62.1f, msg2.BasicTypesValues[2].Float32Value); + Assert.Equal(63.1, msg2.BasicTypesValues[2].Float64Value); + Assert.Equal(64, msg2.BasicTypesValues[2].Int8Value); + Assert.Equal(65, msg2.BasicTypesValues[2].Uint8Value); + Assert.Equal(66, msg2.BasicTypesValues[2].Int16Value); + Assert.Equal(67, msg2.BasicTypesValues[2].Uint16Value); + Assert.Equal(68, msg2.BasicTypesValues[2].Int32Value); + Assert.Equal((uint)69, msg2.BasicTypesValues[2].Uint32Value); + Assert.Equal(70, msg2.BasicTypesValues[2].Int64Value); + Assert.Equal((ulong)71, msg2.BasicTypesValues[2].Uint64Value); } [Fact] @@ -377,14 +378,14 @@ public void TestPublishArraysSizeCheckToLittle() var chatterPub = nodeArraysSizeCheck.CreatePublisher("topic_array_size_check_to_little"); var msg = new test_msgs.msg.Arrays(); - msg.Bool_values = new bool[] + msg.BoolValues = new bool[] { false, true, }; var exception = Assert.Throws(() => chatterPub.Publish(msg)); - Assert.Equal("Invalid size of array 'Bool_values'.", exception.Message); + Assert.Equal("Invalid size of array 'BoolValues'.", exception.Message); } [Fact] @@ -395,7 +396,7 @@ public void TestPublishArraysSizeCheckToMuch() var chatterPub = nodeArraysSizeCheck.CreatePublisher("topic_array_size_check_to_much"); var msg = new test_msgs.msg.Arrays(); - msg.String_values = new string[] + msg.StringValues = new string[] { "0", "1", @@ -404,7 +405,7 @@ public void TestPublishArraysSizeCheckToMuch() }; var exception = Assert.Throws(() => chatterPub.Publish(msg)); - Assert.Equal("Invalid size of array 'String_values'.", exception.Message); + Assert.Equal("Invalid size of array 'StringValues'.", exception.Message); } [Fact] @@ -418,124 +419,124 @@ public void TestPublishUnboundedSequences() test_msgs.msg.UnboundedSequences msg = new test_msgs.msg.UnboundedSequences(); test_msgs.msg.UnboundedSequences msg2 = new test_msgs.msg.UnboundedSequences(); - // bool_values - msg.Bool_values.Add(true); - msg.Bool_values.Add(false); - msg.Bool_values.Add(true); - - // byte_values - msg.Byte_values.Add(0); - msg.Byte_values.Add(1); - msg.Byte_values.Add(2); - - // char_values - msg.Char_values.Add(3); - msg.Char_values.Add(4); - msg.Char_values.Add(5); - - // float32_values - msg.Float32_values.Add(6.1f); - msg.Float32_values.Add(7.1f); - msg.Float32_values.Add(8.1f); - - // float64_values - msg.Float64_values.Add(9.1); - msg.Float64_values.Add(10.1); - msg.Float64_values.Add(11.1); - - // int8_values - msg.Int8_values.Add(12); - msg.Int8_values.Add(13); - msg.Int8_values.Add(14); - - // uint8_values - msg.Uint8_values.Add(15); - msg.Uint8_values.Add(16); - msg.Uint8_values.Add(17); - - // int16_values - msg.Int16_values.Add(18); - msg.Int16_values.Add(19); - msg.Int16_values.Add(20); - - // uint16_values - msg.Uint16_values.Add(21); - msg.Uint16_values.Add(22); - msg.Uint16_values.Add(23); - - // int32_values - msg.Int32_values.Add(24); - msg.Int32_values.Add(25); - msg.Int32_values.Add(26); - - // uint32_values - msg.Uint32_values.Add(27); - msg.Uint32_values.Add(28); - msg.Uint32_values.Add(29); - - // int64_values - msg.Int64_values.Add(30); - msg.Int64_values.Add(31); - msg.Int64_values.Add(32); - - // uint64_values - msg.Uint64_values.Add(33); - msg.Uint64_values.Add(34); - msg.Uint64_values.Add(35); - - // string_values - msg.String_values.Add("one"); - msg.String_values.Add("two"); - msg.String_values.Add("three"); + // boolValues + msg.BoolValues.Add(true); + msg.BoolValues.Add(false); + msg.BoolValues.Add(true); + + // byteValues + msg.ByteValues.Add(0); + msg.ByteValues.Add(1); + msg.ByteValues.Add(2); + + // charValues + msg.CharValues.Add(3); + msg.CharValues.Add(4); + msg.CharValues.Add(5); + + // float32Values + msg.Float32Values.Add(6.1f); + msg.Float32Values.Add(7.1f); + msg.Float32Values.Add(8.1f); + + // float64Values + msg.Float64Values.Add(9.1); + msg.Float64Values.Add(10.1); + msg.Float64Values.Add(11.1); + + // int8Values + msg.Int8Values.Add(12); + msg.Int8Values.Add(13); + msg.Int8Values.Add(14); + + // uint8Values + msg.Uint8Values.Add(15); + msg.Uint8Values.Add(16); + msg.Uint8Values.Add(17); + + // int16Values + msg.Int16Values.Add(18); + msg.Int16Values.Add(19); + msg.Int16Values.Add(20); + + // uint16Values + msg.Uint16Values.Add(21); + msg.Uint16Values.Add(22); + msg.Uint16Values.Add(23); + + // int32Values + msg.Int32Values.Add(24); + msg.Int32Values.Add(25); + msg.Int32Values.Add(26); + + // uint32Values + msg.Uint32Values.Add(27); + msg.Uint32Values.Add(28); + msg.Uint32Values.Add(29); + + // int64Values + msg.Int64Values.Add(30); + msg.Int64Values.Add(31); + msg.Int64Values.Add(32); + + // uint64Values + msg.Uint64Values.Add(33); + msg.Uint64Values.Add(34); + msg.Uint64Values.Add(35); + + // stringValues + msg.StringValues.Add("one"); + msg.StringValues.Add("two"); + msg.StringValues.Add("three"); test_msgs.msg.BasicTypes basic_type_1 = new test_msgs.msg.BasicTypes(); - basic_type_1.Bool_value = true; - basic_type_1.Byte_value = 36; - basic_type_1.Char_value = 37; - basic_type_1.Float32_value = 38.1f; - basic_type_1.Float64_value = 39.1; - basic_type_1.Int8_value = 40; - basic_type_1.Uint8_value = 41; - basic_type_1.Int16_value = 42; - basic_type_1.Uint16_value = 43; - basic_type_1.Int32_value = 44; - basic_type_1.Uint32_value = 45; - basic_type_1.Int64_value = 46; - basic_type_1.Uint64_value = 47; + basic_type_1.BoolValue = true; + basic_type_1.ByteValue = 36; + basic_type_1.CharValue = 37; + basic_type_1.Float32Value = 38.1f; + basic_type_1.Float64Value = 39.1; + basic_type_1.Int8Value = 40; + basic_type_1.Uint8Value = 41; + basic_type_1.Int16Value = 42; + basic_type_1.Uint16Value = 43; + basic_type_1.Int32Value = 44; + basic_type_1.Uint32Value = 45; + basic_type_1.Int64Value = 46; + basic_type_1.Uint64Value = 47; test_msgs.msg.BasicTypes basic_type_2 = new test_msgs.msg.BasicTypes(); - basic_type_2.Bool_value = false; - basic_type_2.Byte_value = 48; - basic_type_2.Char_value = 49; - basic_type_2.Float32_value = 50.1f; - basic_type_2.Float64_value = 51.1; - basic_type_2.Int8_value = 52; - basic_type_2.Uint8_value = 53; - basic_type_2.Int16_value = 54; - basic_type_2.Uint16_value = 55; - basic_type_2.Int32_value = 56; - basic_type_2.Uint32_value = 57; - basic_type_2.Int64_value = 58; - basic_type_2.Uint64_value = 59; + basic_type_2.BoolValue = false; + basic_type_2.ByteValue = 48; + basic_type_2.CharValue = 49; + basic_type_2.Float32Value = 50.1f; + basic_type_2.Float64Value = 51.1; + basic_type_2.Int8Value = 52; + basic_type_2.Uint8Value = 53; + basic_type_2.Int16Value = 54; + basic_type_2.Uint16Value = 55; + basic_type_2.Int32Value = 56; + basic_type_2.Uint32Value = 57; + basic_type_2.Int64Value = 58; + basic_type_2.Uint64Value = 59; test_msgs.msg.BasicTypes basic_type_3 = new test_msgs.msg.BasicTypes(); - basic_type_3.Bool_value = true; - basic_type_3.Byte_value = 60; - basic_type_3.Char_value = 61; - basic_type_3.Float32_value = 62.1f; - basic_type_3.Float64_value = 63.1; - basic_type_3.Int8_value = 64; - basic_type_3.Uint8_value = 65; - basic_type_3.Int16_value = 66; - basic_type_3.Uint16_value = 67; - basic_type_3.Int32_value = 68; - basic_type_3.Uint32_value = 69; - basic_type_3.Int64_value = 70; - basic_type_3.Uint64_value = 71; - - msg.Basic_types_values.Add(basic_type_1); - msg.Basic_types_values.Add(basic_type_2); - msg.Basic_types_values.Add(basic_type_3); + basic_type_3.BoolValue = true; + basic_type_3.ByteValue = 60; + basic_type_3.CharValue = 61; + basic_type_3.Float32Value = 62.1f; + basic_type_3.Float64Value = 63.1; + basic_type_3.Int8Value = 64; + basic_type_3.Uint8Value = 65; + basic_type_3.Int16Value = 66; + basic_type_3.Uint16Value = 67; + basic_type_3.Int32Value = 68; + basic_type_3.Uint32Value = 69; + basic_type_3.Int64Value = 70; + basic_type_3.Uint64Value = 71; + + msg.BasicTypesValues.Add(basic_type_1); + msg.BasicTypesValues.Add(basic_type_2); + msg.BasicTypesValues.Add(basic_type_3); bool received=false; Subscription chatter_sub = node_array_2.CreateSubscription( @@ -554,132 +555,132 @@ public void TestPublishUnboundedSequences() RCLdotnet.SpinOnce(node_array_2, 500); } - // bool_values - Assert.Equal(3, msg2.Bool_values.Count); - Assert.True(msg2.Bool_values[0]); - Assert.False(msg2.Bool_values[1]); - Assert.True(msg2.Bool_values[2]); - - // byte_values - Assert.Equal(3, msg2.Byte_values.Count); - Assert.Equal(0, msg2.Byte_values[0]); - Assert.Equal(1, msg2.Byte_values[1]); - Assert.Equal(2, msg2.Byte_values[2]); - - // char_values - Assert.Equal(3, msg2.Char_values.Count); - Assert.Equal(3, msg2.Char_values[0]); - Assert.Equal(4, msg2.Char_values[1]); - Assert.Equal(5, msg2.Char_values[2]); - - // float32_values - Assert.Equal(3, msg2.Float32_values.Count); - Assert.Equal(6.1f, msg2.Float32_values[0]); - Assert.Equal(7.1f, msg2.Float32_values[1]); - Assert.Equal(8.1f, msg2.Float32_values[2]); - - // float64_values - Assert.Equal(3, msg2.Float64_values.Count); - Assert.Equal(9.1, msg2.Float64_values[0]); - Assert.Equal(10.1, msg2.Float64_values[1]); - Assert.Equal(11.1, msg2.Float64_values[2]); - - // int8_values - Assert.Equal(3, msg2.Int8_values.Count); - Assert.Equal(12, msg2.Int8_values[0]); - Assert.Equal(13, msg2.Int8_values[1]); - Assert.Equal(14, msg2.Int8_values[2]); - - // uint8_values - Assert.Equal(3, msg2.Uint8_values.Count); - Assert.Equal(15, msg2.Uint8_values[0]); - Assert.Equal(16, msg2.Uint8_values[1]); - Assert.Equal(17, msg2.Uint8_values[2]); - - // int16_values - Assert.Equal(3, msg2.Int16_values.Count); - Assert.Equal(18, msg2.Int16_values[0]); - Assert.Equal(19, msg2.Int16_values[1]); - Assert.Equal(20, msg2.Int16_values[2]); - - // uint16_values - Assert.Equal(3, msg2.Uint16_values.Count); - Assert.Equal(21, msg2.Uint16_values[0]); - Assert.Equal(22, msg2.Uint16_values[1]); - Assert.Equal(23, msg2.Uint16_values[2]); - - // int32_values - Assert.Equal(3, msg2.Int32_values.Count); - Assert.Equal(24, msg2.Int32_values[0]); - Assert.Equal(25, msg2.Int32_values[1]); - Assert.Equal(26, msg2.Int32_values[2]); + // boolValues + Assert.Equal(3, msg2.BoolValues.Count); + Assert.True(msg2.BoolValues[0]); + Assert.False(msg2.BoolValues[1]); + Assert.True(msg2.BoolValues[2]); + + // byteValues + Assert.Equal(3, msg2.ByteValues.Count); + Assert.Equal(0, msg2.ByteValues[0]); + Assert.Equal(1, msg2.ByteValues[1]); + Assert.Equal(2, msg2.ByteValues[2]); + + // charValues + Assert.Equal(3, msg2.CharValues.Count); + Assert.Equal(3, msg2.CharValues[0]); + Assert.Equal(4, msg2.CharValues[1]); + Assert.Equal(5, msg2.CharValues[2]); + + // float32Values + Assert.Equal(3, msg2.Float32Values.Count); + Assert.Equal(6.1f, msg2.Float32Values[0]); + Assert.Equal(7.1f, msg2.Float32Values[1]); + Assert.Equal(8.1f, msg2.Float32Values[2]); + + // float64Values + Assert.Equal(3, msg2.Float64Values.Count); + Assert.Equal(9.1, msg2.Float64Values[0]); + Assert.Equal(10.1, msg2.Float64Values[1]); + Assert.Equal(11.1, msg2.Float64Values[2]); + + // int8Values + Assert.Equal(3, msg2.Int8Values.Count); + Assert.Equal(12, msg2.Int8Values[0]); + Assert.Equal(13, msg2.Int8Values[1]); + Assert.Equal(14, msg2.Int8Values[2]); + + // uint8Values + Assert.Equal(3, msg2.Uint8Values.Count); + Assert.Equal(15, msg2.Uint8Values[0]); + Assert.Equal(16, msg2.Uint8Values[1]); + Assert.Equal(17, msg2.Uint8Values[2]); + + // int16Values + Assert.Equal(3, msg2.Int16Values.Count); + Assert.Equal(18, msg2.Int16Values[0]); + Assert.Equal(19, msg2.Int16Values[1]); + Assert.Equal(20, msg2.Int16Values[2]); + + // uint16Values + Assert.Equal(3, msg2.Uint16Values.Count); + Assert.Equal(21, msg2.Uint16Values[0]); + Assert.Equal(22, msg2.Uint16Values[1]); + Assert.Equal(23, msg2.Uint16Values[2]); + + // int32Values + Assert.Equal(3, msg2.Int32Values.Count); + Assert.Equal(24, msg2.Int32Values[0]); + Assert.Equal(25, msg2.Int32Values[1]); + Assert.Equal(26, msg2.Int32Values[2]); - // uint32_values - Assert.Equal(3, msg2.Uint32_values.Count); - Assert.Equal((uint)27, msg2.Uint32_values[0]); - Assert.Equal((uint)28, msg2.Uint32_values[1]); - Assert.Equal((uint)29, msg2.Uint32_values[2]); - - // int64_values - Assert.Equal(3, msg2.Int64_values.Count); - Assert.Equal(30, msg2.Int64_values[0]); - Assert.Equal(31, msg2.Int64_values[1]); - Assert.Equal(32, msg2.Int64_values[2]); + // uint32Values + Assert.Equal(3, msg2.Uint32Values.Count); + Assert.Equal((uint)27, msg2.Uint32Values[0]); + Assert.Equal((uint)28, msg2.Uint32Values[1]); + Assert.Equal((uint)29, msg2.Uint32Values[2]); + + // int64Values + Assert.Equal(3, msg2.Int64Values.Count); + Assert.Equal(30, msg2.Int64Values[0]); + Assert.Equal(31, msg2.Int64Values[1]); + Assert.Equal(32, msg2.Int64Values[2]); - // uint64_values - Assert.Equal(3, msg2.Uint64_values.Count); - Assert.Equal((ulong)33, msg2.Uint64_values[0]); - Assert.Equal((ulong)34, msg2.Uint64_values[1]); - Assert.Equal((ulong)35, msg2.Uint64_values[2]); - - // string_values - Assert.Equal(3, msg2.String_values.Count); - Assert.Equal("one", msg2.String_values[0]); - Assert.Equal("two", msg2.String_values[1]); - Assert.Equal("three", msg2.String_values[2]); + // uint64Values + Assert.Equal(3, msg2.Uint64Values.Count); + Assert.Equal((ulong)33, msg2.Uint64Values[0]); + Assert.Equal((ulong)34, msg2.Uint64Values[1]); + Assert.Equal((ulong)35, msg2.Uint64Values[2]); + + // stringValues + Assert.Equal(3, msg2.StringValues.Count); + Assert.Equal("one", msg2.StringValues[0]); + Assert.Equal("two", msg2.StringValues[1]); + Assert.Equal("three", msg2.StringValues[2]); - Assert.Equal(3, msg2.Basic_types_values.Count); - Assert.True(msg2.Basic_types_values[0].Bool_value); - Assert.Equal(36, msg2.Basic_types_values[0].Byte_value); - Assert.Equal(37, msg2.Basic_types_values[0].Char_value); - Assert.Equal(38.1f, msg2.Basic_types_values[0].Float32_value); - Assert.Equal(39.1, msg2.Basic_types_values[0].Float64_value); - Assert.Equal(40, msg2.Basic_types_values[0].Int8_value); - Assert.Equal(41, msg2.Basic_types_values[0].Uint8_value); - Assert.Equal(42, msg2.Basic_types_values[0].Int16_value); - Assert.Equal(43, msg2.Basic_types_values[0].Uint16_value); - Assert.Equal(44, msg2.Basic_types_values[0].Int32_value); - Assert.Equal((uint)45, msg2.Basic_types_values[0].Uint32_value); - Assert.Equal(46, msg2.Basic_types_values[0].Int64_value); - Assert.Equal((ulong)47, msg2.Basic_types_values[0].Uint64_value); - - Assert.False(msg2.Basic_types_values[1].Bool_value); - Assert.Equal(48, msg2.Basic_types_values[1].Byte_value); - Assert.Equal(49, msg2.Basic_types_values[1].Char_value); - Assert.Equal(50.1f, msg2.Basic_types_values[1].Float32_value); - Assert.Equal(51.1, msg2.Basic_types_values[1].Float64_value); - Assert.Equal(52, msg2.Basic_types_values[1].Int8_value); - Assert.Equal(53, msg2.Basic_types_values[1].Uint8_value); - Assert.Equal(54, msg2.Basic_types_values[1].Int16_value); - Assert.Equal(55, msg2.Basic_types_values[1].Uint16_value); - Assert.Equal(56, msg2.Basic_types_values[1].Int32_value); - Assert.Equal((uint)57, msg2.Basic_types_values[1].Uint32_value); - Assert.Equal(58, msg2.Basic_types_values[1].Int64_value); - Assert.Equal((ulong)59, msg2.Basic_types_values[1].Uint64_value); + Assert.Equal(3, msg2.BasicTypesValues.Count); + Assert.True(msg2.BasicTypesValues[0].BoolValue); + Assert.Equal(36, msg2.BasicTypesValues[0].ByteValue); + Assert.Equal(37, msg2.BasicTypesValues[0].CharValue); + Assert.Equal(38.1f, msg2.BasicTypesValues[0].Float32Value); + Assert.Equal(39.1, msg2.BasicTypesValues[0].Float64Value); + Assert.Equal(40, msg2.BasicTypesValues[0].Int8Value); + Assert.Equal(41, msg2.BasicTypesValues[0].Uint8Value); + Assert.Equal(42, msg2.BasicTypesValues[0].Int16Value); + Assert.Equal(43, msg2.BasicTypesValues[0].Uint16Value); + Assert.Equal(44, msg2.BasicTypesValues[0].Int32Value); + Assert.Equal((uint)45, msg2.BasicTypesValues[0].Uint32Value); + Assert.Equal(46, msg2.BasicTypesValues[0].Int64Value); + Assert.Equal((ulong)47, msg2.BasicTypesValues[0].Uint64Value); + + Assert.False(msg2.BasicTypesValues[1].BoolValue); + Assert.Equal(48, msg2.BasicTypesValues[1].ByteValue); + Assert.Equal(49, msg2.BasicTypesValues[1].CharValue); + Assert.Equal(50.1f, msg2.BasicTypesValues[1].Float32Value); + Assert.Equal(51.1, msg2.BasicTypesValues[1].Float64Value); + Assert.Equal(52, msg2.BasicTypesValues[1].Int8Value); + Assert.Equal(53, msg2.BasicTypesValues[1].Uint8Value); + Assert.Equal(54, msg2.BasicTypesValues[1].Int16Value); + Assert.Equal(55, msg2.BasicTypesValues[1].Uint16Value); + Assert.Equal(56, msg2.BasicTypesValues[1].Int32Value); + Assert.Equal((uint)57, msg2.BasicTypesValues[1].Uint32Value); + Assert.Equal(58, msg2.BasicTypesValues[1].Int64Value); + Assert.Equal((ulong)59, msg2.BasicTypesValues[1].Uint64Value); - Assert.True(msg2.Basic_types_values[2].Bool_value); - Assert.Equal(60, msg2.Basic_types_values[2].Byte_value); - Assert.Equal(61, msg2.Basic_types_values[2].Char_value); - Assert.Equal(62.1f, msg2.Basic_types_values[2].Float32_value); - Assert.Equal(63.1, msg2.Basic_types_values[2].Float64_value); - Assert.Equal(64, msg2.Basic_types_values[2].Int8_value); - Assert.Equal(65, msg2.Basic_types_values[2].Uint8_value); - Assert.Equal(66, msg2.Basic_types_values[2].Int16_value); - Assert.Equal(67, msg2.Basic_types_values[2].Uint16_value); - Assert.Equal(68, msg2.Basic_types_values[2].Int32_value); - Assert.Equal((uint)69, msg2.Basic_types_values[2].Uint32_value); - Assert.Equal(70, msg2.Basic_types_values[2].Int64_value); - Assert.Equal((ulong)71, msg2.Basic_types_values[2].Uint64_value); + Assert.True(msg2.BasicTypesValues[2].BoolValue); + Assert.Equal(60, msg2.BasicTypesValues[2].ByteValue); + Assert.Equal(61, msg2.BasicTypesValues[2].CharValue); + Assert.Equal(62.1f, msg2.BasicTypesValues[2].Float32Value); + Assert.Equal(63.1, msg2.BasicTypesValues[2].Float64Value); + Assert.Equal(64, msg2.BasicTypesValues[2].Int8Value); + Assert.Equal(65, msg2.BasicTypesValues[2].Uint8Value); + Assert.Equal(66, msg2.BasicTypesValues[2].Int16Value); + Assert.Equal(67, msg2.BasicTypesValues[2].Uint16Value); + Assert.Equal(68, msg2.BasicTypesValues[2].Int32Value); + Assert.Equal((uint)69, msg2.BasicTypesValues[2].Uint32Value); + Assert.Equal(70, msg2.BasicTypesValues[2].Int64Value); + Assert.Equal((ulong)71, msg2.BasicTypesValues[2].Uint64Value); } [Fact] @@ -693,124 +694,124 @@ public void TestPublishBoundedSequences() test_msgs.msg.BoundedSequences msg = new test_msgs.msg.BoundedSequences(); test_msgs.msg.BoundedSequences msg2 = new test_msgs.msg.BoundedSequences(); - // bool_values - msg.Bool_values.Add(true); - msg.Bool_values.Add(false); - msg.Bool_values.Add(true); - - // byte_values - msg.Byte_values.Add(0); - msg.Byte_values.Add(1); - msg.Byte_values.Add(2); - - // char_values - msg.Char_values.Add(3); - msg.Char_values.Add(4); - msg.Char_values.Add(5); - - // float32_values - msg.Float32_values.Add(6.1f); - msg.Float32_values.Add(7.1f); - msg.Float32_values.Add(8.1f); - - // float64_values - msg.Float64_values.Add(9.1); - msg.Float64_values.Add(10.1); - msg.Float64_values.Add(11.1); - - // int8_values - msg.Int8_values.Add(12); - msg.Int8_values.Add(13); - msg.Int8_values.Add(14); - - // uint8_values - msg.Uint8_values.Add(15); - msg.Uint8_values.Add(16); - msg.Uint8_values.Add(17); - - // int16_values - msg.Int16_values.Add(18); - msg.Int16_values.Add(19); - msg.Int16_values.Add(20); - - // uint16_values - msg.Uint16_values.Add(21); - msg.Uint16_values.Add(22); - msg.Uint16_values.Add(23); - - // int32_values - msg.Int32_values.Add(24); - msg.Int32_values.Add(25); - msg.Int32_values.Add(26); - - // uint32_values - msg.Uint32_values.Add(27); - msg.Uint32_values.Add(28); - msg.Uint32_values.Add(29); - - // int64_values - msg.Int64_values.Add(30); - msg.Int64_values.Add(31); - msg.Int64_values.Add(32); - - // uint64_values - msg.Uint64_values.Add(33); - msg.Uint64_values.Add(34); - msg.Uint64_values.Add(35); - - // string_values - msg.String_values.Add("one"); - msg.String_values.Add("two"); - msg.String_values.Add("three"); + // boolValues + msg.BoolValues.Add(true); + msg.BoolValues.Add(false); + msg.BoolValues.Add(true); + + // byteValues + msg.ByteValues.Add(0); + msg.ByteValues.Add(1); + msg.ByteValues.Add(2); + + // charValues + msg.CharValues.Add(3); + msg.CharValues.Add(4); + msg.CharValues.Add(5); + + // float32Values + msg.Float32Values.Add(6.1f); + msg.Float32Values.Add(7.1f); + msg.Float32Values.Add(8.1f); + + // float64Values + msg.Float64Values.Add(9.1); + msg.Float64Values.Add(10.1); + msg.Float64Values.Add(11.1); + + // int8Values + msg.Int8Values.Add(12); + msg.Int8Values.Add(13); + msg.Int8Values.Add(14); + + // uint8Values + msg.Uint8Values.Add(15); + msg.Uint8Values.Add(16); + msg.Uint8Values.Add(17); + + // int16Values + msg.Int16Values.Add(18); + msg.Int16Values.Add(19); + msg.Int16Values.Add(20); + + // uint16Values + msg.Uint16Values.Add(21); + msg.Uint16Values.Add(22); + msg.Uint16Values.Add(23); + + // int32Values + msg.Int32Values.Add(24); + msg.Int32Values.Add(25); + msg.Int32Values.Add(26); + + // uint32Values + msg.Uint32Values.Add(27); + msg.Uint32Values.Add(28); + msg.Uint32Values.Add(29); + + // int64Values + msg.Int64Values.Add(30); + msg.Int64Values.Add(31); + msg.Int64Values.Add(32); + + // uint64Values + msg.Uint64Values.Add(33); + msg.Uint64Values.Add(34); + msg.Uint64Values.Add(35); + + // stringValues + msg.StringValues.Add("one"); + msg.StringValues.Add("two"); + msg.StringValues.Add("three"); test_msgs.msg.BasicTypes basic_type_1 = new test_msgs.msg.BasicTypes(); - basic_type_1.Bool_value = true; - basic_type_1.Byte_value = 36; - basic_type_1.Char_value = 37; - basic_type_1.Float32_value = 38.1f; - basic_type_1.Float64_value = 39.1; - basic_type_1.Int8_value = 40; - basic_type_1.Uint8_value = 41; - basic_type_1.Int16_value = 42; - basic_type_1.Uint16_value = 43; - basic_type_1.Int32_value = 44; - basic_type_1.Uint32_value = 45; - basic_type_1.Int64_value = 46; - basic_type_1.Uint64_value = 47; + basic_type_1.BoolValue = true; + basic_type_1.ByteValue = 36; + basic_type_1.CharValue = 37; + basic_type_1.Float32Value = 38.1f; + basic_type_1.Float64Value = 39.1; + basic_type_1.Int8Value = 40; + basic_type_1.Uint8Value = 41; + basic_type_1.Int16Value = 42; + basic_type_1.Uint16Value = 43; + basic_type_1.Int32Value = 44; + basic_type_1.Uint32Value = 45; + basic_type_1.Int64Value = 46; + basic_type_1.Uint64Value = 47; test_msgs.msg.BasicTypes basic_type_2 = new test_msgs.msg.BasicTypes(); - basic_type_2.Bool_value = false; - basic_type_2.Byte_value = 48; - basic_type_2.Char_value = 49; - basic_type_2.Float32_value = 50.1f; - basic_type_2.Float64_value = 51.1; - basic_type_2.Int8_value = 52; - basic_type_2.Uint8_value = 53; - basic_type_2.Int16_value = 54; - basic_type_2.Uint16_value = 55; - basic_type_2.Int32_value = 56; - basic_type_2.Uint32_value = 57; - basic_type_2.Int64_value = 58; - basic_type_2.Uint64_value = 59; + basic_type_2.BoolValue = false; + basic_type_2.ByteValue = 48; + basic_type_2.CharValue = 49; + basic_type_2.Float32Value = 50.1f; + basic_type_2.Float64Value = 51.1; + basic_type_2.Int8Value = 52; + basic_type_2.Uint8Value = 53; + basic_type_2.Int16Value = 54; + basic_type_2.Uint16Value = 55; + basic_type_2.Int32Value = 56; + basic_type_2.Uint32Value = 57; + basic_type_2.Int64Value = 58; + basic_type_2.Uint64Value = 59; test_msgs.msg.BasicTypes basic_type_3 = new test_msgs.msg.BasicTypes(); - basic_type_3.Bool_value = true; - basic_type_3.Byte_value = 60; - basic_type_3.Char_value = 61; - basic_type_3.Float32_value = 62.1f; - basic_type_3.Float64_value = 63.1; - basic_type_3.Int8_value = 64; - basic_type_3.Uint8_value = 65; - basic_type_3.Int16_value = 66; - basic_type_3.Uint16_value = 67; - basic_type_3.Int32_value = 68; - basic_type_3.Uint32_value = 69; - basic_type_3.Int64_value = 70; - basic_type_3.Uint64_value = 71; - - msg.Basic_types_values.Add(basic_type_1); - msg.Basic_types_values.Add(basic_type_2); - msg.Basic_types_values.Add(basic_type_3); + basic_type_3.BoolValue = true; + basic_type_3.ByteValue = 60; + basic_type_3.CharValue = 61; + basic_type_3.Float32Value = 62.1f; + basic_type_3.Float64Value = 63.1; + basic_type_3.Int8Value = 64; + basic_type_3.Uint8Value = 65; + basic_type_3.Int16Value = 66; + basic_type_3.Uint16Value = 67; + basic_type_3.Int32Value = 68; + basic_type_3.Uint32Value = 69; + basic_type_3.Int64Value = 70; + basic_type_3.Uint64Value = 71; + + msg.BasicTypesValues.Add(basic_type_1); + msg.BasicTypesValues.Add(basic_type_2); + msg.BasicTypesValues.Add(basic_type_3); bool received=false; Subscription chatter_sub = node_array_2.CreateSubscription( @@ -829,147 +830,147 @@ public void TestPublishBoundedSequences() RCLdotnet.SpinOnce(node_array_2, 500); } - // bool_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Bool_values_MaxCount); - Assert.Equal(3, msg2.Bool_values.Count); - Assert.True(msg2.Bool_values[0]); - Assert.False(msg2.Bool_values[1]); - Assert.True(msg2.Bool_values[2]); - - // byte_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Byte_values_MaxCount); - Assert.Equal(3, msg2.Byte_values.Count); - Assert.Equal(0, msg2.Byte_values[0]); - Assert.Equal(1, msg2.Byte_values[1]); - Assert.Equal(2, msg2.Byte_values[2]); - - // char_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Char_values_MaxCount); - Assert.Equal(3, msg2.Char_values.Count); - Assert.Equal(3, msg2.Char_values[0]); - Assert.Equal(4, msg2.Char_values[1]); - Assert.Equal(5, msg2.Char_values[2]); - - // float32_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Float32_values_MaxCount); - Assert.Equal(3, msg2.Float32_values.Count); - Assert.Equal(6.1f, msg2.Float32_values[0]); - Assert.Equal(7.1f, msg2.Float32_values[1]); - Assert.Equal(8.1f, msg2.Float32_values[2]); - - // float64_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Float64_values_MaxCount); - Assert.Equal(3, msg2.Float64_values.Count); - Assert.Equal(9.1, msg2.Float64_values[0]); - Assert.Equal(10.1, msg2.Float64_values[1]); - Assert.Equal(11.1, msg2.Float64_values[2]); - - // int8_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Int8_values_MaxCount); - Assert.Equal(3, msg2.Int8_values.Count); - Assert.Equal(12, msg2.Int8_values[0]); - Assert.Equal(13, msg2.Int8_values[1]); - Assert.Equal(14, msg2.Int8_values[2]); - - // uint8_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint8_values_MaxCount); - Assert.Equal(3, msg2.Uint8_values.Count); - Assert.Equal(15, msg2.Uint8_values[0]); - Assert.Equal(16, msg2.Uint8_values[1]); - Assert.Equal(17, msg2.Uint8_values[2]); - - // int16_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Int16_values_MaxCount); - Assert.Equal(3, msg2.Int16_values.Count); - Assert.Equal(18, msg2.Int16_values[0]); - Assert.Equal(19, msg2.Int16_values[1]); - Assert.Equal(20, msg2.Int16_values[2]); - - // uint16_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint16_values_MaxCount); - Assert.Equal(3, msg2.Uint16_values.Count); - Assert.Equal(21, msg2.Uint16_values[0]); - Assert.Equal(22, msg2.Uint16_values[1]); - Assert.Equal(23, msg2.Uint16_values[2]); - - // int32_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Int32_values_MaxCount); - Assert.Equal(3, msg2.Int32_values.Count); - Assert.Equal(24, msg2.Int32_values[0]); - Assert.Equal(25, msg2.Int32_values[1]); - Assert.Equal(26, msg2.Int32_values[2]); + // boolValues + Assert.Equal(3, test_msgs.msg.BoundedSequences.BoolValuesMaxCount); + Assert.Equal(3, msg2.BoolValues.Count); + Assert.True(msg2.BoolValues[0]); + Assert.False(msg2.BoolValues[1]); + Assert.True(msg2.BoolValues[2]); + + // byteValues + Assert.Equal(3, test_msgs.msg.BoundedSequences.ByteValuesMaxCount); + Assert.Equal(3, msg2.ByteValues.Count); + Assert.Equal(0, msg2.ByteValues[0]); + Assert.Equal(1, msg2.ByteValues[1]); + Assert.Equal(2, msg2.ByteValues[2]); + + // charValues + Assert.Equal(3, test_msgs.msg.BoundedSequences.CharValuesMaxCount); + Assert.Equal(3, msg2.CharValues.Count); + Assert.Equal(3, msg2.CharValues[0]); + Assert.Equal(4, msg2.CharValues[1]); + Assert.Equal(5, msg2.CharValues[2]); + + // float32Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Float32ValuesMaxCount); + Assert.Equal(3, msg2.Float32Values.Count); + Assert.Equal(6.1f, msg2.Float32Values[0]); + Assert.Equal(7.1f, msg2.Float32Values[1]); + Assert.Equal(8.1f, msg2.Float32Values[2]); + + // float64Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Float64ValuesMaxCount); + Assert.Equal(3, msg2.Float64Values.Count); + Assert.Equal(9.1, msg2.Float64Values[0]); + Assert.Equal(10.1, msg2.Float64Values[1]); + Assert.Equal(11.1, msg2.Float64Values[2]); + + // int8Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Int8ValuesMaxCount); + Assert.Equal(3, msg2.Int8Values.Count); + Assert.Equal(12, msg2.Int8Values[0]); + Assert.Equal(13, msg2.Int8Values[1]); + Assert.Equal(14, msg2.Int8Values[2]); + + // uint8Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint8ValuesMaxCount); + Assert.Equal(3, msg2.Uint8Values.Count); + Assert.Equal(15, msg2.Uint8Values[0]); + Assert.Equal(16, msg2.Uint8Values[1]); + Assert.Equal(17, msg2.Uint8Values[2]); + + // int16Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Int16ValuesMaxCount); + Assert.Equal(3, msg2.Int16Values.Count); + Assert.Equal(18, msg2.Int16Values[0]); + Assert.Equal(19, msg2.Int16Values[1]); + Assert.Equal(20, msg2.Int16Values[2]); + + // uint16Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint16ValuesMaxCount); + Assert.Equal(3, msg2.Uint16Values.Count); + Assert.Equal(21, msg2.Uint16Values[0]); + Assert.Equal(22, msg2.Uint16Values[1]); + Assert.Equal(23, msg2.Uint16Values[2]); + + // int32Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Int32ValuesMaxCount); + Assert.Equal(3, msg2.Int32Values.Count); + Assert.Equal(24, msg2.Int32Values[0]); + Assert.Equal(25, msg2.Int32Values[1]); + Assert.Equal(26, msg2.Int32Values[2]); - // uint32_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint32_values_MaxCount); - Assert.Equal(3, msg2.Uint32_values.Count); - Assert.Equal((uint)27, msg2.Uint32_values[0]); - Assert.Equal((uint)28, msg2.Uint32_values[1]); - Assert.Equal((uint)29, msg2.Uint32_values[2]); - - // int64_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Int64_values_MaxCount); - Assert.Equal(3, msg2.Int64_values.Count); - Assert.Equal(30, msg2.Int64_values[0]); - Assert.Equal(31, msg2.Int64_values[1]); - Assert.Equal(32, msg2.Int64_values[2]); + // uint32Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint32ValuesMaxCount); + Assert.Equal(3, msg2.Uint32Values.Count); + Assert.Equal((uint)27, msg2.Uint32Values[0]); + Assert.Equal((uint)28, msg2.Uint32Values[1]); + Assert.Equal((uint)29, msg2.Uint32Values[2]); + + // int64Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Int64ValuesMaxCount); + Assert.Equal(3, msg2.Int64Values.Count); + Assert.Equal(30, msg2.Int64Values[0]); + Assert.Equal(31, msg2.Int64Values[1]); + Assert.Equal(32, msg2.Int64Values[2]); - // uint64_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint64_values_MaxCount); - Assert.Equal(3, msg2.Uint64_values.Count); - Assert.Equal((ulong)33, msg2.Uint64_values[0]); - Assert.Equal((ulong)34, msg2.Uint64_values[1]); - Assert.Equal((ulong)35, msg2.Uint64_values[2]); - - // string_values - Assert.Equal(3, test_msgs.msg.BoundedSequences.String_values_MaxCount); - Assert.Equal(3, msg2.String_values.Count); - Assert.Equal("one", msg2.String_values[0]); - Assert.Equal("two", msg2.String_values[1]); - Assert.Equal("three", msg2.String_values[2]); + // uint64Values + Assert.Equal(3, test_msgs.msg.BoundedSequences.Uint64ValuesMaxCount); + Assert.Equal(3, msg2.Uint64Values.Count); + Assert.Equal((ulong)33, msg2.Uint64Values[0]); + Assert.Equal((ulong)34, msg2.Uint64Values[1]); + Assert.Equal((ulong)35, msg2.Uint64Values[2]); + + // stringValues + Assert.Equal(3, test_msgs.msg.BoundedSequences.StringValuesMaxCount); + Assert.Equal(3, msg2.StringValues.Count); + Assert.Equal("one", msg2.StringValues[0]); + Assert.Equal("two", msg2.StringValues[1]); + Assert.Equal("three", msg2.StringValues[2]); - Assert.Equal(3, test_msgs.msg.BoundedSequences.Basic_types_values_MaxCount); - Assert.Equal(3, msg2.Basic_types_values.Count); - Assert.True(msg2.Basic_types_values[0].Bool_value); - Assert.Equal(36, msg2.Basic_types_values[0].Byte_value); - Assert.Equal(37, msg2.Basic_types_values[0].Char_value); - Assert.Equal(38.1f, msg2.Basic_types_values[0].Float32_value); - Assert.Equal(39.1, msg2.Basic_types_values[0].Float64_value); - Assert.Equal(40, msg2.Basic_types_values[0].Int8_value); - Assert.Equal(41, msg2.Basic_types_values[0].Uint8_value); - Assert.Equal(42, msg2.Basic_types_values[0].Int16_value); - Assert.Equal(43, msg2.Basic_types_values[0].Uint16_value); - Assert.Equal(44, msg2.Basic_types_values[0].Int32_value); - Assert.Equal((uint)45, msg2.Basic_types_values[0].Uint32_value); - Assert.Equal(46, msg2.Basic_types_values[0].Int64_value); - Assert.Equal((ulong)47, msg2.Basic_types_values[0].Uint64_value); - - Assert.False(msg2.Basic_types_values[1].Bool_value); - Assert.Equal(48, msg2.Basic_types_values[1].Byte_value); - Assert.Equal(49, msg2.Basic_types_values[1].Char_value); - Assert.Equal(50.1f, msg2.Basic_types_values[1].Float32_value); - Assert.Equal(51.1, msg2.Basic_types_values[1].Float64_value); - Assert.Equal(52, msg2.Basic_types_values[1].Int8_value); - Assert.Equal(53, msg2.Basic_types_values[1].Uint8_value); - Assert.Equal(54, msg2.Basic_types_values[1].Int16_value); - Assert.Equal(55, msg2.Basic_types_values[1].Uint16_value); - Assert.Equal(56, msg2.Basic_types_values[1].Int32_value); - Assert.Equal((uint)57, msg2.Basic_types_values[1].Uint32_value); - Assert.Equal(58, msg2.Basic_types_values[1].Int64_value); - Assert.Equal((ulong)59, msg2.Basic_types_values[1].Uint64_value); + Assert.Equal(3, test_msgs.msg.BoundedSequences.BasicTypesValuesMaxCount); + Assert.Equal(3, msg2.BasicTypesValues.Count); + Assert.True(msg2.BasicTypesValues[0].BoolValue); + Assert.Equal(36, msg2.BasicTypesValues[0].ByteValue); + Assert.Equal(37, msg2.BasicTypesValues[0].CharValue); + Assert.Equal(38.1f, msg2.BasicTypesValues[0].Float32Value); + Assert.Equal(39.1, msg2.BasicTypesValues[0].Float64Value); + Assert.Equal(40, msg2.BasicTypesValues[0].Int8Value); + Assert.Equal(41, msg2.BasicTypesValues[0].Uint8Value); + Assert.Equal(42, msg2.BasicTypesValues[0].Int16Value); + Assert.Equal(43, msg2.BasicTypesValues[0].Uint16Value); + Assert.Equal(44, msg2.BasicTypesValues[0].Int32Value); + Assert.Equal((uint)45, msg2.BasicTypesValues[0].Uint32Value); + Assert.Equal(46, msg2.BasicTypesValues[0].Int64Value); + Assert.Equal((ulong)47, msg2.BasicTypesValues[0].Uint64Value); + + Assert.False(msg2.BasicTypesValues[1].BoolValue); + Assert.Equal(48, msg2.BasicTypesValues[1].ByteValue); + Assert.Equal(49, msg2.BasicTypesValues[1].CharValue); + Assert.Equal(50.1f, msg2.BasicTypesValues[1].Float32Value); + Assert.Equal(51.1, msg2.BasicTypesValues[1].Float64Value); + Assert.Equal(52, msg2.BasicTypesValues[1].Int8Value); + Assert.Equal(53, msg2.BasicTypesValues[1].Uint8Value); + Assert.Equal(54, msg2.BasicTypesValues[1].Int16Value); + Assert.Equal(55, msg2.BasicTypesValues[1].Uint16Value); + Assert.Equal(56, msg2.BasicTypesValues[1].Int32Value); + Assert.Equal((uint)57, msg2.BasicTypesValues[1].Uint32Value); + Assert.Equal(58, msg2.BasicTypesValues[1].Int64Value); + Assert.Equal((ulong)59, msg2.BasicTypesValues[1].Uint64Value); - Assert.True(msg2.Basic_types_values[2].Bool_value); - Assert.Equal(60, msg2.Basic_types_values[2].Byte_value); - Assert.Equal(61, msg2.Basic_types_values[2].Char_value); - Assert.Equal(62.1f, msg2.Basic_types_values[2].Float32_value); - Assert.Equal(63.1, msg2.Basic_types_values[2].Float64_value); - Assert.Equal(64, msg2.Basic_types_values[2].Int8_value); - Assert.Equal(65, msg2.Basic_types_values[2].Uint8_value); - Assert.Equal(66, msg2.Basic_types_values[2].Int16_value); - Assert.Equal(67, msg2.Basic_types_values[2].Uint16_value); - Assert.Equal(68, msg2.Basic_types_values[2].Int32_value); - Assert.Equal((uint)69, msg2.Basic_types_values[2].Uint32_value); - Assert.Equal(70, msg2.Basic_types_values[2].Int64_value); - Assert.Equal((ulong)71, msg2.Basic_types_values[2].Uint64_value); + Assert.True(msg2.BasicTypesValues[2].BoolValue); + Assert.Equal(60, msg2.BasicTypesValues[2].ByteValue); + Assert.Equal(61, msg2.BasicTypesValues[2].CharValue); + Assert.Equal(62.1f, msg2.BasicTypesValues[2].Float32Value); + Assert.Equal(63.1, msg2.BasicTypesValues[2].Float64Value); + Assert.Equal(64, msg2.BasicTypesValues[2].Int8Value); + Assert.Equal(65, msg2.BasicTypesValues[2].Uint8Value); + Assert.Equal(66, msg2.BasicTypesValues[2].Int16Value); + Assert.Equal(67, msg2.BasicTypesValues[2].Uint16Value); + Assert.Equal(68, msg2.BasicTypesValues[2].Int32Value); + Assert.Equal((uint)69, msg2.BasicTypesValues[2].Uint32Value); + Assert.Equal(70, msg2.BasicTypesValues[2].Int64Value); + Assert.Equal((ulong)71, msg2.BasicTypesValues[2].Uint64Value); } [Fact] @@ -980,7 +981,7 @@ public void TestPublishBoundedSequencesSizeCheck() var chatterPub = nodeBoundedSequencesSizeCheck.CreatePublisher("topic_bounded_sequences_size_check"); var msg = new test_msgs.msg.BoundedSequences(); - msg.String_values = new List + msg.StringValues = new List { "0", "1", @@ -989,7 +990,427 @@ public void TestPublishBoundedSequencesSizeCheck() }; var exception = Assert.Throws(() => chatterPub.Publish(msg)); - Assert.Equal("Invalid size of bounded sequence 'String_values'.", exception.Message); + Assert.Equal("Invalid size of bounded sequence 'StringValues'.", exception.Message); + } + + [Fact] + public void TestDefaults() + { + var defaultsMsg = new test_msgs.msg.Defaults(); + + Assert.Equal(true, defaultsMsg.BoolValue); + Assert.Equal(50, defaultsMsg.ByteValue); + Assert.Equal(100, defaultsMsg.CharValue); + Assert.Equal(1.125f, defaultsMsg.Float32Value); + Assert.Equal(1.125, defaultsMsg.Float64Value); + Assert.Equal(-50, defaultsMsg.Int8Value); + Assert.Equal(200, defaultsMsg.Uint8Value); + Assert.Equal(-1000, defaultsMsg.Int16Value); + Assert.Equal(2000, defaultsMsg.Uint16Value); + Assert.Equal(-30000, defaultsMsg.Int32Value); + Assert.True(60000 == defaultsMsg.Uint32Value); + Assert.Equal(-40000000, defaultsMsg.Int64Value); + Assert.True(50000000 == defaultsMsg.Uint64Value); + + var stringsMsg = new test_msgs.msg.Strings(); + Assert.Equal("", stringsMsg.StringValue); + Assert.Equal("Hello world!", stringsMsg.StringValueDefault1); + Assert.Equal("Hello'world!", stringsMsg.StringValueDefault2); + Assert.Equal("Hello\"world!", stringsMsg.StringValueDefault3); + Assert.Equal("Hello'world!", stringsMsg.StringValueDefault4); + Assert.Equal("Hello\"world!", stringsMsg.StringValueDefault5); + } + + [Fact] + public void TestDefaultsArrays() + { + var msg = new test_msgs.msg.Arrays(); + + Assert.IsType(msg.BoolValues); + Assert.Equal(new bool[3], msg.BoolValues); + + Assert.IsType(msg.ByteValues); + Assert.Equal(new byte[3], msg.ByteValues); + + Assert.IsType(msg.CharValues); + Assert.Equal(new byte[3], msg.CharValues); + + Assert.IsType(msg.Float32Values); + Assert.Equal(new float[3], msg.Float32Values); + + Assert.IsType(msg.Float64Values); + Assert.Equal(new double[3], msg.Float64Values); + + Assert.IsType(msg.Int8Values); + Assert.Equal(new sbyte[3], msg.Int8Values); + + Assert.IsType(msg.Uint8Values); + Assert.Equal(new byte[3], msg.Uint8Values); + + Assert.IsType(msg.Int16Values); + Assert.Equal(new short[3], msg.Int16Values); + + Assert.IsType(msg.Uint16Values); + Assert.Equal(new ushort[3], msg.Uint16Values); + + Assert.IsType(msg.Int32Values); + Assert.Equal(new int[3], msg.Int32Values); + + Assert.IsType(msg.Uint32Values); + Assert.Equal(new uint[3], msg.Uint32Values); + + Assert.IsType(msg.Int64Values); + Assert.Equal(new long[3], msg.Int64Values); + + Assert.IsType(msg.Uint64Values); + Assert.Equal(new ulong[3], msg.Uint64Values); + + Assert.IsType(msg.StringValues); + Assert.Equal( + Enumerable.Repeat("", 3).ToArray(), + msg.StringValues); + + Assert.IsType(msg.BasicTypesValues); + Assert.Equal(3, msg.BasicTypesValues.Length); + Assert.NotNull(msg.BasicTypesValues[0]); + Assert.NotNull(msg.BasicTypesValues[1]); + Assert.NotNull(msg.BasicTypesValues[2]); + + Assert.IsType(msg.ConstantsValues); + Assert.Equal(3, msg.ConstantsValues.Length); + Assert.NotNull(msg.ConstantsValues[0]); + Assert.NotNull(msg.ConstantsValues[1]); + Assert.NotNull(msg.ConstantsValues[2]); + + Assert.IsType(msg.DefaultsValues); + Assert.Equal(3, msg.DefaultsValues.Length); + Assert.NotNull(msg.DefaultsValues[0]); + Assert.NotNull(msg.DefaultsValues[1]); + Assert.NotNull(msg.DefaultsValues[2]); + + Assert.IsType(msg.BoolValuesDefault); + Assert.Equal( + new bool[] { false, true, false }, + msg.BoolValuesDefault); + + Assert.IsType(msg.ByteValuesDefault); + Assert.Equal( + new byte[] { 0, 1, 255 }, + msg.ByteValuesDefault); + + Assert.IsType(msg.CharValuesDefault); + Assert.Equal( + new byte[] { 0, 1, 127 }, + msg.CharValuesDefault); + + Assert.IsType(msg.Float32ValuesDefault); + Assert.Equal( + new float[] { 1.125f, 0.0f, -1.125f}, + msg.Float32ValuesDefault); + + Assert.IsType(msg.Float64ValuesDefault); + Assert.Equal( + new double[] { 3.1415, 0.0, -3.1415 }, + msg.Float64ValuesDefault); + + Assert.IsType(msg.Int8ValuesDefault); + Assert.Equal( + new sbyte[] { 0, 127, -128 }, + msg.Int8ValuesDefault); + + Assert.IsType(msg.Uint8ValuesDefault); + Assert.Equal( + new byte[] { 0, 1, 255 }, + msg.Uint8ValuesDefault); + + Assert.IsType(msg.Int16ValuesDefault); + Assert.Equal( + new short[] { 0, 32767, -32768 }, + msg.Int16ValuesDefault); + + Assert.IsType(msg.Uint16ValuesDefault); + Assert.Equal( + new ushort[] { 0, 1, 65535 }, + msg.Uint16ValuesDefault); + + Assert.IsType(msg.Int32ValuesDefault); + Assert.Equal( + new int[] { 0, 2147483647, -2147483648 }, + msg.Int32ValuesDefault); + + Assert.IsType(msg.Uint32ValuesDefault); + Assert.Equal( + new uint[] { 0, 1, 4294967295 }, + msg.Uint32ValuesDefault); + + Assert.IsType(msg.Int64ValuesDefault); + Assert.Equal( + new long[] { 0, 9223372036854775807, -9223372036854775808 }, + msg.Int64ValuesDefault); + + Assert.IsType(msg.Uint64ValuesDefault); + Assert.Equal( + new ulong[] { 0, 1, 18446744073709551615 }, + msg.Uint64ValuesDefault); + + Assert.IsType(msg.StringValuesDefault); + Assert.Equal( + new string[] { "", "max value", "min value" }, + msg.StringValuesDefault); + } + + [Fact] + public void TestDefaultsUnboundedSequences() + { + var msg = new test_msgs.msg.UnboundedSequences(); + + Assert.IsType>(msg.BoolValues); + Assert.Equal(new List(), msg.BoolValues); + + Assert.IsType>(msg.ByteValues); + Assert.Equal(new List(), msg.ByteValues); + + Assert.IsType>(msg.CharValues); + Assert.Equal(new List(), msg.CharValues); + + Assert.IsType>(msg.Float32Values); + Assert.Equal(new List(), msg.Float32Values); + + Assert.IsType>(msg.Float64Values); + Assert.Equal(new List(), msg.Float64Values); + + Assert.IsType>(msg.Int8Values); + Assert.Equal(new List(), msg.Int8Values); + + Assert.IsType>(msg.Uint8Values); + Assert.Equal(new List(), msg.Uint8Values); + + Assert.IsType>(msg.Int16Values); + Assert.Equal(new List(), msg.Int16Values); + + Assert.IsType>(msg.Uint16Values); + Assert.Equal(new List(), msg.Uint16Values); + + Assert.IsType>(msg.Int32Values); + Assert.Equal(new List(), msg.Int32Values); + + Assert.IsType>(msg.Uint32Values); + Assert.Equal(new List(), msg.Uint32Values); + + Assert.IsType>(msg.Int64Values); + Assert.Equal(new List(), msg.Int64Values); + + Assert.IsType>(msg.Uint64Values); + Assert.Equal(new List(), msg.Uint64Values); + + Assert.IsType>(msg.StringValues); + Assert.Equal(new List(), msg.StringValues); + + Assert.IsType>(msg.BasicTypesValues); + Assert.Equal(new List(), msg.BasicTypesValues); + + Assert.IsType>(msg.ConstantsValues); + Assert.Equal(new List(), msg.ConstantsValues); + + Assert.IsType>(msg.DefaultsValues); + Assert.Equal(new List(), msg.DefaultsValues); + + Assert.IsType>(msg.BoolValuesDefault); + Assert.Equal( + new List { false, true, false }, + msg.BoolValuesDefault); + + Assert.IsType>(msg.ByteValuesDefault); + Assert.Equal( + new List { 0, 1, 255 }, + msg.ByteValuesDefault); + + Assert.IsType>(msg.CharValuesDefault); + Assert.Equal( + new List { 0, 1, 127 }, + msg.CharValuesDefault); + + Assert.IsType>(msg.Float32ValuesDefault); + Assert.Equal( + new List { 1.125f, 0.0f, -1.125f}, + msg.Float32ValuesDefault); + + Assert.IsType>(msg.Float64ValuesDefault); + Assert.Equal( + new List { 3.1415, 0.0, -3.1415 }, + msg.Float64ValuesDefault); + + Assert.IsType>(msg.Int8ValuesDefault); + Assert.Equal( + new List { 0, 127, -128 }, + msg.Int8ValuesDefault); + + Assert.IsType>(msg.Uint8ValuesDefault); + Assert.Equal( + new List { 0, 1, 255 }, + msg.Uint8ValuesDefault); + + Assert.IsType>(msg.Int16ValuesDefault); + Assert.Equal( + new List { 0, 32767, -32768 }, + msg.Int16ValuesDefault); + + Assert.IsType>(msg.Uint16ValuesDefault); + Assert.Equal( + new List { 0, 1, 65535 }, + msg.Uint16ValuesDefault); + + Assert.IsType>(msg.Int32ValuesDefault); + Assert.Equal( + new List { 0, 2147483647, -2147483648 }, + msg.Int32ValuesDefault); + + Assert.IsType>(msg.Uint32ValuesDefault); + Assert.Equal( + new List { 0, 1, 4294967295 }, + msg.Uint32ValuesDefault); + + Assert.IsType>(msg.Int64ValuesDefault); + Assert.Equal( + new List { 0, 9223372036854775807, -9223372036854775808 }, + msg.Int64ValuesDefault); + + Assert.IsType>(msg.Uint64ValuesDefault); + Assert.Equal( + new List { 0, 1, 18446744073709551615 }, + msg.Uint64ValuesDefault); + + Assert.IsType>(msg.StringValuesDefault); + Assert.Equal( + new List { "", "max value", "min value" }, + msg.StringValuesDefault); + } + + [Fact] + public void TestDefaultsBoundedSequences() + { + var msg = new test_msgs.msg.BoundedSequences(); + + Assert.IsType>(msg.BoolValues); + Assert.Equal(new List(), msg.BoolValues); + + Assert.IsType>(msg.ByteValues); + Assert.Equal(new List(), msg.ByteValues); + + Assert.IsType>(msg.CharValues); + Assert.Equal(new List(), msg.CharValues); + + Assert.IsType>(msg.Float32Values); + Assert.Equal(new List(), msg.Float32Values); + + Assert.IsType>(msg.Float64Values); + Assert.Equal(new List(), msg.Float64Values); + + Assert.IsType>(msg.Int8Values); + Assert.Equal(new List(), msg.Int8Values); + + Assert.IsType>(msg.Uint8Values); + Assert.Equal(new List(), msg.Uint8Values); + + Assert.IsType>(msg.Int16Values); + Assert.Equal(new List(), msg.Int16Values); + + Assert.IsType>(msg.Uint16Values); + Assert.Equal(new List(), msg.Uint16Values); + + Assert.IsType>(msg.Int32Values); + Assert.Equal(new List(), msg.Int32Values); + + Assert.IsType>(msg.Uint32Values); + Assert.Equal(new List(), msg.Uint32Values); + + Assert.IsType>(msg.Int64Values); + Assert.Equal(new List(), msg.Int64Values); + + Assert.IsType>(msg.Uint64Values); + Assert.Equal(new List(), msg.Uint64Values); + + Assert.IsType>(msg.StringValues); + Assert.Equal(new List(), msg.StringValues); + + Assert.IsType>(msg.BasicTypesValues); + Assert.Equal(new List(), msg.BasicTypesValues); + + Assert.IsType>(msg.ConstantsValues); + Assert.Equal(new List(), msg.ConstantsValues); + + Assert.IsType>(msg.DefaultsValues); + Assert.Equal(new List(), msg.DefaultsValues); + + Assert.IsType>(msg.BoolValuesDefault); + Assert.Equal( + new List { false, true, false }, + msg.BoolValuesDefault); + + Assert.IsType>(msg.ByteValuesDefault); + Assert.Equal( + new List { 0, 1, 255 }, + msg.ByteValuesDefault); + + Assert.IsType>(msg.CharValuesDefault); + Assert.Equal( + new List { 0, 1, 127 }, + msg.CharValuesDefault); + + Assert.IsType>(msg.Float32ValuesDefault); + Assert.Equal( + new List { 1.125f, 0.0f, -1.125f}, + msg.Float32ValuesDefault); + + Assert.IsType>(msg.Float64ValuesDefault); + Assert.Equal( + new List { 3.1415, 0.0, -3.1415 }, + msg.Float64ValuesDefault); + + Assert.IsType>(msg.Int8ValuesDefault); + Assert.Equal( + new List { 0, 127, -128 }, + msg.Int8ValuesDefault); + + Assert.IsType>(msg.Uint8ValuesDefault); + Assert.Equal( + new List { 0, 1, 255 }, + msg.Uint8ValuesDefault); + + Assert.IsType>(msg.Int16ValuesDefault); + Assert.Equal( + new List { 0, 32767, -32768 }, + msg.Int16ValuesDefault); + + Assert.IsType>(msg.Uint16ValuesDefault); + Assert.Equal( + new List { 0, 1, 65535 }, + msg.Uint16ValuesDefault); + + Assert.IsType>(msg.Int32ValuesDefault); + Assert.Equal( + new List { 0, 2147483647, -2147483648 }, + msg.Int32ValuesDefault); + + Assert.IsType>(msg.Uint32ValuesDefault); + Assert.Equal( + new List { 0, 1, 4294967295 }, + msg.Uint32ValuesDefault); + + Assert.IsType>(msg.Int64ValuesDefault); + Assert.Equal( + new List { 0, 9223372036854775807, -9223372036854775808 }, + msg.Int64ValuesDefault); + + Assert.IsType>(msg.Uint64ValuesDefault); + Assert.Equal( + new List { 0, 1, 18446744073709551615 }, + msg.Uint64ValuesDefault); + + Assert.IsType>(msg.StringValuesDefault); + Assert.Equal( + new List { "", "max value", "min value" }, + msg.StringValuesDefault); } } } diff --git a/rcldotnet/test/test_services.cs b/rcldotnet/test/test_services.cs index 5b59d71e..7712d86b 100644 --- a/rcldotnet/test/test_services.cs +++ b/rcldotnet/test/test_services.cs @@ -1,3 +1,18 @@ +/* Copyright 2021-2022 Stefan Hoffmann + * + * 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. + */ + using ROS2; using Xunit; @@ -20,20 +35,20 @@ public void TestServiceAndClient() var client = clientNode.CreateClient("unittest_dotnet_service"); var request = new test_msgs.srv.BasicTypes_Request(); - request.Bool_value = true; - request.Byte_value = 36; - request.Char_value = 37; - request.Float32_value = 38.1f; - request.Float64_value = 39.1; - request.Int8_value = 40; - request.Uint8_value = 41; - request.Int16_value = 42; - request.Uint16_value = 43; - request.Int32_value = 44; - request.Uint32_value = 45; - request.Int64_value = 46; - request.Uint64_value = 47; - request.String_value = "one"; + request.BoolValue = true; + request.ByteValue = 36; + request.CharValue = 37; + request.Float32Value = 38.1f; + request.Float64Value = 39.1; + request.Int8Value = 40; + request.Uint8Value = 41; + request.Int16Value = 42; + request.Uint16Value = 43; + request.Int32Value = 44; + request.Uint32Value = 45; + request.Int64Value = 46; + request.Uint64Value = 47; + request.StringValue = "one"; var task = client.SendRequestAsync(request); @@ -48,54 +63,54 @@ public void TestServiceAndClient() } } - Assert.True(serviceReceivedRequest.Bool_value); - Assert.Equal(36, serviceReceivedRequest.Byte_value); - Assert.Equal(37, serviceReceivedRequest.Char_value); - Assert.Equal(38.1f, serviceReceivedRequest.Float32_value); - Assert.Equal(39.1, serviceReceivedRequest.Float64_value); - Assert.Equal(40, serviceReceivedRequest.Int8_value); - Assert.Equal(41, serviceReceivedRequest.Uint8_value); - Assert.Equal(42, serviceReceivedRequest.Int16_value); - Assert.Equal(43, serviceReceivedRequest.Uint16_value); - Assert.Equal(44, serviceReceivedRequest.Int32_value); - Assert.Equal((uint)45, serviceReceivedRequest.Uint32_value); - Assert.Equal(46, serviceReceivedRequest.Int64_value); - Assert.Equal((ulong)47, serviceReceivedRequest.Uint64_value); - Assert.Equal("one", serviceReceivedRequest.String_value); + Assert.True(serviceReceivedRequest.BoolValue); + Assert.Equal(36, serviceReceivedRequest.ByteValue); + Assert.Equal(37, serviceReceivedRequest.CharValue); + Assert.Equal(38.1f, serviceReceivedRequest.Float32Value); + Assert.Equal(39.1, serviceReceivedRequest.Float64Value); + Assert.Equal(40, serviceReceivedRequest.Int8Value); + Assert.Equal(41, serviceReceivedRequest.Uint8Value); + Assert.Equal(42, serviceReceivedRequest.Int16Value); + Assert.Equal(43, serviceReceivedRequest.Uint16Value); + Assert.Equal(44, serviceReceivedRequest.Int32Value); + Assert.Equal((uint)45, serviceReceivedRequest.Uint32Value); + Assert.Equal(46, serviceReceivedRequest.Int64Value); + Assert.Equal((ulong)47, serviceReceivedRequest.Uint64Value); + Assert.Equal("one", serviceReceivedRequest.StringValue); - Assert.True(clientReceivedResponse.Bool_value); - Assert.Equal(36, clientReceivedResponse.Byte_value); - Assert.Equal(37, clientReceivedResponse.Char_value); - Assert.Equal(38.1f, clientReceivedResponse.Float32_value); - Assert.Equal(39.1, clientReceivedResponse.Float64_value); - Assert.Equal(40, clientReceivedResponse.Int8_value); - Assert.Equal(41, clientReceivedResponse.Uint8_value); - Assert.Equal(42, clientReceivedResponse.Int16_value); - Assert.Equal(43, clientReceivedResponse.Uint16_value); - Assert.Equal(144, clientReceivedResponse.Int32_value); - Assert.Equal((uint)45, clientReceivedResponse.Uint32_value); - Assert.Equal(46, clientReceivedResponse.Int64_value); - Assert.Equal((ulong)47, clientReceivedResponse.Uint64_value); - Assert.Equal("one", clientReceivedResponse.String_value); + Assert.True(clientReceivedResponse.BoolValue); + Assert.Equal(36, clientReceivedResponse.ByteValue); + Assert.Equal(37, clientReceivedResponse.CharValue); + Assert.Equal(38.1f, clientReceivedResponse.Float32Value); + Assert.Equal(39.1, clientReceivedResponse.Float64Value); + Assert.Equal(40, clientReceivedResponse.Int8Value); + Assert.Equal(41, clientReceivedResponse.Uint8Value); + Assert.Equal(42, clientReceivedResponse.Int16Value); + Assert.Equal(43, clientReceivedResponse.Uint16Value); + Assert.Equal(144, clientReceivedResponse.Int32Value); + Assert.Equal((uint)45, clientReceivedResponse.Uint32Value); + Assert.Equal(46, clientReceivedResponse.Int64Value); + Assert.Equal((ulong)47, clientReceivedResponse.Uint64Value); + Assert.Equal("one", clientReceivedResponse.StringValue); void HandleRequest(test_msgs.srv.BasicTypes_Request req, test_msgs.srv.BasicTypes_Response response) { serviceReceivedRequest = req; - response.Bool_value = req.Bool_value; - response.Byte_value = req.Byte_value; - response.Char_value = req.Char_value; - response.Float32_value = req.Float32_value; - response.Float64_value = req.Float64_value; - response.Int8_value = req.Int8_value; - response.Uint8_value = req.Uint8_value; - response.Int16_value = req.Int16_value; - response.Uint16_value = req.Uint16_value; - response.Int32_value = req.Int32_value + 100; - response.Uint32_value = req.Uint32_value; - response.Int64_value = req.Int64_value; - response.Uint64_value = req.Uint64_value; - response.String_value = req.String_value; + response.BoolValue = req.BoolValue; + response.ByteValue = req.ByteValue; + response.CharValue = req.CharValue; + response.Float32Value = req.Float32Value; + response.Float64Value = req.Float64Value; + response.Int8Value = req.Int8Value; + response.Uint8Value = req.Uint8Value; + response.Int16Value = req.Int16Value; + response.Uint16Value = req.Uint16Value; + response.Int32Value = req.Int32Value + 100; + response.Uint32Value = req.Uint32Value; + response.Int64Value = req.Int64Value; + response.Uint64Value = req.Uint64Value; + response.StringValue = req.StringValue; } } } diff --git a/rosidl_generator_dotnet/resource/msg.cs.em b/rosidl_generator_dotnet/resource/msg.cs.em index bb5b336c..69350cde 100644 --- a/rosidl_generator_dotnet/resource/msg.cs.em +++ b/rosidl_generator_dotnet/resource/msg.cs.em @@ -1,4 +1,6 @@ @{ +from ast import literal_eval + from rosidl_generator_dotnet import get_field_name from rosidl_generator_dotnet import get_dotnet_type from rosidl_generator_dotnet import get_builtin_dotnet_type @@ -24,9 +26,9 @@ public class @(type_name) : global::ROS2.IRosMessage { @[for member in message.structure.members]@ @[ if isinstance(member.type, Array)]@ - public const int @(get_field_name(type_name, member.name))_Length = @(member.type.size); + public const int @(get_field_name(type_name, member.name))Length = @(member.type.size); @[ elif isinstance(member.type, AbstractSequence) and member.type.has_maximum_size()]@ - public const int @(get_field_name(type_name, member.name))_MaxCount = @(member.type.maximum_size); + public const int @(get_field_name(type_name, member.name))MaxCount = @(member.type.maximum_size); @[ end if]@ @[end for]@ @@ -34,29 +36,65 @@ public class @(type_name) : global::ROS2.IRosMessage { { @[for member in message.structure.members]@ @[ if isinstance(member.type, Array)]@ - @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)]; @[ if isinstance(member.type.value_type, AbstractString)]@ +@[ if member.has_annotation('default')]@ + @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)] + { +@[ for val in literal_eval(member.get_annotation_value('default')['value'])]@ + @(constant_value_to_dotnet(member.type.value_type, val)), +@[ end for]@ + }; +@[ else]@ + @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)]; for (var i__local_variable = 0; i__local_variable < @(member.type.size); i__local_variable++) { @(get_field_name(type_name, member.name))[i__local_variable] = ""; } +@[ end if]@ @[ elif isinstance(member.type.value_type, BasicType)]@ +@[ if member.has_annotation('default')]@ + @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)] + { +@[ for val in literal_eval(member.get_annotation_value('default')['value'])]@ + @(constant_value_to_dotnet(member.type.value_type, val)), +@[ end for]@ + }; +@[ else]@ + @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)]; @# Basic types get initialized by the array constructor. +@[ end if]@ @[ elif isinstance(member.type.value_type, AbstractWString)]@ // TODO: Unicode types are not supported @[ else]@ + @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type.value_type))[@(member.type.size)]; for (var i__local_variable = 0; i__local_variable < @(member.type.size); i__local_variable++) { @(get_field_name(type_name, member.name))[i__local_variable] = new @(get_dotnet_type(member.type.value_type))(); } @[ end if]@ @[ elif isinstance(member.type, AbstractSequence)]@ +@[ if member.has_annotation('default')]@ + @(get_field_name(type_name, member.name)) = new List<@(get_dotnet_type(member.type.value_type))>() + { +@[ for val in literal_eval(member.get_annotation_value('default')['value'])]@ + @(constant_value_to_dotnet(member.type.value_type, val)), +@[ end for]@ + }; +@[ else]@ @(get_field_name(type_name, member.name)) = new List<@(get_dotnet_type(member.type.value_type))>(); +@[ end if]@ @[ elif isinstance(member.type, AbstractWString)]@ // TODO: Unicode types are not supported @[ elif isinstance(member.type, BasicType)]@ +@[ if member.has_annotation('default')]@ + @(get_field_name(type_name, member.name)) = @(constant_value_to_dotnet(member.type, member.get_annotation_value('default')['value'])); +@[ end if]@ @[ elif isinstance(member.type, AbstractString)]@ +@[ if member.has_annotation('default')]@ + @(get_field_name(type_name, member.name)) = @(constant_value_to_dotnet(member.type, member.get_annotation_value('default')['value'])); +@[ else]@ @(get_field_name(type_name, member.name)) = ""; +@[ end if]@ @[ else]@ @(get_field_name(type_name, member.name)) = new @(get_dotnet_type(member.type))(); @[ end if]@ diff --git a/rosidl_generator_dotnet/rosidl_generator_dotnet/__init__.py b/rosidl_generator_dotnet/rosidl_generator_dotnet/__init__.py index 7528c15d..95310ecc 100644 --- a/rosidl_generator_dotnet/rosidl_generator_dotnet/__init__.py +++ b/rosidl_generator_dotnet/rosidl_generator_dotnet/__init__.py @@ -53,6 +53,7 @@ def generate_dotnet(generator_arguments_file, typesupport_impls): def escape_string(s): s = s.replace('\\', '\\\\') s = s.replace("'", "\\'") + s = s.replace("\"", "\\\"") return s @@ -149,12 +150,12 @@ def msg_type_to_c(type_): assert isinstance(type_, BasicType) return BASIC_IDL_TYPES_TO_C[type_.typename] -def upperfirst(s): - return s[0].capitalize() + s[1:] - +# Taken from http://stackoverflow.com/a/6425628 +def convert_lower_case_underscore_to_camel_case(word): + return ''.join(x.capitalize() or '_' for x in word.split('_')) def get_field_name(type_name, field_name): - if upperfirst(field_name) == type_name: + if convert_lower_case_underscore_to_camel_case(field_name) == type_name: return "{0}_".format(type_name) else: - return upperfirst(field_name) + return convert_lower_case_underscore_to_camel_case(field_name)