<P>The TAP conference is devoted to the convergence of proofs and tests. It combines ideas from both sides for the advancement of software quality. </P> <P>To prove the correctness of a program is to demonstrate, through impeccable mathematical techniques, that it has no bugs; to test a program is to run it with the expectation of discovering bugs. The two techniques seem contradictory: if you have proved your program, it′s fruitless to comb it for bugs; and if you are testing it, that is surely a sign that you have given up on any hope to prove its correctness. </P> <P>Accordingly, proofs and tests have, since the onset of software engineering research, been pursued by distinct communities using rather different techniques and tools. </P> <P>And yet the development of both approaches leads to the discovery of common issues and to the realization that each may need the other. The emergence of model checking has been one of the first signs that contradiction may yield to complementarity, but in the past few years an increasing number of research efforts have encountered the need for combining proofs and tests, dropping earlier dogmatic views of incompatibility and taking instead the best of what each of these software engineering domains has to offer.</P><B>Keywords:</B> <P> – Generation of test data, oracles, or preambles by deductive techniques<BR> such as theorem proving, model checking, symbolic execution,<BR> constraint logic programming, etc.<BR> – Generation of specifications by deduction<BR> – Verification techniques combining proofs and tests<BR> – Program proving with the aid of testing techniques<BR> – Transfer of concepts from testing to proving (e.g., coverage criteria)<BR> – Automatic bug finding<BR> – Formal frameworks<BR> – Tool descriptions and experience reports<BR> – Case studies<BR></P>
Abbrevation
TAP
City
Prato
Country
Italy
Deadline Paper
Start Date
End Date
Abstract