The optimization of a symbolic execution engine for detecting runtime errors

In a software system, most of the runtime failures may come to light only during test execution, and this may have a very high cost. To help address this problem, a symbolic execution engine called RTEHunter, which has been developed at the Department of Software Engineering at the University of Sze...

Teljes leírás

Elmentve itt :
Bibliográfiai részletek
Szerző: Kádár István
Dokumentumtípus: Cikk
Megjelent: 2017
Sorozat:Acta cybernetica 23 No. 2
Kulcsszavak:Informatika, Számítástechnika, Kibernetika, Programozás, Algoritmus
Tárgyszavak:
doi:10.14232/actacyb.23.2.2017.9

Online Access:http://acta.bibl.u-szeged.hu/50089
LEADER 02704nab a2200241 i 4500
001 acta50089
005 20220620152335.0
008 180213s2017 hu o 0|| eng d
022 |a 0324-721X 
024 7 |a 10.14232/actacyb.23.2.2017.9  |2 doi 
040 |a SZTE Egyetemi Kiadványok Repozitórium  |b hun 
041 |a eng 
100 1 |a Kádár István 
245 1 4 |a The optimization of a symbolic execution engine for detecting runtime errors  |h [elektronikus dokumentum] /  |c  Kádár István 
260 |c 2017 
300 |a 573-597 
490 0 |a Acta cybernetica  |v 23 No. 2 
520 3 |a In a software system, most of the runtime failures may come to light only during test execution, and this may have a very high cost. To help address this problem, a symbolic execution engine called RTEHunter, which has been developed at the Department of Software Engineering at the University of Szeged, is able to detect runtime errors (such as null pointer dereference, bad array indexing, division by zero) in Java programs without actually running the program in a real-life environment. Applying the theory of symbolic execution, RTEHunter builds a tree, called a symbolic execution tree, composed of all the possible execution paths of the program. RTEHunter detects runtime issues by traversing the symbolic execution tree and if a certain condition is fulfilled the engine reports an issue. However, as the number of execution paths increases exponentially with the number of branching points, the exploration of the whole symbolic execution tree becomes impossible in practice. To overcome this problem, different kinds of constraints can be set up over the tree. E.g. the number of symbolic states, the depth of the execution tree, or the time consumption could be restricted. Our goal in this study is to find the optimal parametrization of RTEHunter in terms of the maximum number of states, maximum depth of the symbolic execution tree and search strategy in order to find more runtime issues in a shorter time. Results on three open-source Java systems demonstrate that more runtime issues can be detected in the 0 to 60 basic block-depth levels than in deeper ones within the same time frame. We also developed two novel search strategies for traversing the tree based on the number of null pointer references in the program and on linear regression that performs better than the default depth-first search strategy. 
650 4 |a Természettudományok 
650 4 |a Matematika 
650 4 |a Számítás- és információtudomány 
695 |a Informatika, Számítástechnika, Kibernetika, Programozás, Algoritmus 
856 4 0 |u http://acta.bibl.u-szeged.hu/50089/1/actacyb_23_2_2017_9.pdf  |z Dokumentum-elérés