Skip to content

Test Framework for Reproducibility of Software Defect Artifacts.

Notifications You must be signed in to change notification settings

ucd-plse/reproducibility-scanner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Reproducibility Scanner

Usage

Requirements

  • Ubuntu 18.04 or 20.04
  • JDK 8 and JDK 11
  • Maven 3.0.5 or later
  • Python 3.8
  • Python3-virtualenv
  • Git >= 1.9
  • SVN >= 1.8
  • Perl >= 5.0.12

Installation

  1. Clone the repository with submodules. This may take a while since there are large projects in benchmarks.

    git clone --recurse-submodules -j5 [email protected]:ucd-plse/Reproducibility-Scanner.git
    cd Reproducibility-Scanner
  2. Create and activate a Python virtual environment.

    virtualenv -p python3.8 venv
    . venv/bin/activate
  3. Install Docker SDK for Python

    pip install docker==2.5.1
  4. Run initialize script. This may take 40 mins or so depending on the network condition.

    python init.py
  5. Check default Java version. Defects4J requires Java 8 as the default.

    java -version

    The output should be version 1.8.0 for OpenJDK or Oracle JDK. If not, please refer to How to set default Java version?

  6. Run the Reproducibility Scanner

    python scan4r.py -b <benchmark> -i <bug_id> -l <file> -a

    -b | --benchmark: the name of the benchmark. Must be one of defects4j, bears, bugswarm, growingbugs, bugs.jar
    -i | --id: the id of bug to reproduce. When there is no id inputted, it will reproduce all bugs in the benchmark.
    -l | --list: the path to a text file containing a list of bug ids with one ID in one line.
    -a | --analyze-only: do not reproduce and run the test, just analyze the existing log.

Examples

  1. Reproduce bug Cli-1 in defects4j benchmark:

    python scan4r.py -b defects4j -i Cli-1
  2. Reproduce bugs in bears benchmark with bug ids in bears_sample.txt:

    python scan4r.py -b bears -l bears_sample.txt
  3. Reproduce all bugs in growingbugs benchmark:

    python scan4r.py -b growingbugs
  4. Analyze reproduced log for one bug in bugs.jar benchmark:

    python scan4r.py -b bugs.jar -i bugs-dot-jar_WICKET-5565_204849bc -a
  5. Analyze reproduced log for all bugs in bugswarm benchmark:

    python scan4r.py -b bugswarm -a

About

Test Framework for Reproducibility of Software Defect Artifacts.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages