Finish the testcase for extensions
This commit is contained in:
1
tests/extensions.options
Normal file
1
tests/extensions.options
Normal file
@@ -0,0 +1 @@
|
|||||||
|
* max_size:16
|
||||||
@@ -3,3 +3,13 @@ import 'alltypes.proto';
|
|||||||
extend AllTypes {
|
extend AllTypes {
|
||||||
optional int32 AllTypes_extensionfield1 = 255;
|
optional int32 AllTypes_extensionfield1 = 255;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message ExtensionMessage {
|
||||||
|
extend AllTypes {
|
||||||
|
optional ExtensionMessage AllTypes_extensionfield2 = 254;
|
||||||
|
}
|
||||||
|
|
||||||
|
required string test1 = 1;
|
||||||
|
required int32 test2 = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,11 @@
|
|||||||
#include "alltypes.pb.h"
|
#include "alltypes.pb.h"
|
||||||
#include "extensions.pb.h"
|
#include "extensions.pb.h"
|
||||||
|
|
||||||
|
#define TEST(x) if (!(x)) { \
|
||||||
|
printf("Test " #x " failed.\n"); \
|
||||||
|
return 2; \
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
uint8_t buffer[1024];
|
uint8_t buffer[1024];
|
||||||
@@ -14,9 +19,14 @@ int main(int argc, char **argv)
|
|||||||
pb_istream_t stream = pb_istream_from_buffer(buffer, count);
|
pb_istream_t stream = pb_istream_from_buffer(buffer, count);
|
||||||
|
|
||||||
AllTypes alltypes = {};
|
AllTypes alltypes = {};
|
||||||
|
|
||||||
int32_t extensionfield1;
|
int32_t extensionfield1;
|
||||||
pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL};
|
pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL};
|
||||||
alltypes.extensions = &ext1;
|
alltypes.extensions = &ext1;
|
||||||
|
|
||||||
|
ExtensionMessage extensionfield2 = {};
|
||||||
|
pb_extension_t ext2 = {&ExtensionMessage_AllTypes_extensionfield2, &extensionfield2, NULL};
|
||||||
|
ext1.next = &ext2;
|
||||||
|
|
||||||
if (!pb_decode(&stream, AllTypes_fields, &alltypes))
|
if (!pb_decode(&stream, AllTypes_fields, &alltypes))
|
||||||
{
|
{
|
||||||
@@ -24,11 +34,9 @@ int main(int argc, char **argv)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (extensionfield1 != 12345)
|
TEST(extensionfield1 == 12345)
|
||||||
{
|
TEST(strcmp(extensionfield2.test1, "test") == 0)
|
||||||
printf("Wrong value for extension field: %d\n", extensionfield1);
|
TEST(extensionfield2.test2 == 54321)
|
||||||
return 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,10 +11,14 @@
|
|||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
AllTypes alltypes = {};
|
AllTypes alltypes = {};
|
||||||
|
|
||||||
int32_t extensionfield1 = 12345;
|
int32_t extensionfield1 = 12345;
|
||||||
pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL};
|
pb_extension_t ext1 = {&AllTypes_extensionfield1, &extensionfield1, NULL};
|
||||||
|
|
||||||
alltypes.extensions = &ext1;
|
alltypes.extensions = &ext1;
|
||||||
|
|
||||||
|
ExtensionMessage extensionfield2 = {"test", 54321};
|
||||||
|
pb_extension_t ext2 = {&ExtensionMessage_AllTypes_extensionfield2, &extensionfield2, NULL};
|
||||||
|
ext1.next = &ext2;
|
||||||
|
|
||||||
uint8_t buffer[1024];
|
uint8_t buffer[1024];
|
||||||
pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer));
|
pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer));
|
||||||
|
|||||||
Reference in New Issue
Block a user