tests: prefer dynamically allocated buffers
[project/libubox.git] / tests / fuzz / test-fuzz.c
index 7153847e0825b648706925dd4783c35e3a9132ad..026a3fd53a73b3c2645ea6a3cc8a606c75a1a5d7 100644 (file)
@@ -1,10 +1,13 @@
 #include <stdio.h>
 #include <stdint.h>
 #include <stddef.h>
+#include <limits.h>
 
 #include "blob.h"
 #include "blobmsg.h"
 
+#define BLOBMSG_TYPE_TROUBLE INT_MAX
+
 static void fuzz_blobmsg_parse(const uint8_t *data, size_t size)
 {
        enum {
@@ -14,6 +17,19 @@ static void fuzz_blobmsg_parse(const uint8_t *data, size_t size)
                __FOO_MAX
        };
 
+       static const int blobmsg_type[] = {
+               BLOBMSG_TYPE_UNSPEC,
+               BLOBMSG_TYPE_ARRAY,
+               BLOBMSG_TYPE_TABLE,
+               BLOBMSG_TYPE_STRING,
+               BLOBMSG_TYPE_INT64,
+               BLOBMSG_TYPE_INT32,
+               BLOBMSG_TYPE_INT16,
+               BLOBMSG_TYPE_INT8,
+               BLOBMSG_TYPE_DOUBLE,
+               BLOBMSG_TYPE_TROUBLE,
+       };
+
        static const struct blobmsg_policy foo_policy[] = {
                [FOO_MESSAGE] = {
                        .name = "message",
@@ -33,6 +49,14 @@ static void fuzz_blobmsg_parse(const uint8_t *data, size_t size)
 
        blobmsg_parse(foo_policy, __FOO_MAX, tb, (uint8_t *)data, size);
        blobmsg_parse_array(foo_policy, __FOO_MAX, tb, (uint8_t *)data, size);
+
+       blobmsg_check_attr_len((struct blob_attr *)data, false, size);
+       blobmsg_check_attr_len((struct blob_attr *)data, true, size);
+
+       for (size_t i=0; i < ARRAY_SIZE(blobmsg_type); i++) {
+               blobmsg_check_array_len((struct blob_attr *)data, blobmsg_type[i], size);
+               blobmsg_check_attr_list_len((struct blob_attr *)data, blobmsg_type[i], size);
+       }
 }
 
 static void fuzz_blob_parse(const uint8_t *data, size_t size)
@@ -64,13 +88,21 @@ static void fuzz_blob_parse(const uint8_t *data, size_t size)
        struct blob_attr *foo[__FOO_ATTR_MAX];
        struct blob_attr *buf = (struct blob_attr *)data;
 
-       blob_parse(buf, foo, foo_policy, __FOO_ATTR_MAX);
+       blob_parse_untrusted(buf, size, foo, foo_policy, __FOO_ATTR_MAX);
 }
 
-int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
+int LLVMFuzzerTestOneInput(const uint8_t *input, size_t size)
 {
+       uint8_t *data;
+
+       data = malloc(size);
+       if (!data)
+               return -1;
+
+       memcpy(data, input, size);
        fuzz_blob_parse(data, size);
        fuzz_blobmsg_parse(data, size);
+       free(data);
 
        return 0;
 }