Fitness-guided path exploration in dynamic symbolic execution

T Xie, N Tillmann, J De Halleux… - 2009 IEEE/IFIP …, 2009 - ieeexplore.ieee.org
T Xie, N Tillmann, J De Halleux, W Schulte
2009 IEEE/IFIP International Conference on Dependable Systems …, 2009ieeexplore.ieee.org
Dynamic symbolic execution is a structural testing technique that systematically explores
feasible paths of the program under test by running the program with different test inputs to
improve code coverage. To address the space-explosion issue in path exploration, we
propose a novel approach called Fitnex, a search strategy that uses state-dependent fitness
values (computed through a fitness function) to guide path exploration. The fitness function
measures how close an already discovered feasible path is to a particular test target (eg …
Dynamic symbolic execution is a structural testing technique that systematically explores feasible paths of the program under test by running the program with different test inputs to improve code coverage. To address the space-explosion issue in path exploration, we propose a novel approach called Fitnex, a search strategy that uses state-dependent fitness values (computed through a fitness function) to guide path exploration. The fitness function measures how close an already discovered feasible path is to a particular test target (e.g., covering a not-yet-covered branch). Our new fitness-guided search strategy is integrated with other strategies that are effective for exploration problems where the fitness heuristic fails. We implemented the new approach in Pex, an automated structural testing tool developed at Microsoft Research. We evaluated our new approach by comparing it with existing search strategies. The empirical results show that our approach is effective since it consistently achieves high code coverage faster than existing search strategies.
ieeexplore.ieee.org