Regression test prioritization leveraging source code similarity with tree kernels

代码库 计算机科学 源代码 回归检验 测试套件 Java 杠杆(统计) 测试用例 抽象语法树 控制流程 数据挖掘 软件进化 程序设计语言 回归分析 软件 语法 机器学习 人工智能 软件开发 软件建设
作者
Francesco Altiero,Anna Corazza,Sergio Di Martino,Adriano Peron,Luigi Libero Lucio Starace
出处
期刊:Journal of software [Wiley]
卷期号:36 (8)
标识
DOI:10.1002/smr.2653
摘要

Abstract Regression test prioritization (RTP) is an active research field, aiming at re‐ordering the tests in a test suite to maximize the rate at which faults are detected. A number of RTP strategies have been proposed, leveraging different factors to reorder tests. Some techniques include an analysis of changed source code, to assign higher priority to tests stressing modified parts of the codebase. Still, most of these change‐based solutions focus on simple text‐level comparisons among versions. We believe that measuring source code changes in a more refined way, capable of discriminating between mere textual changes (e.g., renaming of a local variable) and more structural changes (e.g., changes in the control flow), could lead to significant benefits in RTP, under the assumption that major structural changes are also more likely to introduce faults. To this end, we propose two novel RTP techniques that leverage tree kernels (TK), a class of similarity functions largely used in Natural Language Processing on tree‐structured data. In particular, we apply TKs to abstract syntax trees of source code, to more precisely quantify the extent of structural changes in the source code, and prioritize tests accordingly. We assessed the effectiveness of the proposals by conducting an empirical study on five real‐world Java projects, also used in a number of RTP‐related papers. We automatically generated, for each considered pair of software versions (i.e., old version, new version) in the evolution of the involved projects, 100 variations with artificially injected faults, leading to over 5k different software evolution scenarios overall. We compared the proposed prioritization approaches against well‐known prioritization techniques, evaluating both their effectiveness and their execution times. Our findings show that leveraging more refined code change analysis techniques to quantify the extent of changes in source code can lead to relevant improvements in prioritization effectiveness, while typically introducing negligible overheads due to their execution.

科研通智能强力驱动
Strongly Powered by AbleSci AI
科研通是完全免费的文献互助平台,具备全网最快的应助速度,最高的求助完成率。 对每一个文献求助,科研通都将尽心尽力,给求助人一个满意的交代。
实时播报
兔斯基完成签到,获得积分10
刚刚
wanci应助Jolleyhaha采纳,获得10
1秒前
几分之几发布了新的文献求助10
1秒前
1秒前
1秒前
酷卡卡完成签到,获得积分10
2秒前
睡大觉完成签到,获得积分20
2秒前
橙汁完成签到,获得积分10
3秒前
3秒前
3秒前
3秒前
YAO完成签到 ,获得积分10
4秒前
星辰大海应助11122采纳,获得10
4秒前
刻苦亦丝发布了新的文献求助10
5秒前
迷路完成签到,获得积分10
5秒前
唐美鸭应助毛日骏采纳,获得10
6秒前
852应助科研通管家采纳,获得10
6秒前
bjbmtxy应助科研通管家采纳,获得10
6秒前
6秒前
天天快乐应助科研通管家采纳,获得10
6秒前
脑洞疼应助科研通管家采纳,获得10
6秒前
6秒前
6秒前
传奇3应助科研通管家采纳,获得10
6秒前
华仔应助科研通管家采纳,获得10
7秒前
爆米花应助科研通管家采纳,获得10
7秒前
深情安青应助科研通管家采纳,获得10
7秒前
Criminology34应助爱慕秋森万采纳,获得10
7秒前
田様应助科研通管家采纳,获得20
7秒前
7秒前
FashionBoy应助科研通管家采纳,获得10
7秒前
汉堡包应助科研通管家采纳,获得10
7秒前
7秒前
7秒前
7秒前
7秒前
爆米花应助科研通管家采纳,获得10
7秒前
7秒前
7秒前
7秒前
高分求助中
(应助此贴封号)【重要!!请各用户(尤其是新用户)详细阅读】【科研通的精品贴汇总】 10000
Polymorphism and polytypism in crystals 1000
Signals, Systems, and Signal Processing 610
Discrete-Time Signals and Systems 610
Russian Politics Today: Stability and Fragility (2nd Edition) 500
Death Without End: Korea and the Thanatographics of War 500
Der Gleislage auf der Spur 500
热门求助领域 (近24小时)
化学 材料科学 医学 生物 工程类 纳米技术 有机化学 物理 生物化学 化学工程 计算机科学 复合材料 内科学 催化作用 光电子学 物理化学 电极 冶金 遗传学 细胞生物学
热门帖子
关注 科研通微信公众号,转发送积分 6083050
求助须知:如何正确求助?哪些是违规求助? 7913389
关于积分的说明 16367596
捐赠科研通 5218275
什么是DOI,文献DOI怎么找? 2789846
邀请新用户注册赠送积分活动 1772906
关于科研通互助平台的介绍 1649256