Abbrevation
TAP
City
L'Aquila
Country
Italy
Deadline Paper
Start Date
End Date
Abstract

The TAP conference is devoted to the synergy of proofs and tests, to the application of techniques from both sides and their combination for the advancement of software quality&#046;<br>Testing and proving seem to be orthogonal techniques: Once a program has been proven to be correct then additional testing seems pointless; however, when such a proof in not feasible, then testing the program seems to be the only option&#046; This view has dominated the research community for a long time, and has resulted in distinct communities pursuing the different research areas&#046;<br>The development of both approaches has led to the discovery of common issues and to the realization of potential synergy&#046; Perhaps the use of model checking in testing was one of the first signs that a counterexample to a proof may be interpreted as a test case&#046; Recent breakthroughs in deductive techniques such as satisfiability modulo theories, abstract interpretation, and interactive theorem proving have paved the way for new and practically effective methods of powering testing techniques&#046; Moreover, since formal, proof&#8211;based verification is costly, testing invariants and background theories can be helpful to detect errors early and to improve cost effectiveness&#046; Summing up, 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&#046;<br>The TAP conference aims to bring together researchers and practitioners working in the converging fields of testing and proving by offering a generous forum for the presentation of ongoing research, for tutorials on established technologies and for informal discussions&#046;<br>Topics of Interest<br>Topics of interest cover theory definitions, tool constructions and experimentations, and include among others:<br>&#8211; Bridging the gap between concrete and symbolic techniques, e&#046;g&#046; using proof search in satisfiability modulo theories solvers to enhance various testing techniques<br>&#8211; Transfer of concepts from testing to proving (e&#046;g&#046;, coverage criteria) and from proving to testing<br>&#8211; Program proving with the aid of testing techniques<br>&#8211; Verification and testing techniques combining proofs and tests<br>&#8211; Generation of test data, oracles, or preambles by deductive techniques such as: theorem proving, model checking, symbolic execution, constraint logic programming<br>&#8211; Model&#8211;based testing and verification<br>&#8211; Generation of specifications by deduction<br>&#8211; Automatic bug finding<br>&#8211; Debugging of programs combining static and dynamic analysis<br>&#8211; Case studies combining tests and proofs<br>&#8211; Domain specific applications of testing and proving to new application domains such as validating security protocols, vulnerability detection of programs, security<br>&#8211; Testing of verification environments and reasoning engines like solvers and theorem provers<br>&#8211; New approaches such as crowd&#8211;sourcing and serious games to infer intended semantics and assess correctness<br>&#8211; Formal frameworks<br>&#8211; Tool descriptions and experience reports<br>