李 娟,陈光武,范多旺
(兰州交通大学 光电技术与智能控制教育部重点实验室,兰州 730070)
计算机联锁系统是保证铁路行车安全和效率的实时控制和防护系统。联锁软件是联锁系统的安全性关键软件,通过自动测试可尽早发现并排除联锁软件潜在的缺陷,使联锁软件运行时发生故障的几率降到最低。联锁软件测试的实质是针对所设计的一组测试用例,执行联锁程序,以发现联锁程序的缺陷。测试用例的设计与生成是联锁软件测试中的难点和关键,它决定着软件测试的质量,影响软件测试的效率和速度。
测试用例的自动生成是在特定的数据空间中寻找符合测试标准的输入数据,执行将实际结果与预期结果比较的过程。本文研究的重点是测试用例质量的提高和优化。该问题具有非线性特点,而遗传算法的优化计算和全局寻优搜索策略适合于处理高度复杂的非线性问题。本文提出一种新的设计方案:应用基于成对组合的遗传算法进行联锁测试用例自动生成和优化,以提高联锁测试用例的质量。
成对组合覆盖是软件测试方法之一,同时也是衡量测试充分性的一种准则。它是一种面向应用的测试方案,按照两两覆盖的原则产生测试用例。成对组合的测试目标是所设计的测试用例集合对系统的所有对象可能取值的两两组合至少覆盖一次。满足成对组合的最小测试用例集实际上是经典的NP-Complete问题,目前主要采用启发式算法或人工智能方法产生测试用例的最优解。
测试用例最优解的生成模型分析如下。设DC为道岔测试用例集合,DZ为其一个子集,对应每个测试用例都有相应的测试代价,DR为测试需求。测试用例最优解问题等价于如何从测试用例空间DC中选取最小数量的用例子集DZ,使DZ能够以最小的测试代价覆盖测试需求集DR。
设道岔测试有3个输入参数A、B、C。A表示道岔,有2个值A1、A2,V(A)={1/3,5};B表示操纵,有4个值B1、B2、B3、B4,V(B)={定位单独操纵, 反位单独操纵,单独解锁,单独锁闭};C表示条件,有4个值C1、C2、C3、C4,V(C)={一般状态,进路锁闭,区段锁闭,引导总锁闭}。测试需求集DR可描述为DR={dr1,dr2,dr3,dr4,dr5},其中需求dr1为道岔定、反位单独操纵,dr2为道岔单独锁闭、操纵、解锁,dr3为进路锁闭后道岔单操测试,dr4为区段锁闭后道岔单操测试,dr5为引导总锁闭后道岔单操测试。按照全覆盖准则,共需2×4×4=32个测试用例。而应用成对组合覆盖可以只包含16个测试用例。
图1 道岔测试用例生成过程
测试用例生成过程如图1,采用的是AETG启发式算法。AETG(Automatic Efficient Test Genera-tor,自动高效测试生成器)开始于一个空的测试用例集,每次根据贪心算法产生一组候选用例,从中选取能够覆盖最多未被覆盖的成对组合的用例为新的测试用例。最初未被覆盖的成对组合集WZ={(A1,B1),(A1,B2),(A1,B3), (A1,B4),(A1,C1),(A1,C2),(A1,C3),(A1,C4),(A2,B1),(A2,B2),(A2,B3),(A2,B4),(A2,C1),(A2,C2),(A2,C3),(A2,C4),(B1,C1),(B1,C2),(B1,C3),(B1,C4),(B2,C1),(B2,C2),(B2,C3),(B2,C4), (B3,C1), (B3,C2),(B3,C3),(B3,C4),(B4,C1),(B4,C2),(B4,C3),(B4,C4)}。首先选择测试用例DC1=(A1,B1,C1),然后去掉WZ中的(A1,B1)、(A1,C1)和(B1,C1), 以剩下的组合中出现次数最多的A2为中心选择DC2=(A2,B2,C2)。按照同样的方法依次递归产生新的测试子集,直到集合WZ为空。测试用例集和测试需求间的覆盖关系如表1。
表1 测试用例与测试需求覆盖表
此例中利用16个交互测试用例组合覆盖测试需求,能有效地避免测试用例集之间产生的组合爆炸问题。采用传统的贪心搜索方法求得的测试用例集并非最小化的测试用例子集,其中包含大量的冗余测试用例,影响了测试效率。
本文在设计遗传算法时主要考虑3个因素:可靠性,收敛性,稳定性。
解决满足覆盖需求的软件测试用例集生成问题时,通常先以随机方法产生初始种群,然后将种群中的不可行个体通过选择、交叉、变异转化为可行个体,再根据种群中个体的适应度函数值选取最优的测试用例子集。基于上述思路,本文将GA嵌入到AETG中,并从贪心算法改进为遗传算法生成新的测试用例集。以道岔测试为例,所设计的算法框架如图2。
图2 算法的整体流程
其中遗传算法的代码结构如下所示:
Genetic Algorithm Program
Begin
t<-0;
initialize(); //随机产生N个个体进行种群初始化
execute solution();//运行N个初始个体
图3 道岔测试用例的编码表示
遗传算法处理过程中参数编码对算法的效率、性能有很大的影响。为了将问题的潜在解使用适合遗传算法的基因编码表示,本文将组合测试中的输入参数映射到位串空间Bl={0,1}l上,然后在其上进行遗传操作,得到的结果再通过解码过程还原成其表现型以进行适应度函数值的评估。根据各个参数的取值范围确定其编码长度。若一个参数的最大取值为Li,且2n-1
适应度函数是用以区分种群中个体好坏的演进过程。利用遗传算法生成的测试用例集,在满足成对组合覆盖的前提下,其例数尽可能的少。关于进化个体的适应度可按以下公式计算:
其中Cov(DCj)是用例集DCj的测试覆盖度,Cost(DCj) 是用例集DCj的测试运行代价。Cov(DCj)可按式(2)计算,Cost(DCj)可按式(3)计算。
测试用例中的覆盖信息由表1给出,在第j列中有多少个“X”,就代表测试用例DCj覆盖了哪些测试需求。设向量Xj=[xj1,xj2,…,xjk]表示表1中第j列的信息,向量W=[w1,w2,…,wk]表示每个测试需求的权重,用例子集DZ覆盖度可按下式计算:
从以上计算方法可以看出,F值越高表示单位测试代价下测试用例子集DZ的覆盖度越大。
遗传算法的基本操作包括3种:选择、杂交和变异操作。
不同的选择策略将导致不同的选择压力,从而影响算法的收敛速度。选用轮赌盘模型,选择算子从当前群体中按照某一概率选择一些个体作为新生种群的父辈,某个体Xi被选择的概率Pi与其适应度函数值成正比。设累计函数Lj=∑i=1~jPi,每个个体DCj处于选择区间[Lj,Lj+1),计算时每一轮产生一个[0,1]均匀分布的随机数,以该随机数为指针来确定对应选择区间的个体。个体的适应值越大,它被选择到的机会越多,其基因被遗传到下一代的可能性越大。
杂交运算是遗传算法区别于其他进化算法的重要特征。它的设计与所研究的问题密切相关,本文采用单点杂交操作,能较少的破坏优良个体的性状,同时有效地产生较好的新个体。单点杂交是指在个体编码串中只随机设计一个杂交点,然后在该点相互交换两个配对个体的部分染色体。两个长度为n的个体编码串进行单点杂交的过程如图4。
图4 单点杂交示意图
变异操作可改善遗传算法的局部搜索能力,维持群体的多样性,防止出现过早收敛。本文中二值基因链模型,采用基本位变异操作,即对指定的变异点进行取反运算。若测试用例子集A编码为:10111010,对选取的第5位基因值取反后产生新的A编码为:10110010。杂交算子和变异算子的相互配合,共同完成对搜索空间的全局搜索和局部搜索,实现测试用例最优解的寻优过程。
遗传算法因其自身强大的鲁棒性和全局寻优搜索能力,在解决非线性、大空间的测试数据自动生成中显示出独特的优势和高效性。将其嵌入到成对组合的启发式算法AETG中,可有效的减少冗余测试用例,更快的收敛到全局近似最优解,提高测试效率。本文以道岔测试为例,着重介绍了应用基于成对组合覆盖的遗传算法进行计算机联锁测试用例生成和优化的新想法,并对其应用过程进行了分析探讨,给出了具体的设计思路。