diff options
Diffstat (limited to 'src/tests/fuzzer')
| -rw-r--r-- | src/tests/fuzzer/CMakeLists.txt | 26 | ||||
| -rwxr-xr-x | src/tests/fuzzer/run_test.sh | 27 | ||||
| -rw-r--r-- | src/tests/fuzzer/testcase.cpp | 37 | ||||
| -rw-r--r-- | src/tests/fuzzer/testcase_dir/gooddata.txt | 45 |
4 files changed, 135 insertions, 0 deletions
diff --git a/src/tests/fuzzer/CMakeLists.txt b/src/tests/fuzzer/CMakeLists.txt new file mode 100644 index 0000000..b93a1d3 --- /dev/null +++ b/src/tests/fuzzer/CMakeLists.txt @@ -0,0 +1,26 @@ +cmake_minimum_required(VERSION 3.16) +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -fno-permissive -pedantic -Wall -Wextra") +set(CMAKE_AUTOMOC ON) + +find_package(Qt6Core REQUIRED) +find_package(Qt6Gui REQUIRED) +find_package(Qt6Svg REQUIRED) +find_package(Qt6Concurrent REQUIRED) + +set(CMAKE_INCLUDE_CURRENT_DIR ON) +set(CMAKE_AUTOMOC ON) + +#SET (CMAKE_EXE_LINKER_FLAGS "-static") + +add_definitions(-DPAINTER_OP) +set(MODE "cli") + + + +set(fdsource testcase.cpp) + +add_executable(fuzzTestCase ${fdsource} ) + + +target_link_libraries(fuzzTestCase libdiceparser.a Qt6::Core Qt6::Gui Qt6::Svg Qt6::Concurrent) +#target_link_libraries(fuzzTestCase ) diff --git a/src/tests/fuzzer/run_test.sh b/src/tests/fuzzer/run_test.sh new file mode 100755 index 0000000..9ecdeef --- /dev/null +++ b/src/tests/fuzzer/run_test.sh @@ -0,0 +1,27 @@ +#!/bin/sh + +rm -rf build +mkdir build +cd build +CC=afl-gcc CXX=afl-g++ cmake ../ -DSTATIC_BUILD=ON && make +#export LD_LIBRARY_PATH="/usr/local/lib:$LD_LIBRARY_PATH" + + +#./fuzzTestCase ../testcase_dir/gooddata.txt +# afl-fuzz -m 2G -i ../testcase_dir -o ../findings_dir ./fuzzTestCase @@ +afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -M fuzzer01 ./fuzzTestCase @@ & +screen -S fuzz1 -d -m touch afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -S fuzzer02 ./fuzzTestCase @@ & +screen -S fuzz2 -d -m touch afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -S fuzzer03 ./fuzzTestCase @@ & +screen -S fuzz3 -d -m touch afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -S fuzzer04 ./fuzzTestCase @@ & +screen -S fuzz4 -d -m touch afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -S fuzzer05 ./fuzzTestCase @@ & +screen -S fuzz5 -d -m touch afl-fuzz -m 2G -i ../testcase_dir -o ../sync_dir -S fuzzer06 ./fuzzTestCase @@ + + + +# as root + +# echo core >/proc/sys/kernel/core_pattern + +# echo performance | tee cpu*/cpufreq/scaling_governor + +# echo ondemand | tee cpu*/cpufreq/scaling_governor diff --git a/src/tests/fuzzer/testcase.cpp b/src/tests/fuzzer/testcase.cpp new file mode 100644 index 0000000..87d1867 --- /dev/null +++ b/src/tests/fuzzer/testcase.cpp @@ -0,0 +1,37 @@ +#include <QCoreApplication> +#include <QDebug> +#include <QFile> +#include <diceparser.h> + +static DiceParser* parser= new DiceParser(); + +void runCommand(const QString& cmd) +{ + qDebug() << "cmd" << cmd; + if(parser->parseLine(cmd)) + { + parser->start(); + } +} + +int main(int argc, char** argv) +{ + // qDebug() << "first"; + QCoreApplication app(argc, argv); + + // qDebug() << "start"; + QFile file(app.arguments().at(1)); + // qDebug() << "file" << app.arguments().at(1); + if(!file.open(QIODevice::ReadOnly)) + return 1; + + auto line= file.readLine(); + while(!line.isEmpty()) + { + // qDebug() << line; + runCommand(QString::fromUtf8(line)); + line= file.readLine(); + } + + return 0; +} diff --git a/src/tests/fuzzer/testcase_dir/gooddata.txt b/src/tests/fuzzer/testcase_dir/gooddata.txt new file mode 100644 index 0000000..d62c87e --- /dev/null +++ b/src/tests/fuzzer/testcase_dir/gooddata.txt @@ -0,0 +1,45 @@ +1L[cheminée,chocolat,épée,arc,chute de pierre[40]] +10d10c[>=6]-@c[=1] +1+1D10 +1+(4*3)D10s +2+4/4 +2D10*2D20*8 +1D100a[>=95]a[>=96]a[>=97]a[>=98]a[>=99]e[>=100] +15D10e10c[8-10] +(4+4)^4 +(1d20+20)*7/10 +20*7/10 +2d6c[%2=0] +D25;D10 +8+8+8 +1D20-88 +100*1D20*2D6 +2D6 # comment +100/28*3 +help +la +10D10c[<2|>7] +10D6c[=2|=4|=6] +10D10e[=1|=10]k4 +1L[t,b,s,r,j,v,i,p[8-10]] +1d6e6;1d4e4mk1 +400D20/400000 +1d100e[>=95]i[<5]{-1d100e95} +1d100i[<70]{1d10i[=10]{1d100i[<70]{1d10e10}}} +5-5*5+5 +((3+4)*2)d6 +4d6i[=6]{+1d6} +10d[-8--1] +4d6e6i[=4]{-4} +4d6e6f[!=4] +5d10g10 +4d6p[4:blue] +10d[0-9] +1d8e8;1d6e6mk1+2 +3d100g5 +2d10k1+2d10k1+2d10k1 +(1)-1d6e6 +8d10o +[100,200,300]k2 +100;200;300;[$1,$2,$3]k2 +0-2;$1+$1;$2i:[<1]{1}{0} |