Coverage Report

Created: 2026-06-17 06:17

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/qpid-proton/c/tests/fuzz/fuzz-message-decode.c
Line
Count
Source
1
/*
2
 *
3
 * Licensed to the Apache Software Foundation (ASF) under one
4
 * or more contributor license agreements.  See the NOTICE file
5
 * distributed with this work for additional information
6
 * regarding copyright ownership.  The ASF licenses this file
7
 * to you under the Apache License, Version 2.0 (the
8
 * "License"); you may not use this file except in compliance
9
 * with the License.  You may obtain a copy of the License at
10
 *
11
 *   http://www.apache.org/licenses/LICENSE-2.0
12
 *
13
 * Unless required by applicable law or agreed to in writing,
14
 * software distributed under the License is distributed on an
15
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16
 * KIND, either express or implied.  See the License for the
17
 * specific language governing permissions and limitations
18
 * under the License.
19
 *
20
 */
21
22
#include <stdint.h>
23
24
#include "proton/message.h"
25
26
#include "libFuzzingEngine.h"
27
28
4.98k
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
29
4.98k
  if (Size < 1) {
30
    // pn_message_decode would die on assert
31
0
    return 0;
32
0
  }
33
4.98k
  pn_message_t *msg = pn_message();
34
4.98k
  int ret = pn_message_decode(msg, (const char *)Data, Size);
35
4.98k
  if (ret == 0) {
36
    // FUTURE: do something like encode msg and compare again with Data
37
4.98k
  }
38
4.98k
  if (msg != NULL) {
39
4.98k
    pn_message_free(msg);
40
4.98k
  }
41
4.98k
  return 0;
42
4.98k
}