pgsql: Add built-in fuzzing harnesses for security testing. - Mailing list pgsql-committers

From Andrew Dunstan
Subject pgsql: Add built-in fuzzing harnesses for security testing.
Date
Msg-id E1wBByO-000Iys-28@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Add built-in fuzzing harnesses for security testing.

Add 12 libFuzzer-compatible fuzzing harnesses behind a new -Dfuzzing=true
meson option.  Each harness implements LLVMFuzzerTestOneInput() and can
also be built in standalone mode (reading from files) when no fuzzer
engine is detected.

Frontend targets (no backend dependencies):
  fuzz_json            - non-incremental JSON parser (pg_parse_json)
  fuzz_json_incremental - incremental/chunked JSON parser
  fuzz_conninfo        - libpq connection string parser (PQconninfoParse)
  fuzz_pglz            - PGLZ decompressor (pglz_decompress)
  fuzz_unescapebytea   - libpq bytea unescape (PQunescapeBytea)
  fuzz_b64decode       - base64 decoder (pg_b64_decode)
  fuzz_saslprep        - SASLprep normalization (pg_saslprep)
  fuzz_parsepgarray    - array literal parser (parsePGArray)
  fuzz_pgbench_expr    - pgbench expression parser (via Bison/Flex)

Backend targets (link against postgres_lib):
  fuzz_rawparser       - SQL raw parser (raw_parser)
  fuzz_regex           - regex engine (pg_regcomp/pg_regexec)
  fuzz_typeinput       - type input functions (numeric/date/timestamp/interval)

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/4a18907b412e77684bf888ad6d1b4844d220196a

Modified Files
--------------
meson_options.txt                        |   3 +
src/test/fuzzing/fuzz_b64decode.c        |  98 ++++++++++++++
src/test/fuzzing/fuzz_conninfo.c         | 105 +++++++++++++++
src/test/fuzzing/fuzz_json.c             | 104 +++++++++++++++
src/test/fuzzing/fuzz_json_incremental.c | 127 ++++++++++++++++++
src/test/fuzzing/fuzz_parsepgarray.c     | 102 +++++++++++++++
src/test/fuzzing/fuzz_pgbench_expr.c     | 211 ++++++++++++++++++++++++++++++
src/test/fuzzing/fuzz_pglz.c             | 127 ++++++++++++++++++
src/test/fuzzing/fuzz_rawparser.c        | 162 +++++++++++++++++++++++
src/test/fuzzing/fuzz_regex.c            | 193 +++++++++++++++++++++++++++
src/test/fuzzing/fuzz_saslprep.c         | 104 +++++++++++++++
src/test/fuzzing/fuzz_typeinput.c        | 218 +++++++++++++++++++++++++++++++
src/test/fuzzing/fuzz_unescapebytea.c    | 103 +++++++++++++++
src/test/fuzzing/meson.build             | 203 ++++++++++++++++++++++++++++
src/test/meson.build                     |   2 +
15 files changed, 1862 insertions(+)


pgsql-committers by date:

Previous
From: Aleksander Alekseev
Date:
Subject: Re: pgsql: Allow autovacuum to use parallel vacuum workers.
Next
From: Andrew Dunstan
Date:
Subject: pgsql: Revert "Add built-in fuzzing harnesses for security testing."