diff options
-rw-r--r-- | tests/extensions.options | 1 | ||||
-rw-r--r-- | tests/extensions.proto | 10 | ||||
-rw-r--r-- | tests/test_decode_extensions.c | 18 | ||||
-rw-r--r-- | tests/test_encode_extensions.c | 6 |
4 files changed, 29 insertions, 6 deletions
diff --git a/tests/extensions.options b/tests/extensions.options new file mode 100644 index 00000000..a5cd61dd --- /dev/null +++ b/tests/extensions.options @@ -0,0 +1 @@ +* max_size:16 diff --git a/tests/extensions.proto b/tests/extensions.proto index 12c7c9a5..cbffdce6 100644 --- a/tests/extensions.proto +++ b/tests/extensions.proto @@ -3,3 +3,13 @@ import 'alltypes.proto'; extend AllTypes { optional int32 AllTypes_extensionfield1 = 255; } + +message ExtensionMessage { + extend AllTypes { + optional ExtensionMessage AllTypes_extensionfield2 = 254; + } + + required string test1 = 1; + required int32 test2 = 2; +} + diff --git a/tests/test_decode_extensions.c b/tests/test_decode_extensions.c index b384c337..ef6a0228 100644 --- a/tests/test_decode_extensions.c +++ b/tests/test_decode_extensions.c @@ -7,6 +7,11 @@ #include "alltypes.pb.h" #include "extensions.pb.h" +#define TEST(x) if (!(x)) { \ + printf("Test " #x " failed.\n"); \ + return 2; \ + } + int main(int argc, char **argv) { uint8_t buffer[1024]; @@ -14,9 +19,14 @@ int main(int argc, char **argv) pb_istream_t stream = pb_istream_from_buffer(buffer, count); AllTypes alltypes = {}; + int32_t extensionfield1; pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL}; alltypes.extensions = &ext1; + + ExtensionMessage extensionfield2 = {}; + pb_extension_t ext2 = {&ExtensionMessage_AllTypes_extensionfield2, &extensionfield2, NULL}; + ext1.next = &ext2; if (!pb_decode(&stream, AllTypes_fields, &alltypes)) { @@ -24,11 +34,9 @@ int main(int argc, char **argv) return 1; } - if (extensionfield1 != 12345) - { - printf("Wrong value for extension field: %d\n", extensionfield1); - return 2; - } + TEST(extensionfield1 == 12345) + TEST(strcmp(extensionfield2.test1, "test") == 0) + TEST(extensionfield2.test2 == 54321) return 0; } diff --git a/tests/test_encode_extensions.c b/tests/test_encode_extensions.c index c889dec6..8857f148 100644 --- a/tests/test_encode_extensions.c +++ b/tests/test_encode_extensions.c @@ -11,10 +11,14 @@ int main(int argc, char **argv) { AllTypes alltypes = {}; + int32_t extensionfield1 = 12345; pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL}; - alltypes.extensions = &ext1; + + ExtensionMessage extensionfield2 = {"test", 54321}; + pb_extension_t ext2 = {&ExtensionMessage_AllTypes_extensionfield2, &extensionfield2, NULL}; + ext1.next = &ext2; uint8_t buffer[1024]; pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); |