/dharma

A generation-based, context-free grammar fuzzer.

Primary LanguageJavaScriptMozilla Public License 2.0MPL-2.0

Logo

Build Status

Requirements

None

Examples

Generate a single test-case.

% ./dharma.py -grammars grammars/webcrypto.dg

Generate a single test case with multiple grammars.

% ./dharma.py -grammars grammars/canvas2d.dg grammars/mediarecorder.dg

Generating test-cases as files.

% ./dharma.py -grammars grammars/webcrypto.dg -storage . -count 5

Generate test-cases, send each over WebSocket to Firefox, observe the process for crashes and bucket them.

% ./dharma.py -server -grammars grammars/canvas2d.dg -template grammars/var/templates/html5/default.html
% ./framboise.py -setup inbound64-release -debug -worker 4 -testcase ~/dev/projects/fuzzers/dharma/grammars/var/index.html

Benchmark the generator.

% time ./dharma.py -grammars grammars/webcrypto.dg -count 10000 > /dev/null

Screenshots

Dharma Demo Dharma Menu

Grammar Cheatsheet

comment

%%% comment

controls

%const% name := value

sections

%section% := value
%section% := variable
%section% := variance

extension methods

%range%(0-9)
%range%(0.0-9.0)
%range%(a-z)
%range%(!-~)
%range%(0x100-0x200)

%repeat%(+variable+)
%repeat%(+variable+, ", ")

%uri%(path)
%uri%(lookup_key)

%block%(path)

%choice%(foo, "bar", 1)

assigning values

digit :=
    %range%(0-9)

sign :=
    +
    -

value :=
    +sign+%repeat%(+digit+)

using values

+value+

assigning variables

variable :=
    @variable@ = new Foo();

using variables

value :=
    !variable!.bar();

referencing values from common.dg

value :=
    attribute=+common:number+

calling javascript library functions

foo :=
    Random.pick([0,1]);