Can This Fault Be Detected by Automated Test Generation: A Preliminary Study

Hangyuan Cheng, Ping Ma, Jingxuan Zhang, J. Xuan
{"title":"Can This Fault Be Detected by Automated Test Generation: A Preliminary Study","authors":"Hangyuan Cheng, Ping Ma, Jingxuan Zhang, J. Xuan","doi":"10.1109/IBF50092.2020.9034780","DOIUrl":null,"url":null,"abstract":"Automated test generation can reduce the manual effort to improve software quality. A test generation method employs code coverage, such as the widely-used branch coverage, to guide the inference of test cases. These test cases can be used to detect hidden faults. An automatic tool takes a specific type of code coverage as a configurable parameter. Given an automated tool of test generation, a fault may be detected by one type of code coverage, but omitted by another. In frequently released software projects, the time budget of testing is limited. Configuring code coverage for a testing tool can effectively improve the quality of projects. In this paper, we conduct a preliminary study on whether a fault can be detected by specific code coverage in automated test generation. We build predictive models with 60 metrics of faulty source code to identify detectable faults under eight types of code coverage, such as branch coverage. In the experiment, an off-the-shelf tool, EvoSuite is used to generate test data. Experimental results show that different types of code coverage result in the detection of different faults. The extracted metrics of faulty source code can be used to predict whether a fault can be detected with the given code coverage; all studied code coverage can increase the number of detected faults that are missed by the widely-used branch coverage. This study can be viewed as a preliminary result to support the configuration of code coverage in the application of automated test generation.","PeriodicalId":190321,"journal":{"name":"2020 IEEE 2nd International Workshop on Intelligent Bug Fixing (IBF)","volume":"1 1","pages":"0"},"PeriodicalIF":0.0000,"publicationDate":"2020-02-01","publicationTypes":"Journal Article","fieldsOfStudy":null,"isOpenAccess":false,"openAccessPdf":"","citationCount":"3","resultStr":null,"platform":"Semanticscholar","paperid":null,"PeriodicalName":"2020 IEEE 2nd International Workshop on Intelligent Bug Fixing (IBF)","FirstCategoryId":"1085","ListUrlMain":"https://doi.org/10.1109/IBF50092.2020.9034780","RegionNum":0,"RegionCategory":null,"ArticlePicture":[],"TitleCN":null,"AbstractTextCN":null,"PMCID":null,"EPubDate":"","PubModel":"","JCR":"","JCRName":"","Score":null,"Total":0}
引用次数: 3

Abstract

Automated test generation can reduce the manual effort to improve software quality. A test generation method employs code coverage, such as the widely-used branch coverage, to guide the inference of test cases. These test cases can be used to detect hidden faults. An automatic tool takes a specific type of code coverage as a configurable parameter. Given an automated tool of test generation, a fault may be detected by one type of code coverage, but omitted by another. In frequently released software projects, the time budget of testing is limited. Configuring code coverage for a testing tool can effectively improve the quality of projects. In this paper, we conduct a preliminary study on whether a fault can be detected by specific code coverage in automated test generation. We build predictive models with 60 metrics of faulty source code to identify detectable faults under eight types of code coverage, such as branch coverage. In the experiment, an off-the-shelf tool, EvoSuite is used to generate test data. Experimental results show that different types of code coverage result in the detection of different faults. The extracted metrics of faulty source code can be used to predict whether a fault can be detected with the given code coverage; all studied code coverage can increase the number of detected faults that are missed by the widely-used branch coverage. This study can be viewed as a preliminary result to support the configuration of code coverage in the application of automated test generation.
查看原文
分享 分享
微信好友 朋友圈 QQ好友 复制链接
本刊更多论文
自动测试生成是否可以检测到该故障:初步研究
自动化的测试生成可以减少提高软件质量的手工工作。测试生成方法使用代码覆盖,例如广泛使用的分支覆盖,来指导测试用例的推断。这些测试用例可用于检测隐藏的故障。自动工具将特定类型的代码覆盖率作为可配置参数。给定一个自动生成测试的工具,一个错误可能被一种类型的代码覆盖检测到,但被另一种类型的代码覆盖忽略。在频繁发布的软件项目中,测试的时间预算是有限的。为测试工具配置代码覆盖率可以有效地提高项目的质量。在本文中,我们对自动化测试生成中是否可以通过特定的代码覆盖来检测故障进行了初步的研究。我们用60个错误源代码的度量来建立预测模型,以在8种类型的代码覆盖下识别可检测的错误,例如分支覆盖。在实验中,使用了现成的工具EvoSuite来生成测试数据。实验结果表明,不同类型的代码覆盖率可以检测到不同的故障。提取的错误源代码度量可以用来预测在给定的代码覆盖率下是否可以检测到错误;所有研究过的代码覆盖都会增加被广泛使用的分支覆盖所遗漏的检测到的错误的数量。这项研究可以被看作是支持自动测试生成应用程序中代码覆盖配置的初步结果。
本文章由计算机程序翻译,如有差异,请以英文原文为准。
求助全文
约1分钟内获得全文 去求助
来源期刊
自引率
0.00%
发文量
0
期刊最新文献
Exploring the Differences between Plausible and Correct Patches at Fine-Grained Level An Empirical Study of High-Impact Factors for Machine Learning-Based Vulnerability Detection An Empirical Study of Bug Bounty Programs Utilizing Source Code Embeddings to Identify Correct Patches Intelligent Bug Fixing
×
引用
GB/T 7714-2015
复制
MLA
复制
APA
复制
导出至
BibTeX EndNote RefMan NoteFirst NoteExpress
×
×
提示
您的信息不完整,为了账户安全,请先补充。
现在去补充
×
提示
您因"违规操作"
具体请查看互助需知
我知道了
×
提示
现在去查看 取消
×
提示
确定
0
微信
客服QQ
Book学术公众号 扫码关注我们
反馈
×
意见反馈
请填写您的意见或建议
请填写您的手机或邮箱
已复制链接
已复制链接
快去分享给好友吧!
我知道了
×
扫码分享
扫码分享
Book学术官方微信
Book学术文献互助
Book学术文献互助群
群 号:481959085
Book学术
文献互助 智能选刊 最新文献 互助须知 联系我们:info@booksci.cn
Book学术提供免费学术资源搜索服务,方便国内外学者检索中英文文献。致力于提供最便捷和优质的服务体验。
Copyright © 2023 Book学术 All rights reserved.
ghs 京公网安备 11010802042870号 京ICP备2023020795号-1