@article{8872, author = {Gordon Fraser and Andrea Arcuri}, title = {1600 Faults in 100 Projects: Automatically Finding Faults While Achieving High Coverage With EvoSuite.}, abstract = {Automated unit test generation techniques traditionally follow one of two goals: Either they try to find violations of automated oracles (e.g., assertions, contracts, undeclared exceptions), or they aim to produce representative test suites (e.g., satisfying branch coverage) such that a developer can manually add test oracles. Search-based testing (SBST) has delivered promising results when it comes to achieving coverage, yet the use in conjunction with automated oracles has hardly been explored, and is generally hampered by the reliance of SBST techniques on (small) sets of explicit testing targets. In this paper we present a search-based approach to handle both objectives at the same time, implemented in the EVOSUITE tool. An empirical study applying EVOSUITE on 100 randomly selected open source software projects (the SF100 corpus) reveals that SBST has the unique advantage of being well suited to perform both traditional goals at the same time - efficiently triggering faults, while producing representative test sets for any chosen coverage criterion. In our study, EVOSUITE detected twice as many failures in terms of undeclared exceptions as a traditional random testing approach, witnessing thousands of real faults in the 100 open source projects. Two out of every five classes with undeclared exceptions have actual faults, but these are buried within many failures that are caused by implicit preconditions. This {\textquotedblleft}noise{\textquotedblright} can be interpreted as either a call for further research in improving automated oracles - or to make tools like EVOSUITE an integral part of software development to enforce clean program interfaces.}, year = {2013}, journal = {Empirical Software Engineering}, number = {online}, publisher = {Springer US}, }