]> git.ipfire.org Git - thirdparty/json-c.git/commitdiff
pull in fuzzers, add CI scripts later 402/head
authorChris Wolfe <chriswwolfe@gmail.com>
Tue, 6 Feb 2018 01:24:51 +0000 (19:24 -0600)
committerChris Wolfe <chriswwolfe@gmail.com>
Tue, 6 Feb 2018 01:26:24 +0000 (19:26 -0600)
ChangeLog
fuzz/README.md [new file with mode: 0644]
fuzz/build.sh [new file with mode: 0755]
fuzz/tokener_parse_ex_fuzzer.cc [new file with mode: 0644]
fuzz/tokener_parse_ex_fuzzer.dict [new file with mode: 0644]

index 5dd29abd6e8563535926d129e52f6af6ec9a546d..8f8aa8d033d2fb23ea6de7ec6c4c3cee9a5f5927 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -9,6 +9,9 @@ Deprecated and removed features:
 * lh_table_lookup() has been removed, use lh_table_lookup_ex() instead.
 * Remove TRUE and FALSE defines, use 1 and 0 instead.
 
+Build changes:
+--------------
+* Add a top level fuzz directory for fuzzers run by OSS-Fuzz
 
 0.13 (up to commit 5dae561, 2017/11/29)
 =================================
diff --git a/fuzz/README.md b/fuzz/README.md
new file mode 100644 (file)
index 0000000..237c1da
--- /dev/null
@@ -0,0 +1,6 @@
+# Fuzzers
+
+This directory contains fuzzers that
+target [llvm's LibFuzzer](https://llvm.org/docs/LibFuzzer.html). They are built
+and run automatically by
+Google's [OSS-Fuzz](https://github.com/google/oss-fuzz/) infrastructure.
diff --git a/fuzz/build.sh b/fuzz/build.sh
new file mode 100755 (executable)
index 0000000..30c3f77
--- /dev/null
@@ -0,0 +1,30 @@
+#!/bin/bash -eu
+# Copyright 2018 Google Inc.
+#
+# Licensed 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.
+#
+################################################################################
+
+./autogen.sh
+./configure --enable-static --disable-shared
+make -j$(nproc) all
+ar rc json_c.a *.o
+
+cp $SRC/*.dict $OUT/
+
+for f in $SRC/*_fuzzer.cc; do
+    fuzzer=$(basename "$f" _fuzzer.cc)
+    $CXX $CXXFLAGS -std=c++11 -I$SRC/json-c \
+         $SRC/${fuzzer}_fuzzer.cc -o $OUT/${fuzzer}_fuzzer \
+         -lFuzzingEngine $SRC/json-c/json_c.a
+done
diff --git a/fuzz/tokener_parse_ex_fuzzer.cc b/fuzz/tokener_parse_ex_fuzzer.cc
new file mode 100644 (file)
index 0000000..c0a1c3d
--- /dev/null
@@ -0,0 +1,13 @@
+#include <stdint.h>
+
+#include <json.h>
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
+  const char *data1 = reinterpret_cast<const char *>(data);
+  json_tokener *tok = json_tokener_new();
+  json_object *obj = json_tokener_parse_ex(tok, data1, size);
+
+  json_object_put(obj);
+  json_tokener_free(tok);
+  return 0;
+}
diff --git a/fuzz/tokener_parse_ex_fuzzer.dict b/fuzz/tokener_parse_ex_fuzzer.dict
new file mode 100644 (file)
index 0000000..23c6fa2
--- /dev/null
@@ -0,0 +1,18 @@
+"{"
+"}"
+","
+"["
+"]"
+","
+":"
+"e"
+"e+"
+"e-"
+"E"
+"E+"
+"E-"
+"\""
+"null"
+"1"
+"1.234"
+"3e4"