3.8 Proceedings Paper

Learning-to-Rank vs Ranking-to-Learn: Strategies for Regression Testing in Continuous Integration

Publisher

IEEE COMPUTER SOC
DOI: 10.1145/3377811.3380369

Keywords

regression testing; test selection; test prioritization; continuous integration; machine learning

Funding

  1. PRIN 2015 project GAUSS - MIUR
  2. INES 2.0
  3. FACEPE [PRONEX APQ 0388-1.03/14, APQ-0399-1.03/17]
  4. CAPES [88887.136410/2017-00]
  5. CNPq [465614/2014-0]

Ask authors/readers for more resources

In Continuous Integration (CI), regression testing is constrained by the time between commits. This demands for careful selection and/or prioritization of test cases within test suites too large to be run entirely. To this aim, some Machine Learning (ML) techniques have been proposed, as an alternative to deterministic approaches. Two broad strategies for ML-based prioritization are learning-to-rank and what we call ranking-to-learn (i.e., reinforcement learning). Various ML algorithms can be applied in each strategy. In this paper we introduce ten of such algorithms for adoption in CI practices, and perform a comprehensive study comparing them against each other using subjects from the Apache Commons project. We analyze the influence of several features of the code under test and of the test process. The results allow to draw criteria to support testers in selecting and tuning the technique that best fits their context.

Authors

I am an author on this paper
Click your name to claim this paper and add it to your profile.

Reviews

Primary Rating

3.8
Not enough ratings

Secondary Ratings

Novelty
-
Significance
-
Scientific rigor
-
Rate this paper

Recommended

No Data Available
No Data Available