Shadow Symbolic Execution for Testing Software Patches

Tomasz Kuchta,Hristina Palikareva,Cristian Cadar
DOI: https://doi.org/10.1145/3208952
IF: 3.685
2018-07-31
ACM Transactions on Software Engineering and Methodology
Abstract:While developers are aware of the importance of comprehensively testing patches, the large effort involved in coming up with relevant test cases means that such testing rarely happens in practice. Furthermore, even when test cases are written to cover the patch, they often exercise the same behaviour in the old and the new version of the code. In this article, we present a symbolic execution-based technique that is designed to generate test inputs that cover the new program behaviours introduced by a patch. The technique works by executing both the old and the new version in the same symbolic execution instance, with the old version shadowing the new one. During this combined shadow execution, whenever a branch point is reached where the old and the new version diverge, we generate a test input exercising the divergence and comprehensively test the new behaviours of the new version. We evaluate our technique on the Coreutils patches from the CoREBench suite of regression bugs, and show that it is able to generate test inputs that exercise newly added behaviours and expose some of the regression bugs.
computer science, software engineering
What problem does this paper attempt to address?