Skip to content

Latest commit

 

History

History
55 lines (44 loc) · 3.72 KB

README.md

File metadata and controls

55 lines (44 loc) · 3.72 KB

Test Case Prioritization (TCP) scripts

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.

Requirements

Python 3 (tested on 3.7).

Also you need to install libs, mentioned in requirements.txt for example, via

pip install -r requirements.txt

How to repeat all the experiments absolutely from scratch:

  1. Set up Defects4J. Make all the steps described in the installation guide. Make sure that defects4j command has successfully integrated into your environment.
  2. Install R language, and all its additional packages, which are required for launching the Modificare tool.
  3. Install Matlab environment in order to launch the GeTLO tool. Make sure that matlab command has successfully integrated into your environment.
  4. Install Java (tested with Java 8) and all the dependencies of the Kanonizo tool for its launching.
  5. Run script run_all_stages.sh . execution_scripts/run_all_stages.sh $1 $2 $3 with passing 3 args (directories actual for your machine):
    1. As the first argument pass dir till Defects4J home.
    2. As second argument provide path till the environment, into which you have integrated defects4j command and all aforementioned requirements.
    3. As the third argument provide full path till the current project on your laptop.

These steps are described in more details in the script.