Bita: Coverage-Guided, Automatic Testing of Actor Programs

被引:0
|
作者
Tasharofi, Samira [1 ]
Pradel, Michael [2 ]
Lin, Yu [1 ]
Johnson, Ralph [1 ]
机构
[1] Univ Illinois, Dept Comp Sci, 1304 W Springfield Ave, Urbana, IL 61801 USA
[2] ETH, Dept Comp Sci, Zurich, Switzerland
基金
瑞士国家科学基金会;
关键词
CONCURRENCY BUGS; FRAMEWORK; TOOL;
D O I
暂无
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Actor programs are concurrent programs where concurrent entities communicate asynchronously by exchanging messages. Testing actor programs is challenging because the order of message receives depends on the non-deterministic scheduler and because exploring all schedules does not scale to large programs. This paper presents Bita, a scalable, automatic approach for testing non-deterministic behavior of actor programs. The key idea is to generate and explore schedules that are likely to reveal concurrency bugs because these schedules increase the schedule coverage. We present three schedule coverage criteria for actor programs, an algorithm to generate feasible schedules that increase coverage, and a technique to force a program to comply with a schedule. Applying Bita to real-world actor programs implemented in Scala reveals eight previously unknown concurrency bugs, of which six have already been fixed by the developers. Furthermore, we show our approach to find bugs 122x faster than random scheduling, on average.
引用
收藏
页码:114 / 124
页数:11
相关论文
共 50 条
  • [1] Quito: a Coverage-Guided Test Generator for Quantum Programs
    Wang, Xinyi
    Arcaini, Paolo
    Yue, Tao
    Ali, Shaukat
    [J]. 2021 36TH IEEE/ACM INTERNATIONAL CONFERENCE ON AUTOMATED SOFTWARE ENGINEERING ASE 2021, 2021, : 1237 - 1241
  • [2] Coverage-Guided Testing for Recurrent Neural Networks
    Huang, Wei
    Sun, Youcheng
    Zhao, Xingyu
    Sharp, James
    Ruan, Wenjie
    Meng, Jie
    Huang, Xiaowei
    [J]. IEEE TRANSACTIONS ON RELIABILITY, 2022, 71 (03) : 1191 - 1206
  • [3] DeepRanger: Coverage-guided Deep Forest Testing Approach
    Cui Z.-Q.
    Xie R.-L.
    Chen X.
    Liu X.-L.
    Zheng L.-W.
    [J]. Ruan Jian Xue Bao/Journal of Software, 2023, 34 (05): : 2251 - 2267
  • [4] CoCoFuzzing: Testing Neural Code Models With Coverage-Guided Fuzzing
    Wei, Moshi
    Huang, Yuchao
    Yang, Jinqiu
    Wang, Junjie
    Wang, Song
    [J]. IEEE TRANSACTIONS ON RELIABILITY, 2023, 72 (03) : 1276 - 1289
  • [5] Coverage-Guided Fuzz Testing for Cyber-Physical Systems
    Sheikhi, Sanaz
    Kim, Edward
    Duggirala, Parasara Sridhar
    Bak, Stanley
    [J]. 2022 13TH ACM/IEEE INTERNATIONAL CONFERENCE ON CYBER-PHYSICAL SYSTEMS (ICCPS 2022), 2022, : 24 - 33
  • [6] COMET: Coverage-guided Model Generation For Deep Learning Library Testing
    Li, Meiziniu
    Cao, Jialun
    Tian, Yongqiang
    Li, Tsz On
    Wen, Ming
    Cheung, Shing-Chi
    [J]. ACM TRANSACTIONS ON SOFTWARE ENGINEERING AND METHODOLOGY, 2023, 32 (05)
  • [7] INSTRCR: Lightweight instrumentation optimization based on coverage-guided fuzz testing
    Zhang, Cao
    Dong, Wei Yu
    Ren, Yu Zhu
    [J]. 2019 IEEE 2ND INTERNATIONAL CONFERENCE ON COMPUTER AND COMMUNICATION ENGINEERING TECHNOLOGY (CCET), 2019, : 74 - 78
  • [8] DeepHunter: A Coverage-Guided Fuzz Testing Framework for Deep Neural Networks
    Xie, Xiaofei
    Ma, Lei
    Juefei-Xu, Felix
    Xue, Minhui
    Chen, Hongxu
    Liu, Yang
    Zhao, Jianjun
    Li, Bo
    Yin, Jianxiong
    See, Simon
    [J]. PROCEEDINGS OF THE 28TH ACM SIGSOFT INTERNATIONAL SYMPOSIUM ON SOFTWARE TESTING AND ANALYSIS (ISSTA '19), 2019, : 146 - 157
  • [9] Coverage-guided differential testing of TLS implementations based on syntax mutation
    Pan, Yan
    Lin, Wei
    He, Yubo
    Zhu, Yuefei
    [J]. PLOS ONE, 2022, 17 (01):
  • [10] JQF: Coverage-Guided Property-Based Testing in Java']Java
    Padhye, Rohan
    Lemieux, Caroline
    Sen, Koushik
    [J]. PROCEEDINGS OF THE 28TH ACM SIGSOFT INTERNATIONAL SYMPOSIUM ON SOFTWARE TESTING AND ANALYSIS (ISSTA '19), 2019, : 398 - 401