aboutsummaryrefslogtreecommitdiff
path: root/src/mint-lib/afl-generate.sh
diff options
context:
space:
mode:
authorChristian Grothoff <christian@grothoff.org>2015-09-21 15:52:07 +0200
committerChristian Grothoff <christian@grothoff.org>2015-09-21 15:52:07 +0200
commit74dfa2dfe0995ad9c01fbd499db7ff11dc2ede95 (patch)
tree279afda05958baf78175d241695fe29e789321ed /src/mint-lib/afl-generate.sh
parent8ae03a690b9695e6edf12e6be4895248408cfd7e (diff)
downloadexchange-74dfa2dfe0995ad9c01fbd499db7ff11dc2ede95.tar.xz
AFL test generation scripts
Diffstat (limited to 'src/mint-lib/afl-generate.sh')
-rw-r--r--src/mint-lib/afl-generate.sh34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/mint-lib/afl-generate.sh b/src/mint-lib/afl-generate.sh
new file mode 100644
index 000000000..4b5051869
--- /dev/null
+++ b/src/mint-lib/afl-generate.sh
@@ -0,0 +1,34 @@
+#!/bin/sh
+#
+# This file is part of TALER
+# Copyright (C) 2015 GNUnet e.V.
+#
+# TALER is free software; you can redistribute it and/or modify it under the
+# terms of the GNU Affero General Public License as published by the Free Software
+# Foundation; either version 3, or (at your option) any later version.
+#
+# TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License along with
+# TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/licenses/>
+#
+#
+# This will generate testcases in a directory 'afl-tests', which can then
+# be moved into src/mint/afl-tests/ to be run during mint-testing.
+#
+# This script uses American Fuzzy Loop (AFL) to fuzz the mint to
+# automatically create tests with good coverage. You must install
+# AFL and set AFL_HOME to the directory where AFL is installed
+# before running. Also, a directory "baseline/" should exist with
+# templates for inputs for AFL to fuzz. These can be generated
+# by running wireshark on loopback while running 'make check' in
+# this directory. Save each HTTP request to a new file.
+#
+# Note that you want to switch 'TESTRUN = NO' and pre-init the
+# database before running this, otherwise it will be awfully slow.
+#
+# Must be run from this directory.
+#
+$AFL_HOME/afl-fuzz -i baseline/ -m 250 -o afl-tests/ -f /tmp/afl-input taler-mint-httpd -f /tmp/afl-input -d test-mint-home/ -C