基于活动图的软件回归测试用例自动生成技术研究

来源 :南京大学 | 被引量 : 0次 | 上传用户:youguxinzhu2009
下载到本地 , 更方便阅读
声明 : 本文档内容版权归属内容提供方 , 如果您对本文有版权争议 , 可与客服联系进行内容授权或下架
论文部分内容阅读
软件系统规模和复杂性的不断增长,对软件质量保证技术提出了新的挑战。演化式软件开发过程被广泛用于控制软件系统的复杂性,它将复杂软件系统的开发过程分解成为一系列连续的迭代,在每次迭代中结合用户对已有软件系统的反馈和新的需求对软件系统的功能进行修正和增强。针对这类不断演化中的复杂软件系统,回归测试是保证其质量最重要的技术手段。与一般测试过程相比,回归测试过程即需要确认修改没有对软件功能和行为造成不利的影响,又需要确认新的功能已经被正确地实现,因而更加复杂,需要更多的测试资源。如何在不影响测试质量的基础上,提高回归测试的效率,降低测试开销,一直是回归测试技术研究的主要问题。针对这一问题,本文基于回归测试用例选取技术,研究了为回归测试自动生成测试用例的技术。引入活动图,对修改前后的软件进行建模,并通过对修改前后的模型进行自动比较,识别出软件修改的部分,从而选取出可重用用例并同时为修改部分生成新用例,最终生成有效的回归测试用例集合。进一步地,研究了基于修改后软件的动态运行轨迹,自动修订过时模型,生成修改后软件新模型的方法。以上两种方法结合在一起,就可以在很少人工干预的情况下,为回归测试自动地生成用例集合。具体来说,本文的主要工作如下:(1)提出了一种基于UML活动图比较的回归测试用例生成方法。该方法使用活动图作为描述程序内部动态行为的模型,通过比较程序在修改前后不同版本的活动图模型,来找出程序修改前后的行为变化,以及对应的受影响路径。利用程序插桩技术与活动图路径覆盖分析技术,实际测试用例到活动图中路径之间的追踪关系能够自动地建立起来。根据找出的受影响路径以及所建立的追踪关系,覆盖受影响路径的回归测试用例能够自动地被生成出来。(2)为了进一步减少对人工模型更新的依赖,本文在前一种方法的基础之上进一步提出了基于活动图自动修订的回归测试用例生成方法。在只提供原始版本的活动图模型的情况下,它能够依据程序当前的执行轨迹对模型进行自动修订,使得修订完成的活动图模型符合被测程序的当前行为。而回归测试用例生成工作也能在修订完成的活动图的基础上进行。通过实现活动图模型的自动更新,能够省去人工模型更新的工作开销,有效地提高回归测试的效率。(3)基于上述研究工作,开发出了原型工具并进行了实例研究。实验表明:本文所提出的基于UML活动图比较的回归测试用例生成方法能够有效地找出活动图发生变化时受影响的路径,并据此进行回归测试用例的生成,实现整个回归测试用例生成过程的自动化;而基于活动图修订的回归测试用例生成方法能够依照程序当前行为正确地对原始版本活动图进行自动修订,并将修订后的活动图模型用以指导接下来的回归测试工作、实例研究证明了本文方法的实用性和有效性。
其他文献
该文工作以国家"九五"重点科技攻关专题"基于构件/构架模式的应用软件集成环 境---青鸟Ⅲ型系统"为背景.结合Internet和Web技术,作者设计并实现了基于WWW的青鸟 构件库系统,
计算机持持的协同工作(Conputer Supported Cooperative Work)是指地域分散的一 个群体借助及其网络技术,共同协调与协作来完成一项任务.它包括群体工作方式研究和支持群体工
该文给出了可以在计算机上编程实现的信念修正的一种方法,称为信念归结;设计了基于这种方法的一个原型系统;最后讨论了如何将信念修正的成果应用到算法设计自动化中.
该文通过理论分析和实际系统析设计实现,分析了煤炭企业综合调度信息系统建设目标、内容和组织措施,以及在此基础上的综合调度数据仓库管理系统的设计方案和实现措施,讨论了
该论文中,作者使用模型检查(model checking)方法来形式化地分析安全协议中认证协议的性质,目的是帮助协议设计和分析人员发现认证协议中隐藏的漏洞.
该文是在研制开发武汉市排水泵站远程数据采集监测系统的过程中展开进行的.首先从理论上给出了大系统监控的几种方法,其后对分布式计算机系统的组成、结构和组态特点进行了深
该文是结合作者最近在美国参与"全球学习制作系统GLAS(Global Learning Authoring System)"的研究和开发工作所写.基于开发多语言远程教学系统的实践,作者在文中将重要研究它
学位
该文在信息可视化方面做了如下研究工作:1.对信息可视化当前国际研究状况进行了全面系统的分析阐述.2.提出并实现了一个通用的近邻算法可视化分析程序.3.提出了一种新颖的基
该文提出了"基于BP网络的彩色匹配"新方法.该方法首先利用迭代自组织数据分析算法,并根据色彩学中的色差理论和人的视觉特性,实现对大量测量样本的动态聚类.在此聚类的基础上