The system for checking an effectiveness of the prioritized test suite versus random tests' ordering. The system consists of scripts with experiments and its results for the master thesis paper "Automated test prioritization". It checks the effectiveness of the GeTLO, Modificare, and Kanonizo tools.
For producing results of the prioritization based on the already built-in files with already prioritized tests, just launch following line from bash terminal from the root directory of this project:
. execution_scripts/estimate_results.sh
(Important! The scripts were tested on the Ubuntu 18.04. There is no guarantee of working on other OS).
After that you find files with APFD scores, VD-A effect size estimations, and also whisker plots of APFD variances for each project by the following directory structure:
└── D4J_projects
└── $project_name
└── results
├── prioritized_orderings
├── APFD_projects_tools_statistics.txt
├── APFDs.png
└── VD_A_projects_tools_statistics.txt
Prioritized test suite (i.e. files with names of the tests in the prioritized order) are available in the "prioritized_orderings" directory in subdirectory of each concrete tool for each tool's algorithm tested.
By default experiments are made for the Commons-Lang and JfreeChart projects. Additionally the system is tested with Closure-Compiler, Commons-Math, and Joda-Time projects. Their results are also presented by the aforementioned directory structure. You can add other projects by including its Defects4J lowercased identifier (e.g. chart, math, time...) to the corresponding array called "projects" at all the scripts in the execution_scripts folder.
Python 3 (tested on 3.7).
Also you need to install libs, mentioned in requirements.txt for example, via
pip install -r requirements.txt
- Set up Defects4J.
Make all the steps described in the installation guide.
Make sure that
defects4j
command has successfully integrated into your environment. - Install R language, and all its additional packages, which are required for launching the Modificare tool.
- Install Matlab environment in order to launch the
GeTLO tool.
Make sure that
matlab
command has successfully integrated into your environment. - Install Java (tested with Java 8) and all the dependencies of the Kanonizo tool for its launching.
- Run script run_all_stages.sh
. execution_scripts/run_all_stages.sh $1 $2 $3
with passing 3 args (directories actual for your machine):- As the first argument pass dir till Defects4J home.
- As second argument provide path till the environment, into which you have
integrated
defects4j
command and all aforementioned requirements. - As the third argument provide full path till the current project on your laptop.
These steps are described in more details in the script.