aboutsummaryrefslogtreecommitdiff
path: root/tests/map/decode_map.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/map/decode_map.c')
-rw-r--r--tests/map/decode_map.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/tests/map/decode_map.c b/tests/map/decode_map.c
new file mode 100644
index 0000000..c798b03
--- /dev/null
+++ b/tests/map/decode_map.c
@@ -0,0 +1,60 @@
+/* Decode a message using map field */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <pb_decode.h>
+#include "map.pb.h"
+#include "test_helpers.h"
+#include "unittests.h"
+
+/* Helper function to find an entry in the list. Not as efficient as a real
+ * hashmap or similar would be, but suitable for small arrays. */
+MyMessage_NumbersEntry *find_entry(MyMessage *msg, const char *key)
+{
+ int i;
+ for (i = 0; i < msg->numbers_count; i++)
+ {
+ if (strcmp(msg->numbers[i].key, key) == 0)
+ {
+ return &msg->numbers[i];
+ }
+ }
+ return NULL;
+}
+
+int main(int argc, char **argv)
+{
+ uint8_t buffer[MyMessage_size];
+ size_t count;
+
+ SET_BINARY_MODE(stdin);
+ count = fread(buffer, 1, sizeof(buffer), stdin);
+
+ if (!feof(stdin))
+ {
+ printf("Message does not fit in buffer\n");
+ return 1;
+ }
+
+ {
+ int status = 0;
+ MyMessage msg = MyMessage_init_zero;
+ MyMessage_NumbersEntry *e;
+ pb_istream_t stream = pb_istream_from_buffer(buffer, count);
+
+ if (!pb_decode(&stream, MyMessage_fields, &msg))
+ {
+ fprintf(stderr, "Decoding failed\n");
+ return 2;
+ }
+
+ TEST((e = find_entry(&msg, "one")) && e->value == 1);
+ TEST((e = find_entry(&msg, "two")) && e->value == 2);
+ TEST((e = find_entry(&msg, "seven")) && e->value == 7);
+ TEST(!find_entry(&msg, "zero"));
+
+ return status;
+ }
+}
+