firmware/extra/nanopb/tests/map/decode_map.c
Patrick Moessler 0c83634f42 Initial commit
2019-10-13 00:37:11 +02:00

60 lines
1.5 KiB
C

/* 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;
}
}