Semantic mutation testing

John Andrew Clark, Haitao Dan, Robert M. Hierons

Research output: Contribution to journalArticlepeer-review

Abstract

Mutation testing is a powerful and flexible test technique. Traditional mutation testing makes a small change to the syntax of a description (usually a program) in order to create a mutant. A test suite is considered to be good if it distinguishes between the original description and all of the (functionally non-equivalent) mutants. These mutants can be seen as representing potential small slips and thus mutation testing aims to produce a test suite that is good at finding such slips. It has also been argued that a test suite that finds such small changes is likely to find larger changes. This paper describes a new approach to mutation testing, called semantic mutation testing. Rather than mutate the description, semantic mutation testing mutates the semantics of the language in which the description is written. The mutations of the semantics of the language represent possible misunderstandings of the description language and thus capture a different class of faults. Since the likely misunderstandings are highly context dependent, this context should be used to determine which semantic mutants should be produced. The approach is illustrated through examples with statecharts and C code. The paper also describes a semantic mutation testing tool for C and the results of experiments that investigated the nature of some semantic mutation operators for C.
Original languageEnglish
Pages (from-to)345-363
Number of pages19
JournalScience of Computer Programming
Volume78
Issue number4
Early online date20 Apr 2011
DOIs
Publication statusPublished - 1 Apr 2013

Bibliographical note

Note that this has now appeared in full journal format April 2013 and so appears there. This one ought to be deleted.

Cite this