Skip to main navigation Skip to search Skip to main content

Ballerina: Automatic generation and clustering of efficient random unit tests for multithreaded code

  • Adrian Nistor
  • , Qingzhou Luo
  • , Michael Pradel
  • , Thomas R. Gross
  • , Darko Marinov

Research output: Chapter in Book/Report/Conference proceedingConference contribution

Abstract

Testing multithreaded code is hard and expensive. A multithreaded unit test creates two or more threads, each executing one or more methods on shared objects of the class under test. Such unit tests can be generated at random, but basic random generation produces tests that are either slow or do not trigger concurrency bugs. Worse, such tests have many false alarms, which require human effort to filter out. We present Ballerina, a novel technique for automated random generation of efficient multithreaded tests that effectively trigger concurrency bugs. Ballerina makes tests efficient by having only two threads, each executing a single, randomly selected method. Ballerina increases chances that such simple parallel code finds bugs by appending it to more complex, randomly generated sequential code. We also propose a clustering technique to reduce the manual effort in inspecting failures of automatically generated multithreaded tests. We evaluate Ballerina on 14 real-world bugs from six popular codebases: Groovy, JDK, JFreeChart, Apache Log4j, Apache Lucene, and Apache Pool. The experiments show that tests generated by Ballerina find bugs on average 2X-10X faster than basic random generation, and our clustering technique reduces the number of inspected failures on average 4X-8X. Using Ballerina, we found three previously unknown bugs, two of which were already confirmed and fixed.

Original languageEnglish (US)
Title of host publicationProceedings - 34th International Conference on Software Engineering, ICSE 2012
Pages727-737
Number of pages11
DOIs
StatePublished - 2012
Event34th International Conference on Software Engineering, ICSE 2012 - Zurich, Switzerland
Duration: Jun 2 2012Jun 9 2012

Publication series

NameProceedings - International Conference on Software Engineering
ISSN (Print)0270-5257

Other

Other34th International Conference on Software Engineering, ICSE 2012
Country/TerritorySwitzerland
CityZurich
Period6/2/126/9/12

ASJC Scopus subject areas

  • Software

Fingerprint

Dive into the research topics of 'Ballerina: Automatic generation and clustering of efficient random unit tests for multithreaded code'. Together they form a unique fingerprint.

Cite this