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
科研通是完全免费的文献互助平台,具备全网最快的应助速度,最高的求助完成率。 对每一个文献求助,科研通都将尽心尽力,给求助人一个满意的交代。
实时播报
小鱼不干发布了新的文献求助30
刚刚
1秒前
务实善若完成签到,获得积分10
1秒前
吴祥坤发布了新的文献求助10
3秒前
晴天发布了新的文献求助10
3秒前
4秒前
mao发布了新的文献求助10
5秒前
脑洞疼应助hrpppp采纳,获得10
5秒前
senli2018发布了新的文献求助10
5秒前
6秒前
zhangxiaopan发布了新的文献求助30
7秒前
小鱼不干完成签到,获得积分20
7秒前
科研通AI6.3应助随便吧采纳,获得10
8秒前
空空完成签到,获得积分10
8秒前
9秒前
852发布了新的文献求助10
10秒前
朱方莉发布了新的文献求助10
10秒前
13秒前
小鱼完成签到,获得积分10
14秒前
852完成签到,获得积分20
15秒前
15秒前
蓬莱第几宫完成签到,获得积分10
15秒前
彩色的续完成签到,获得积分10
16秒前
16秒前
迅速丸子发布了新的文献求助10
16秒前
晴天完成签到,获得积分10
17秒前
西西0331完成签到,获得积分10
17秒前
古工楼发布了新的文献求助10
18秒前
坚强莺完成签到,获得积分10
18秒前
JamesPei应助DeepFancy采纳,获得10
19秒前
科目三应助ZOE采纳,获得10
19秒前
19秒前
nululala发布了新的文献求助10
19秒前
20秒前
搞怪的金鑫完成签到,获得积分10
21秒前
vishey完成签到,获得积分10
22秒前
22秒前
无情愫完成签到,获得积分20
23秒前
23秒前
dongrui发布了新的文献求助10
24秒前
高分求助中
(应助此贴封号)【重要!!请各用户(尤其是新用户)详细阅读】【科研通的精品贴汇总】 10000
The Organometallic Chemistry of the Transition Metals 800
Chemistry and Physics of Carbon Volume 18 800
The Organometallic Chemistry of the Transition Metals 800
The formation of Australian attitudes towards China, 1918-1941 640
Signals, Systems, and Signal Processing 610
全相对论原子结构与含时波包动力学的理论研究--清华大学 500
热门求助领域 (近24小时)
化学 材料科学 医学 生物 纳米技术 工程类 有机化学 化学工程 生物化学 计算机科学 物理 内科学 复合材料 催化作用 物理化学 光电子学 电极 细胞生物学 基因 无机化学
热门帖子
关注 科研通微信公众号,转发送积分 6439507
求助须知:如何正确求助?哪些是违规求助? 8253451
关于积分的说明 17566809
捐赠科研通 5497645
什么是DOI,文献DOI怎么找? 2899309
邀请新用户注册赠送积分活动 1876128
关于科研通互助平台的介绍 1716642