Skip to content

Performance fuzzer for ProB's constraint solving backends

Notifications You must be signed in to change notification settings

hhu-stups/probandit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

55 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ProBandit

An external banditfuzzer for ProB.

This is an extension of the original ProB banditfuzz extension which uses external fuzzing. External fuzzing hereby means that ProBandit is called in an external instance, independent from the ProB instance under test. This approach allows ProBandit to target different versions of ProB at the same time rather than being bound to one singular version.

Calling ProBandit

Dependencies:

  • Python 3.8+
  • SICStus Prolog 4.8+

Run with python3 -m probandit <config file path> [<target csv file>].

Installing Python Dependencies

python3 -m venv env
. env/bin/activate  # Might be different on Windows
pip install -r requirements.txt

Configuration Files

The configuration files are in YAML format and follow a simple pattern consisting of two sections: fuzzer and solvers:

fuzzer:
  path: <path string>
  targets:
    - <solver list>
  references:
    - <solver list>
  options:
    - <option list>
  csv: <path string>

solvers:
  <solver name>:
    <setting>: <value>

Fuzzer configuration

  • path: Directory path to the ProB version with the desired fuzzer implementation. This does not necessarily have to be a ProB version which is used as target or reference solver. Rather, this instance is queried for the BanditFuzz generator and mutator capabilities to create and manipulate inputs for the solvers under test. Especially, this path needs to point a distribution of the ProB source code as the fuzzing algorithm is executed via SICStus Prolog.

    Note: Available environment variables can be used and will be expanded, e.g. $PROBDIR (or any available variable).

  • targets: A list of target solvers to use in this ProBandit run. The solvers need to be defined under the solvers:-section (see below).

  • references: A list of reference solvers to use in this ProBandit run. The solvers need to be defined under the solvers:-section (see below).

  • options (Optional): A list of options that is forwarded to the BanditFuzz implementation linked under the path setting. See the respective readme for more information as of which options are available.

  • csv (Optional): Name of the target CSV file into which BanditFuzz writes the found benchmark results. The value defaults to results.csv.

    If the target csv file is given via command line option, the csv property will be ignored.

  • independent (Optional, default false): If set, solvers are restarted after each solving attempt to guarantee independence over different benchmarks.

Solver configuration

Under the solvers:-section, the user can define custom identifiers for each needed configuration of ProB that should be tested. For instance, defining two different versions of ProB as available solvers might look like this:

solvers:
  prob_1.13.0: /* Config for ProB 1.13.0 */
  prob_1.12.3: /* Config for ProB 1.12.3 */

The respective solver configuration options are as follows:

  • path: Path to the ProB distribution. If the path is a directory, ProBandit will attempt to access the probcli executable therein.

    Note: Available environment variables can be used and will be expanded, e.g. $PROBDIR (or any available variable).

  • cli_preferences (Optional): List of preferences with which the respective probcli will be called.

    For instance, the following will query the CLI with -p SMT TRUE

    prob_1.13.0:
      cli_preferences:
        - SMT TRUE
  • base_solver (Optional): Name of the base solver to use. Supported values are all valid solver names for the prob2_interface:cbc_timed_solve_with_opts/6 predicate. Examples include: PROB, KODKOD, Z3, Z3AXM, Z3CNS, and CDCLT.

  • prolog_call (Optional): The ProB2-Interface prolog call attempted by the solver to solve a given predicate in Prolog-AST representation. The call-string supports the use of the variables $pred and $base, which are substituted with the predicate to solve and with the base solver, respectively. Further, it supports an $options variable which is substituted with a list of call options defined under call_options (see below).

    This value defaults to cbc_timed_solve_with_opts($base,_,$pred,_,Res,Msec).

  • call_options (Optional): List of options forwarded to the Prolog call in the $options replacement.

    For instance, the following will substitute $options in the prolog call with [use_clpfd_solver/true, clean_up_pred].

    prob_1.13.0:
      call_options:
        - use_clpfd_solver/true
        - clean_up_pred
  • call_result_var (Optional): The variable used in the prolog_call which will bind to the solving result. Defaults to Res.

  • call_time_var (Optional): The variable used in the prolog_call which will bind to the solving time. Defaults to Msec.

References

The original ProB BanditFuzz article. This work is an extension in that it makes use of external fuzzing as described above.

@InProceedings(dunkelau2023banditfuzz,
  Author    = {Dunkelau, Jannik and Leuschel, Michael},
  Title     = {Performance Fuzzing with Reinforcement-Learning and Well-Defined Constraints for the {B} Method},
  Booktitle = {iFM 2023},
  Year      = 2023,
  Month     = nov,
  Series    = {LNCS},
  Volume    = 14300,
  Pages     = {237--256},
  Publisher = {Springer},
  doi       = {10.1007/978-3-031-47705-8_13}
)

About

Performance fuzzer for ProB's constraint solving backends

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages