SunDew: Systematic Automated Security Testing

被引:4
|
作者
Babic, Domagoj [1 ]
机构
[1] Google, Mountain View, CA 94043 USA
关键词
Software testing; vulnerabilities; symbolic execution;
D O I
10.1145/3092282.3092314
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
SunDew is a new automated test generation framework developed at Google, focused on finding security bugs in C/C++ code. It combines the strengths of multiple test generation techniques under a single cohesive platform. It leverages the vast amount of computational resources available at Google to massively parallelize the automated test generation and triage. By using a portfolio of test generation techniques, SunDew aims to overcome the coverage saturation (or plateau) that occurs with any individual technique. This saturation manifests as the inability of the technique to discover unexplored parts of a program after a certain number of generated tests. A portfolio of techniques, on the other hand, provides a diversity of test generation strategies that complement each other. SunDew embeds the most recent advances in automated test case generation, which provide precision and thoroughness. For example, symbolic execution uses powerful constraint solvers to generate tests that precisely follow desired program branches. This approach allows symbolic execution to reach code executed under very specific input preconditions that would be difficult to discover randomly. At the same time, recent improvements to coverage-guided automated fuzzing, such as AFL or LibFuzzer, generates tests faster than symbolic execution. Thus, SunDew alternates these approaches by using coverage-guided fuzzing to quickly bring the coverage to a first saturation level, then using symbolic execution to refine the search for harder-to-reach code. This, in turn, may provide additional inputs for coverage-guided fuzzers, etc. As part of SunDew, we also developed a number of format-aware fuzzers, that rely on, amongst other things, machine learning to generate language-aware fuzzers. The SunDew architecture follows a distributed continuous pipeline pattern. It allows a performance-based dynamic resource allocation for the various test generation techniques. This allows us to maximize the combined output of the test suite generation and avoid long plateaus in the coverage growth of the test suite. We discuss the application of SunDew on a variety of fuzzing targets of interest.
引用
收藏
页码:10 / 10
页数:1
相关论文
共 50 条
  • [1] SunDew: Systematic Automated Security Testing
    Ivancic, Franjo
    2020 IEEE 13TH INTERNATIONAL CONFERENCE ON SOFTWARE TESTING, VALIDATION AND VERIFICATION (ICST 2020), 2020, : 3 - 3
  • [2] Automated IoT security testing with SecLab
    Schwaiger, Patrick
    Simopoulos, Dimitrios
    Wolf, Andreas
    PROCEEDINGS OF THE IEEE/IFIP NETWORK OPERATIONS AND MANAGEMENT SYMPOSIUM 2022, 2022,
  • [3] Security Guarantees for Automated Software Testing
    Liyanage, Danushka
    PROCEEDINGS OF THE 29TH ACM JOINT MEETING ON EUROPEAN SOFTWARE ENGINEERING CONFERENCE AND SYMPOSIUM ON THE FOUNDATIONS OF SOFTWARE ENGINEERING (ESEC/FSE '21), 2021, : 1610 - 1614
  • [4] Automated Security Testing of Web Widget Interactions
    Bezemer, Cor-Paul
    Mesbah, Ali
    van Deursen, Arie
    7TH JOINT MEETING OF THE EUROPEAN SOFTWARE ENGINEERING CONFERENCE AND THE ACM SIGSOFT SYMPOSIUM ON THE FOUNDATIONS OF SOFTWARE ENGINEERING, 2009, : 81 - 90
  • [5] Plan It! Automated Security Testing Based on Planning
    Wotawa, Franz
    Bozic, Josip
    TESTING SOFTWARE AND SYSTEMS (ICTSS 2014), 2014, 8763 : 48 - 62
  • [6] Plan it! automated security testing based on planning
    Bozic, Josip (jbozic@ist.tugraz.at), 1600, Springer Verlag (8763):
  • [7] Automated systematic testing of open distributed programs
    Sen, K
    Agha, G
    FUNDAMENTAL APPROACHES TO SOFTWARE ENGINEERING, PROCEEDINGS, 2006, 3922 : 339 - 356
  • [8] A systematic classification of security regression testing approaches
    Felderer, Michael
    Fourneret, Elizabeta
    INTERNATIONAL JOURNAL ON SOFTWARE TOOLS FOR TECHNOLOGY TRANSFER, 2015, 17 (03) : 305 - 319
  • [9] A Framework for Systematic Classification of Assets for Security Testing
    Jan, Sadeeq
    Bin Tauqeer, Omer
    Khan, Fazal Qudus
    Tsaramirsis, George
    Ahmad, Awais
    Ahmad, Iftikhar
    Maqsood, Imran
    Ullah, Niamat
    CMC-COMPUTERS MATERIALS & CONTINUA, 2021, 66 (01): : 631 - 645
  • [10] A systematic classification of security regression testing approaches
    Michael Felderer
    Elizabeta Fourneret
    International Journal on Software Tools for Technology Transfer, 2015, 17 : 305 - 319