diff options
author | 2015-09-13 11:38:54 +0300 | |
---|---|---|
committer | 2015-09-13 11:38:54 +0300 | |
commit | 6e72df4808aa138f1396ad098ce2d06a6feba882 (patch) | |
tree | 4154ca61069643a2a668f016a3263b152efcdea1 /tests/regression/issue_166/enum_encoded_size.c | |
parent | 0b29baf5deaa4213c08ee71fa55d3d0b2ed709e4 (diff) |
Fix maximum encoded size for negative enums (issue #166).
Diffstat (limited to 'tests/regression/issue_166/enum_encoded_size.c')
-rw-r--r-- | tests/regression/issue_166/enum_encoded_size.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/regression/issue_166/enum_encoded_size.c b/tests/regression/issue_166/enum_encoded_size.c new file mode 100644 index 0000000..84e1c7d --- /dev/null +++ b/tests/regression/issue_166/enum_encoded_size.c @@ -0,0 +1,43 @@ +#include <stdio.h> +#include <string.h> +#include <pb_encode.h> +#include "unittests.h" +#include "enums.pb.h" + +int main() +{ + int status = 0; + + uint8_t buf[256]; + SignedMsg msg1; + UnsignedMsg msg2; + pb_ostream_t s; + + { + COMMENT("Test negative value of signed enum"); + /* Negative value should take up the maximum size */ + msg1.value = SignedEnum_SE_MIN; + s = pb_ostream_from_buffer(buf, sizeof(buf)); + TEST(pb_encode(&s, SignedMsg_fields, &msg1)); + TEST(s.bytes_written == SignedMsg_size); + + COMMENT("Test positive value of signed enum"); + /* Positive value should be smaller */ + msg1.value = SignedEnum_SE_MAX; + s = pb_ostream_from_buffer(buf, sizeof(buf)); + TEST(pb_encode(&s, SignedMsg_fields, &msg1)); + TEST(s.bytes_written < SignedMsg_size); + } + + { + COMMENT("Test positive value of unsigned enum"); + /* This should take up the maximum size */ + msg2.value = UnsignedEnum_UE_MAX; + s = pb_ostream_from_buffer(buf, sizeof(buf)); + TEST(pb_encode(&s, UnsignedMsg_fields, &msg2)); + TEST(s.bytes_written == UnsignedMsg_size); + } + + return status; +} + |