diff options
author | Petteri Aimonen <jpa@git.mail.kapsi.fi> | 2013-09-11 16:13:19 +0300 |
---|---|---|
committer | Petteri Aimonen <jpa@git.mail.kapsi.fi> | 2013-09-11 16:13:19 +0300 |
commit | 61ad04afd5236e2a6a0d4b4f2caa3bab4a820c99 (patch) | |
tree | beea1aa405bb022927fc0eb5b8f4982083b68458 /tests/missing_fields/missing_fields.c | |
parent | 5b9ad17dc2014d7506a7dde92281d8c36a1433e4 (diff) | |
parent | 9f93d39f728c3e87b0ab482aa604c5cad4b1c86e (diff) |
Merge branch 'dev_tests_using_scons'
Diffstat (limited to 'tests/missing_fields/missing_fields.c')
-rw-r--r-- | tests/missing_fields/missing_fields.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/tests/missing_fields/missing_fields.c b/tests/missing_fields/missing_fields.c new file mode 100644 index 00000000..b9a273a2 --- /dev/null +++ b/tests/missing_fields/missing_fields.c @@ -0,0 +1,50 @@ +/* Checks that missing required fields are detected properly */ + +#include <stdio.h> +#include <pb_encode.h> +#include <pb_decode.h> +#include "missing_fields.pb.h" + +int main() +{ + uint8_t buffer[512]; + + /* Create a message with one missing field */ + { + MissingField msg = {0}; + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + + if (!pb_encode(&stream, MissingField_fields, &msg)) + { + printf("Encode failed.\n"); + return 1; + } + } + + /* Test that it decodes properly if we don't require that field */ + { + MissingField msg = {0}; + pb_istream_t stream = pb_istream_from_buffer(buffer, sizeof(buffer)); + + if (!pb_decode(&stream, MissingField_fields, &msg)) + { + printf("Decode failed: %s\n", PB_GET_ERROR(&stream)); + return 2; + } + } + + /* Test that it does *not* decode properly if we require the field */ + { + AllFields msg = {0}; + pb_istream_t stream = pb_istream_from_buffer(buffer, sizeof(buffer)); + + if (pb_decode(&stream, AllFields_fields, &msg)) + { + printf("Decode didn't detect missing field.\n"); + return 3; + } + } + + return 0; /* All ok */ +} + |