Coverage Report

Created: 2025-12-31 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/unpack_fuzzer.c
Line
Count
Source
1
/*
2
 * Copyright 2025 Google LLC
3
 *
4
 * Licensed under the Apache License, Version 2.0 (the "License");
5
 * you may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at
7
 *
8
 *      http://www.apache.org/licenses/LICENSE-2.0
9
 *
10
 * Unless required by applicable law or agreed to in writing, software
11
 * distributed under the License is distributed on an "AS IS" BASIS,
12
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
 * See the License for the specific language governing permissions and
14
 * limitations under the License.
15
 */
16
17
#include <stdint.h>
18
#include <stddef.h>
19
20
#include <protobuf-c/protobuf-c.h>
21
#include "t/test-full.pb-c.h"
22
23
2.11k
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
24
    /*
25
     * Test the core protobuf-c parsing by unpacking as TestMess.
26
     * This message type contains repeated fields of all types including
27
     * nested messages, which exercises all parsing code paths in
28
     * protobuf_c_message_unpack().
29
     */
30
2.11k
    ProtobufCMessage *msg = protobuf_c_message_unpack(
31
2.11k
        &foo__test_mess__descriptor, NULL, size, data);
32
2.11k
    if (msg != NULL) {
33
1.29k
        protobuf_c_message_free_unpacked(msg, NULL);
34
1.29k
    }
35
36
2.11k
    return 0;
37
2.11k
}