State merging for concolic testing of event-driven applications

被引:0
|
作者
Vandercammen, Maarten [1 ]
De Roover, Coen [1 ]
机构
[1] Vrije Univ Brussel, Pleinlaan 2, Brussels 1050, Belgium
关键词
Concolic testing; State merging; Event-driven applications; SYMBOLIC EXECUTION; EFFICIENT;
D O I
10.1016/j.scico.2025.103264
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Symbolic execution has proven itself a successful technique for automatically testing applications. However, it suffers from the state explosion problem, where execution of the program generates an exponential number of execution states that must be explored to fully cover the program. This problem can be mitigated by incorporating state merging into the testing procedure, where execution states that are sufficiently similar are merged together. Although state merging has been applied successfully to the testing of sequential applications, testing of event-driven applications brings with it unique challenges. In event-driven programs, the creation of new execution states is driven by both branch conditions encountered by the executor and the various permutations of the application's event sequence, as every event sequence potentially gives rise to a unique set of execution states that are created. This article presents the first description of how state merging can be applied in the context of symbolic execution of event- driven applications. Furthermore, although state merging has been described extensively for online symbolic execution, no mechanism has yet explicitly been described for incorporating state merging into offline symbolic execution, such as concolic testing. Online symbolic executors enable forking of the execution state upon reaching a branch condition that depends on symbolic input. Such testers can explore multiple program paths simultaneously. They can hence fork and merge states whenever the opportunity arises. Offline symbolic execution on the other hand, explores each program path separately. The reduced flexibility complicates the application of state merging. This article provides the first explicit overview of how state merging can be incorporated in concolic testing. We have implemented this approach to state merging in a concolic tester for event-driven JavaScript applications named STACKFUL. We evaluate this tester on a limited set of eight small, event-driven JavaScript web applications, and find that, within the scope of these eight applications, state merging successfully alleviates the state explosion problem, resulting in the concolic tester covering a larger part of the application in fewer test iterations.
引用
收藏
页数:31
相关论文
共 50 条
  • [41] Event-Driven Network Programming
    McClurg, Jedidiah
    Hojjat, Hossein
    Foster, Nate
    Cerny, Pavol
    ACM SIGPLAN NOTICES, 2016, 51 (06) : 369 - 385
  • [42] EVENT-DRIVEN MODULO SAMPLING
    Florescu, Dorian
    Krahmer, Felix
    Bhandari, Ayush
    2021 IEEE INTERNATIONAL CONFERENCE ON ACOUSTICS, SPEECH AND SIGNAL PROCESSING (ICASSP 2021), 2021, : 5435 - 5439
  • [43] Event-Driven Programming with EScala
    Satabin, Lucas
    Mezini, Mira
    AOSD 2011 PROCEEDINGS AND COMPANION MATERIAL, 2011, : 67 - 67
  • [44] Event-driven intermittent control
    Gawthrop, Peter J.
    Wang, Liuping
    INTERNATIONAL JOURNAL OF CONTROL, 2009, 82 (12) : 2235 - 2248
  • [45] EVENT-DRIVEN COMPILING TECHNIQUE
    BANATRE, JP
    ROUTEAU, JP
    TRILLING, L
    COMMUNICATIONS OF THE ACM, 1979, 22 (01) : 34 - 42
  • [46] On Event-Driven Business Integration
    Frank, Joachim H.
    Zeng, Liangzhao
    2013 IEEE 10TH INTERNATIONAL CONFERENCE ON E-BUSINESS ENGINEERING (ICEBE), 2013, : 82 - 89
  • [47] Event-driven stochastic approximation
    Vivek S. Borkar
    Neeraja Sahasrabudhe
    M. Ashok Vardhan
    Indian Journal of Pure and Applied Mathematics, 2016, 47 : 291 - 299
  • [48] Event-Driven Headline Generation
    Sun, Rui
    Zhang, Yue
    Zhang, Meishan
    Ji, Donghong
    PROCEEDINGS OF THE 53RD ANNUAL MEETING OF THE ASSOCIATION FOR COMPUTATIONAL LINGUISTICS AND THE 7TH INTERNATIONAL JOINT CONFERENCE ON NATURAL LANGUAGE PROCESSING, VOL 1, 2015, : 462 - 472
  • [49] EVENT-DRIVEN STOCHASTIC APPROXIMATION
    Borkar, Vivek S.
    Sahasrabudhe, Neeraja
    Vardhan, M. Ashok
    INDIAN JOURNAL OF PURE & APPLIED MATHEMATICS, 2016, 47 (02): : 291 - 299
  • [50] Event-driven competing risks
    Ewing, B
    Yandell, BS
    Barbieri, JF
    Luck, RF
    Forster, LD
    ECOLOGICAL MODELLING, 2002, 158 (1-2) : 35 - 50