Beyond Tests

Author:

Gao Xiang1,Wang Bo2,Duck Gregory J.1,Ji Ruyi2,Xiong Yingfei2,Roychoudhury Abhik1

Affiliation:

1. National University of Singapore, Singapore

2. Peking University, China

Abstract

Automated program repair is an emerging technology that seeks to automatically rectify program errors and vulnerabilities. Repair techniques are driven by a correctness criterion that is often in the form of a test suite. Such test-based repair may produce overfitting patches, where the patches produced fail on tests outside the test suite driving the repair. In this work, we present a repair method that fixes program vulnerabilities without the need for a voluminous test suite. Given a vulnerability as evidenced by an exploit, the technique extracts a constraint representing the vulnerability with the help of sanitizers. The extracted constraint serves as a proof obligation that our synthesized patch should satisfy. The proof obligation is met by propagating the extracted constraint to locations that are deemed to be “suitable” fix locations. An implementation of our approach (E xtract F ix ) on top of the KLEE symbolic execution engine shows its efficacy in fixing a wide range of vulnerabilities taken from the ManyBugs benchmark, real-world CVEs and Google’s OSS-Fuzz framework. We believe that our work presents a way forward for the overfitting problem in program repair by generalizing observable hazards/vulnerabilities (as constraint) from a single failing test or exploit.

Funder

National Research Foundation (NRF) Singapore

National Cybersecurity R8D (NCR) programme

National Satellite of Excellence in Trustworthy Software Systems

National Natural Science Foundation of China

Natural Science Foundation of Guangdong Province

Publisher

Association for Computing Machinery (ACM)

Subject

Software

Cited by 39 articles. 订阅此论文施引文献 订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献

1. On the acceptance by code reviewers of candidate security patches suggested by Automated Program Repair tools;Empirical Software Engineering;2024-08-03

2. Detecting, Creating, Repairing, and Understanding Indivisible Multi-Hunk Bugs;Proceedings of the ACM on Software Engineering;2024-07-12

3. A Case Study of LLM for Automated Vulnerability Repair: Assessing Impact of Reasoning and Patch Validation Feedback;Proceedings of the 1st ACM International Conference on AI-Powered Software;2024-07-10

4. Does Going Beyond Branch Coverage Make Program Repair Tools More Reliable?;2024 IEEE Conference on Software Testing, Verification and Validation (ICST);2024-05-27

5. Multi-mechanism neural machine translation framework for automatic program repair;Journal of Intelligent & Fuzzy Systems;2024-04-18

同舟云学术

1.学者识别学者识别

2.学术分析学术分析

3.人才评估人才评估

"同舟云学术"是以全球学者为主线,采集、加工和组织学术论文而形成的新型学术文献查询和分析系统,可以对全球学者进行文献检索和人才价值评估。用户可以通过关注某些学科领域的顶尖人物而持续追踪该领域的学科进展和研究前沿。经过近期的数据扩容,当前同舟云学术共收录了国内外主流学术期刊6万余种,收集的期刊论文及会议论文总量共计约1.5亿篇,并以每天添加12000余篇中外论文的速度递增。我们也可以为用户提供个性化、定制化的学者数据。欢迎来电咨询!咨询电话:010-8811{复制后删除}0370

www.globalauthorid.com

TOP

Copyright © 2019-2024 北京同舟云网络信息技术有限公司
京公网安备11010802033243号  京ICP备18003416号-3