Coverage Report

Created: 2024-07-27 07:03

/src/log_fuzzer.cc
Line
Count
Source (jump to first uncovered line)
1
// Copyright 2020 Google LLC
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//      http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
#include <cstddef>
16
17
#include <fuzzer/FuzzedDataProvider.h>
18
19
#include "spdlog/spdlog.h"
20
#include "spdlog/sinks/basic_file_sink.h"
21
22
6.07k
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
23
6.07k
  static std::shared_ptr<spdlog::logger> my_logger;
24
6.07k
  if (!my_logger.get()) {
25
2
    my_logger = spdlog::basic_logger_mt("basic_logger", "/dev/null");
26
2
    spdlog::set_default_logger(my_logger);
27
2
  }
28
29
6.07k
  if (size == 0) {
30
0
    return 0;
31
0
  }
32
33
34
6.07k
  FuzzedDataProvider stream(data, size);
35
36
6.07k
  const unsigned long size_arg = stream.ConsumeIntegral<unsigned long>();
37
6.07k
  const unsigned long int_arg = stream.ConsumeIntegral<unsigned long>();
38
6.07k
  const std::string string_arg = stream.ConsumeRandomLengthString(size);
39
6.07k
  const std::string format_string = stream.ConsumeRemainingBytesAsString();
40
41
6.07k
  spdlog::info(format_string.c_str(), size_arg, int_arg, string_arg);
42
6.07k
  spdlog::trace(format_string.c_str(), size_arg, int_arg, string_arg);
43
6.07k
  spdlog::debug(format_string.c_str(), size_arg, int_arg, string_arg);
44
6.07k
  spdlog::error(format_string.c_str(), size_arg, int_arg, string_arg);
45
6.07k
  spdlog::warn(format_string.c_str(), size_arg, int_arg, string_arg);
46
6.07k
  spdlog::critical(format_string.c_str(), size_arg, int_arg, string_arg);
47
48
6.07k
  SPDLOG_INFO(format_string.c_str(), size_arg, int_arg, string_arg);
49
6.07k
  SPDLOG_TRACE(format_string.c_str(), size_arg, int_arg, string_arg);
50
6.07k
  SPDLOG_DEBUG(format_string.c_str(), size_arg, int_arg, string_arg);
51
6.07k
  SPDLOG_ERROR(format_string.c_str(), size_arg, int_arg, string_arg);
52
6.07k
  SPDLOG_WARN(format_string.c_str(), size_arg, int_arg, string_arg);
53
6.07k
  SPDLOG_CRITICAL(format_string.c_str(), size_arg, int_arg, string_arg);
54
55
6.07k
  return 0;
56
6.07k
}