The software industry favors dynamic testing over static analysis of software, because traditional static software analysis techniques do not adequately balance automation, precision and scalability. Recently several researchers have combined static and dynamic techniques to overcome these problems. Undergoing efforts include concolic execution, testing-based correctness prove, execution driven abstract interpretation and dynamic invariant generation. This paper summarizes the state of the art about combining dynamic testing and static analysis, and designs a roadmap towards a modern approach to software V&V that enhances dynamic testing with static analysis techniques. In particular, this paper surveys the most promising approaches to combine dynamic testing and static program analysis. It classifies the techniques against a framework of combination patterns, to facilitate the identification of commonalities and complementarities between the techniques. It quantifies analytically the gain that stems from the most important combination patterns. It provides a roadmap for future research

Braione, P., Denaro, G., Pezze', M. (2012). On the integration of software testing and formal analysis. In Meyer, B, M. Nordio (a cura di), Empirical Software Engineering and Verification (pp. 158-193). Springer [10.1007/978-3-642-25231-0_4].

On the integration of software testing and formal analysis

BRAIONE, PIETRO;DENARO, GIOVANNI;PEZZE', MAURO
2012

Abstract

The software industry favors dynamic testing over static analysis of software, because traditional static software analysis techniques do not adequately balance automation, precision and scalability. Recently several researchers have combined static and dynamic techniques to overcome these problems. Undergoing efforts include concolic execution, testing-based correctness prove, execution driven abstract interpretation and dynamic invariant generation. This paper summarizes the state of the art about combining dynamic testing and static analysis, and designs a roadmap towards a modern approach to software V&V that enhances dynamic testing with static analysis techniques. In particular, this paper surveys the most promising approaches to combine dynamic testing and static program analysis. It classifies the techniques against a framework of combination patterns, to facilitate the identification of commonalities and complementarities between the techniques. It quantifies analytically the gain that stems from the most important combination patterns. It provides a roadmap for future research
Capitolo o saggio
Abstract interpretations; Analysis techniques; Concolic execution; Dynamic invariants; Dynamic testing; Formal analysis; Roadmap; Software analysis; Software industry; State of the art; Static and dynamic; Static program analysis
English
Empirical Software Engineering and Verification
Meyer; B; Nordio, M
2012
978-3-642-25230-3
7007
Springer
158
193
Braione, P., Denaro, G., Pezze', M. (2012). On the integration of software testing and formal analysis. In Meyer, B, M. Nordio (a cura di), Empirical Software Engineering and Verification (pp. 158-193). Springer [10.1007/978-3-642-25231-0_4].
none
File in questo prodotto:
Non ci sono file associati a questo prodotto.

I documenti in IRIS sono protetti da copyright e tutti i diritti sono riservati, salvo diversa indicazione.

Utilizza questo identificativo per citare o creare un link a questo documento: https://hdl.handle.net/10281/43307
Citazioni
  • Scopus 2
  • ???jsp.display-item.citation.isi??? 2
Social impact