南京大学学报(自然科学版) ›› 2018, Vol. 54 ›› Issue (4): 742.
张卫祥*,齐玉华
Zhang Weixiang*,Qi Yuhua
摘要: 如何实现软件输出域覆盖,是对安全攸关软件开展功能测试时面临的一个难题. 采用智能化软件测试思路,提出了基于人工免疫算法的软件测试数据自动生成方法. 首先分析了软件输出域覆盖问题的由来和面临的困难,说明了利用灰盒测试技术将输出域覆盖转化为软件伪路径覆盖的技术途径,并给出了软件测试数据质量评价的度量指标. 其次,给出了人工免疫算法应用于软件测试数据生成的基本思路,介绍了人工免疫算法的一般步骤及其与遗传算法的异同分析. 然后,分别设计了抗体亲和度评价算子、抗体浓度评价算子、免疫选择算子、克隆算子、变异算子、抑制算子、刷新算子等人工免疫算法的主要算子,实现了基于人工免疫算法的测试数据自动化生成方法. 最后,采用三种不同类型软件对方法有效性进行了验证,并对数据命中率、平均迭代轮次以及测试用例总个数等指标进行了分析. 结果表明,该方法满足软件输出域覆盖要求,总体效果优于遗传算法和随机测试.
[1] Alessandro O,Gregg R. Software testing:A research travelogue(2000-2014) ∥ Proceedings of the on Future of Software Engineering. Hyderabad,India:ACM,2014:117-132. [2] 黄席樾. 现代智能算法理论及应用. 北京:科学出版社,2005,134. [3] Endoh S,Toma N,Yamada K. Immune algorithm for n-TSP ∥ IEEE International Conference on Systems,Man,and Cybernetics. San Diego,CA,USA:IEEE,1998,3844-3849. [4] 蒋加伏,陈荣元,唐贤瑛等. 基于免疫——蚂蚁算法的多约束QoS路由选择. 通信学报,2004,25(8):89-95.(Jiang J F,Chen R Y,Tang X Y,et al. A multiple constrained QoS routing based on immune - ant algorithm. Journal of Communications,2004,25(8):89-95.) [5] 梁勤欧,祝国瑞. 基于克隆选择算法的布局分配问题研究. 测绘通报,2004(11):17-19.(Liang Q O,Zhu G R. Research on location-allocation problem based on clonal selection principle. Bulletin of Surveying and Mapping,2004(11):17-19.) [6] Li M J,Tang Z. An artificial immune algorithm based on bidding of power market ∥ Proceedings of International Conference on Power System Technology. Kunming,China:IEEE,2002,2405-2408. [7] 刘 英,戚玉涛,公茂果. 免疫克隆分类算法. 电子学报,2005,33(12A):2301-2307.(Liu Y,Qi Y T,Gong M G. Immune clonal algorithm for classification. Acta Electronica Sinica,2005,33(12A):2301-2307.) [8] 左万利,韩佳育,刘 露等. 基于人工免疫算法的增量式用户兴趣挖掘. 计算机科学,2015,42(5):34-41.(Zuo W L,Han J Y,Liu L,et al. Incremental user interest mining based on artificial immune algorithm. Computer Science,2015,42(5):34-41.) [9] 莫宏伟,左兴权. 人工免疫系统. 北京:科学出版社,2009,68-172.(Mo H W,Zuo X Q. Artificial immune system. Beijing:Science Press,2009,68-172.) [10] 张卫祥,魏 波,杜会森. 一种基于遗传算法的测试用例优先排序方法. 小型微型计算机系统,2015,36(9):1998-2002.(Zhang W X,Wei B,Du H S. Test case prioritization method based on genetic algorithm. Journal of Chinese Computer Systems,2015,36(9):1998-2002.) [11] Zhang W X,Wei B,Du H S. An output-oriented approach of test data generation based on genetic algorithm ∥ Wang G J,Zomaya A,Martinez,et al. Algorithms and Architectures for Parallel Processing. Zhangjiajie,China:Springer,2015:100-108. [12] 张卫祥,齐玉华,李德治. 基于离散粒子群算法的测试用例优先排序. 计算机应用,2017,37(1):108-113.(Zhang W X,Qi Y H,Li D Z. Test case prioritization based on discrete particle swarm optimization algorithm. Journal of Computer Applications,2017,37(1):108-113.) [13] 严 俊,张 健. 组合测试:原理与方法. 软件学报,2009,20(6):1393-1405.(Yan J,Zhang J. Combinatorial testing:Principles and methods. Journal of Software,2009,20(6):1393-1405.) [14] 段海滨,张祥银,徐春芳. 仿生智能计算. 北京:科学出版社,2011,175-179.(Duan H B,Zhang X Y,Xu C F. Bio-inspired computing. Beijing:Science Press,2011,175-179.) [15] 孙 宁. 人工免疫优化算法及其应用研究. 博士学位论文. 哈尔滨:哈尔滨工业大学,2006.(Sun N. Artificial immune optimization algorithm and applications. Ph. D. dissertation. Harbin:Harbin Institute of Technology,2006.) [16] 李茂军,舒 宜,童调生. 旅行商问题的人工免疫算法. 计算机科学,2003,30(3):80-82,89.(Li M J,Shu Y,Tong T S. An artificial immune algorithm for travelling salesman problem. Computer Science,2003,30(3):80-82,89.) [17] 焦李成,杜海峰. 人工免疫系统进展与展望. 电子学报,2003,91(10):1540-1548.(Jiao L C,Du H F. Development and prospect of the artificial immune system. Acta Electronica Sinica,2003,91(10):1540-1548.) |
No related articles found! |
|