This is an automated email from the ASF dual-hosted git repository.
swebb2066 pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/logging-log4cxx.git
The following commit(s) were added to refs/heads/master by this push:
new dba1b066 Add JSONLayout fuzzer (#453)
dba1b066 is described below
commit dba1b0660e4cd64640d8a76d267f01e342c56854
Author: AdamKorcz <[email protected]>
AuthorDate: Wed Jan 22 23:22:41 2025 +0000
Add JSONLayout fuzzer (#453)
---
src/fuzzers/cpp/CMakeLists.txt | 2 +-
src/fuzzers/cpp/JSONLayoutFuzzer.cpp | 86 ++++++++++++++++++++++++++++++++++++
2 files changed, 87 insertions(+), 1 deletion(-)
diff --git a/src/fuzzers/cpp/CMakeLists.txt b/src/fuzzers/cpp/CMakeLists.txt
index b4ae9606..848b064f 100644
--- a/src/fuzzers/cpp/CMakeLists.txt
+++ b/src/fuzzers/cpp/CMakeLists.txt
@@ -15,7 +15,7 @@
# limitations under the License.
#
-set(ALL_LOG4CXX_FUZZERS PatternLayoutFuzzer XMLLayoutFuzzer HTMLLayoutFuzzer)
+set(ALL_LOG4CXX_FUZZERS PatternLayoutFuzzer XMLLayoutFuzzer HTMLLayoutFuzzer
JSONLayoutFuzzer)
set(LOG4CXX_CHAR "utf-8")
# Get the most recent Git commit ID
diff --git a/src/fuzzers/cpp/JSONLayoutFuzzer.cpp
b/src/fuzzers/cpp/JSONLayoutFuzzer.cpp
new file mode 100644
index 00000000..ef9dd231
--- /dev/null
+++ b/src/fuzzers/cpp/JSONLayoutFuzzer.cpp
@@ -0,0 +1,86 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "stdint.h"
+#include <log4cxx/logstring.h>
+#include <log4cxx/ndc.h>
+#include <log4cxx/helpers/stringhelper.h>
+#include <fuzzer/FuzzedDataProvider.h>
+#include <log4cxx/mdc.h>
+#include <log4cxx/jsonlayout.h>
+
+using namespace log4cxx;
+using namespace log4cxx::helpers;
+using namespace log4cxx::spi;
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
+ // Setup JSONLayout
+ JSONLayout layout;
+
+ FuzzedDataProvider fdp(data, size);
+
+ // Optional locationinfo
+ if (fdp.ConsumeBool()) {
+ layout.setOption(LOG4CXX_STR("LOCATIONINFO"),
LOG4CXX_STR("true"));
+ }
+ // Optional threadinfo
+ if (fdp.ConsumeBool()) {
+ layout.setOption(LOG4CXX_STR("THREADINFO"),
LOG4CXX_STR("true"));
+ }
+ // Optional prettyprint
+ if (fdp.ConsumeBool()) {
+ layout.setOption(LOG4CXX_STR("PRETTYPRINT"),
LOG4CXX_STR("true"));
+ }
+
+ // Create random strings we need later
+ std::string key1 = fdp.ConsumeRandomLengthString();
+ std::string val1 = fdp.ConsumeRandomLengthString();
+ std::string key2 = fdp.ConsumeRandomLengthString();
+ std::string val2 = fdp.ConsumeRandomLengthString();
+ std::string key3 = fdp.ConsumeRandomLengthString();
+ std::string val3 = fdp.ConsumeRandomLengthString();
+ std::string key4 = fdp.ConsumeRandomLengthString();
+ std::string val4 = fdp.ConsumeRandomLengthString();
+ std::string ndcMessage = fdp.ConsumeRandomLengthString();
+ std::string loggerStr = fdp.ConsumeRandomLengthString();
+ std::string content = fdp.ConsumeRemainingBytesAsString();
+
+ log4cxx::LogString logger = LOG4CXX_STR(loggerStr);
+ log4cxx::LevelPtr level = log4cxx::Level::getInfo();
+ log4cxx::NDC::push(ndcMessage);
+ log4cxx::spi::LoggingEventPtr event = log4cxx::spi::LoggingEventPtr(
+ new log4cxx::spi::LoggingEvent(
+ logger, level, LOG4CXX_STR(content), LOG4CXX_LOCATION));
+
+ // Set properties
+ event->setProperty(LOG4CXX_STR(key1), LOG4CXX_STR(val1));
+ event->setProperty(LOG4CXX_STR(key2), LOG4CXX_STR(val2));
+
+ // Set MDC
+ log4cxx::MDC::put(key3, val3);
+ log4cxx::MDC::put(key4, val4);
+
+ // Call the target API
+ log4cxx::helpers::Pool p;
+ log4cxx::LogString result;
+ layout.format(result, event, p);
+
+ // Clean up
+ log4cxx::NDC::clear();
+ log4cxx::MDC::clear();
+ return 0;
+}