Mutants as Patches: Towards a formal approach to Mutation Testing

2Citations
Citations of this article
6Readers
Mendeley users who have this article in their library.

Abstract

Mutation testing is a widely explored technique used to evaluate the quality of software tests, but little attention has been given to its mathematical foundations. Aim: We provide a formal description of the core concepts in mutation testing, relations between them and conclusions that can be drawn from the presented model. Method: We introduce concepts of mutant space and patch space, and refer to patch merging procedure from the patch theory. We explicitly present constraints, such as location-dependence, that affect mutation operators. We also present a way to use introduced formalism with traditional operators proposed in other papers. Results: The proposed formalism allows to describe interactions between separate mutations using well-known abstract algebra notation. Conclusion: The presented formalism may substantially decrease the number of tested weak mutants and increase the number of valuable ones, while giving tools to partially address the problem of equivalent mutants, particularly for higher-order mutation testing. However, additional empirical evaluation is still needed.

Cite

CITATION STYLE

APA

Lewowski, T., & Madeyski, L. (2019). Mutants as Patches: Towards a formal approach to Mutation Testing. Foundations of Computing and Decision Sciences, 44(4), 379–405. https://doi.org/10.2478/fcds-2019-0019

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free