A revisit of three studies related to random testing

Tsong Yueh Chen, Fei Ching Kuo, Dave Towey, Zhi Quan Zhou

Research output: Journal PublicationArticlepeer-review

57 Citations (Scopus)
4 Downloads (Pure)

Abstract

Software testing is an approach that ensures the quality of software through execution, with a goal being to reveal failures and other problems as quickly as possible. Test case selection is a fundamental issue in software testing, and has generated a large body of research, especially with regards to the effectiveness of random testing (RT), where test cases are randomly selected from the software’s input domain. In this paper, we revisit three of our previous studies. The first study investigated a sufficient condition for partition testing (PT) to outperform RT, and was motivated by various controversial and conflicting results suggesting that sometimes PT performed better than RT, and sometimes the opposite. The second study aimed at enhancing RT itself, and was motivated by the fact that RT continues to be a fundamental and popular testing technique. This second study enhanced RT fault detection effectiveness by making use of the common observation that failure-causing inputs tend to cluster together, and resulted in a new family of RT techniques: adaptive random testing (ART), which is random testing with an even spread of test cases across the input domain. Following the successful use of failure-causing region contiguity insights to develop ART, we conducted a third study on how to make use of other characteristics of failure-causing inputs to develop more effective test case selection strategies. This third study revealed how best to approach testing strategies when certain characteristics of the failure-causing inputs are known, and produced some interesting and important results. In revisiting these three previous studies, we explore their unexpected commonalities, and identify diversity as a key concept underlying their effectiveness. This observation further prompted us to examine whether or not such a concept plays a role in other areas of software testing, and our conclusion is that, yes, diversity appears to be one of the most important concepts in the field of software testing.

Original languageEnglish
Pages (from-to)1-9
Number of pages9
JournalScience China Information Sciences
Volume58
Issue number5
DOIs
Publication statusPublished - 1 May 2015

Keywords

  • adaptive random testing
  • diversity
  • metamorphic testing
  • proportional sampling strategy
  • random testing
  • software testing

ASJC Scopus subject areas

  • Computer Science (all)

Fingerprint

Dive into the research topics of 'A revisit of three studies related to random testing'. Together they form a unique fingerprint.

Cite this