[发明专利]一种基于动态基本块的缺陷定位测试用例约简方法无效
申请号: | 201110413590.7 | 申请日: | 2011-12-13 |
公开(公告)号: | CN102521131A | 公开(公告)日: | 2012-06-27 |
发明(设计)人: | 陈林;马倩;卢红敏;徐宝文 | 申请(专利权)人: | 南京大学 |
主分类号: | G06F11/36 | 分类号: | G06F11/36 |
代理公司: | 南京天翼专利代理有限责任公司 32112 | 代理人: | 黄明哲 |
地址: | 210093 江*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 动态 基本 缺陷 定位 测试 用例约简 方法 | ||
1.一种基于动态基本块的缺陷定位测试用例约简方法,在基于测试执行的语句覆盖信息的缺陷定位技术中,缺陷定位算法可以识别的最小单元为动态基本块,其特征是根据测试用例的执行路径构建语句覆盖矩阵,由语句覆盖矩阵得到动态基本块集合,根据动态基本块集合将每条测试用例表示成以动态基本块为单位的向量,将语句覆盖矩阵转换为动态基本块覆盖矩阵,对其中需要人工检查结果的测试用例集进行约简:采用最大划分策略MDS或均匀划分策略EDS挑选测试用例,并判断所挑选的测试用例是否能继续对当前已划分出的动态基本块做划分,如果能,则保留已挑选的测试用例,继续挑选余下的测试用例,如果不能,则将已经挑选的所有测试用例构成约简后的测试用例集,约简后的测试用例集用于缺陷定位。
2.根据权利要求1所述的一种基于动态基本块的缺陷定位测试用例约简方法,其特征是包括以下步骤:
1)对待测试程序P执行测试用例集TS,TS为待约简的初始测试用例集,根据测试用例执行路径收集语句覆盖信息,构建语句覆盖矩阵;
2)由语句覆盖矩阵得到动态基本块集合B(TS),设动态基本块集合B(TS)包含n个元素B1,B2,...,Bn,则TS中每条测试用例ti都被表示成一个n维的向量:
ti=<b1,b2,...,bn>
将语句覆盖矩阵转化为动态基本块覆盖矩阵;
3)设约简后的测试用例集为TS’,初始时TS’为空集,从TS中选择任意一条出现错误的测试用例加入到测试用例集TS’中;
4)使用划分策略MDS或EDS挑选测试用例加入到TS’中,并判断所挑选的测试用例是否能继续对当前所挑选出的测试用例集所划分出的动态基本块做划分;
5)如果能,则转步骤4)继续挑选测试用例,不能则转步骤6);
6)将挑选的所有测试用例构成约简后的测试用例集TS’,用于缺陷定位。
3.根据权利要求2所述的一种基于动态基本块的缺陷定位测试用例约简方法,其特征是最大划分策略MDS首先将步骤3)任意选择的那条错误测试t1用例作为它选择的第一条用例,对于初始测试用例集TS,用N(B(TS))表示TS划分出的动态基本块的数量,N(Bt1(TS))表示TS对错误测试用例t1覆盖的部分能够划分出的动态基本块数量,设当前已经选择的测试用例的集合为T0,MDS在TS中选择使N(Bt1(T0∪{t}))达到最大值的测试用例t,将测试用例t加入T0,继续下一轮迭代选择,其中,当有不止一个t满足条件时,任意选择一个用例;直到对于所有未选择的测试用例t’,N(Bt1(T0∪{t’}))都与N(Bt1(T0))相同而不再增加,由所选择的测试用例得到最终的约简后的测试用例集为TS’。
4.根据权利要求2所述的一种基于动态基本块的缺陷定位测试用例约简方法,其特征是EDS采用迭代从TS中挑选测试用例,用Size(t,P)表示一条测试用例t划分一个临时块P产生的子块中较小的那一个包含的动态基本块的数量,假如t对P没有产生划分,Size(t,P)为0,设当前已经选择的测试用例的集合为T0,则T0=Tp∪Tf,其中Tp代表正确测试用例的集合,Tf代表错误测试用例的集合,EDS挑选测试用例后后立即检查其正确与否,用N(BTf(T0))表示T0对所有已选错误测试用例都覆盖的部分能够划分出的临时动态基本块数量,EDS挑选能够使最大的用例,当对所有未挑选的测试用例都为0时,说明所有需要被划分的动态基本块都被划分开来,不再产生新的划分,EDS收敛,完成挑选,由所选择的测试用例得到最终的约简后的测试用例集为TS’。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南京大学,未经南京大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201110413590.7/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种高效节能余热回收装置用波纹板
- 下一篇:一种治疗中风的药物及其制备方法