- 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
-
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
-
Create and activate a Python virtual environment.
virtualenv -p python3.8 venv . venv/bin/activate
-
Install Docker SDK for Python
pip install docker==2.5.1
-
Run initialize script. This may take 40 mins or so depending on the network condition.
python init.py
-
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? -
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 ofdefects4j, 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.
-
Reproduce bug
Cli-1
indefects4j
benchmark:python scan4r.py -b defects4j -i Cli-1
-
Reproduce bugs in
bears
benchmark with bug ids inbears_sample.txt
:python scan4r.py -b bears -l bears_sample.txt
-
Reproduce all bugs in
growingbugs
benchmark:python scan4r.py -b growingbugs
-
Analyze reproduced log for one bug in
bugs.jar
benchmark:python scan4r.py -b bugs.jar -i bugs-dot-jar_WICKET-5565_204849bc -a
-
Analyze reproduced log for all bugs in
bugswarm
benchmark:python scan4r.py -b bugswarm -a