UI自动化测试驱动的软件开发方法研究(推荐3篇)

UI自动化测试驱动的软件开发方法研究 篇一

在软件开发过程中,UI自动化测试是一个重要的环节,它可以有效地提高软件开发的效率和质量。本文将探讨UI自动化测试驱动的软件开发方法,并分析其优势和挑战。

UI自动化测试是一种通过模拟用户操作来对软件界面进行测试的方法。通过自动化测试脚本,可以模拟用户在软件界面上的各种操作,如点击、输入等。通过自动化测试工具,可以快速地执行大量的测试用例,并生成详细的测试报告。这种方法可以有效地减少人工测试的工作量,提高测试的效率和准确性。

UI自动化测试驱动的软件开发方法是一种以测试为驱动的开发方式。在传统的软件开发流程中,测试往往是在开发完成后的一个环节,而且测试工作主要是由测试人员完成。但是,在UI自动化测试驱动的软件开发方法中,测试被提前到了开发的早期阶段,并且测试工作是由开发人员来完成的。开发人员通过编写自动化测试脚本来测试软件的各个功能模块,并通过持续集成工具来自动运行这些测试脚本。这种方式可以及早地发现和修复软件的缺陷,提高软件的质量和稳定性。

UI自动化测试驱动的软件开发方法有以下几个优势。首先,它可以提高软件开发的效率。通过自动化测试,可以快速地执行大量的测试用例,并及早地发现和修复软件的缺陷。这样可以减少软件开发过程中的反复修改和调试,提高开发效率。其次,它可以提高软件的质量。通过自动化测试,可以对软件的各个功能模块进行全面和深入的测试,从而发现和修复软件的潜在问题。这样可以提高软件的质量和稳定性。最后,它可以降低软件开发的成本。通过自动化测试,可以减少人工测试的工作量,降低测试的成本。

然而,UI自动化测试驱动的软件开发方法也面临一些挑战。首先,自动化测试脚本的编写和维护需要一定的技术和经验。开发人员需要熟悉自动化测试工具的使用和编程语言的知识,才能编写出高质量的测试脚本。其次,自动化测试的覆盖范围有限。由于UI自动化测试主要是针对软件的界面进行测试,对于一些非界面的功能,如数据库操作和接口调用等,无法进行有效的测试。最后,自动化测试需要不断地更新和维护。随着软件的不断迭代和升级,测试脚本也需要不断地进行更新和维护,以适应新的需求和变化。

综上所述,UI自动化测试驱动的软件开发方法是一种提高软件开发效率和质量的有效方式。它可以通过自动化测试脚本来及早地发现和修复软件的缺陷,提高软件的质量和稳定性。然而,它也面临一些挑战,如测试脚本的编写和维护等。因此,在实际应用中,需要根据具体的项目情况来选择和使用UI自动化测试驱动的软件开发方法。

UI自动化测试驱动的软件开发方法研究 篇三

UI自动化测试驱动的软件开发方法研究

  软件在开发的过程中有很多方式,不同的软件开发也需要不同的技术。下面是小编搜集整理的测试驱动开发研究的论文范文,供大家阅读借鉴。

  【摘 要】在软件测试中,UI测试是保证软件质量、提高软件可靠性不可或缺的一部分,而基于单元的测试驱动开发对UI的关注度不够,本文探讨了适用于测试驱动开发的UI自动化测试框架需要的性质以及框架结构,并用开源框架KIF展示了UI自动化测试在测试驱动开发中的应用。

  【关键词】软件测试,UI测试,测试驱动,极限编程

  引言

  测试驱动开发是一种新的软件开发方式,它遵守测试先行的原则,既简化了代码,又提高了软件的质量,已经成功的运用到各种项目的开发。现今的软件由于越来越注重软件的用户体验,对UI的测试越来越重要,而现在的测试驱动开发以测试代码单元设计正确性为主的单元测试为主要驱动,极少考虑用户与UI的操作对程序的影响,所以,研究UI测试在测试驱动开发中的应用有重要意义。

  1、测试驱动开发

  测试驱动开发(Test- Driven Development), 简称TDD, 由 Kent Beck提出的一种软件开发方式。测试驱动开发以测试作为开发过程的中心, 它要求在编写任何产品代码之前, 首先编写用于定义产品代码行为的测试, 而编写的产品代码又要以使测试通过为目标。测试驱动开发要求测试可以完全自动化的运行, 在对代码进行重构前后必须运行测试。

  1.1 传统测试方法存在的问题

  1)传统的功能性测试存在着漏洞和冗余, 而且同时不能被发现。功能性测试使测试人员离代码过远;

  2)传统的结构性测试将代码采用有向图表示和程序路径公式化, 掩盖了代码中的重要信息, 这就在路径分析的方向上走得太远;

  3)如果测试编写人员编写测试时所依赖的是文档而不是代码时, 当文档和代码存在任何不一致的地方就会造成问题;

  4)测试不是自动运行的, 它们极有可能不会被频繁、经常性地运行, 或每次都以相同的方式来运行。

  1.2 测试驱动开发的优点

  1)从软件开发的初始阶段, TDD 就强迫开发人员以测试的角度与用户的观点对软件进行审视,因而更能够对软件有全面的认识和把握。

  2)由于可以保证编写测试和编写代码的是相同的程序员, 降低了理解代码所花费的成本。

  3)减轻了测试的工作量。无论是否进行设计工作, 测试工作都是不可避免的, 先进行单元测试, 可以减少后续的测试工作量。

  4)让程序员能够更大程度地控制代码的正确度, 相当于提供了两道的`代码审核手段, 在软件成品的质量上提供了一定的保障。

  1.3 测试驱动开发步骤

  1)根据软件设计需求快速增加一个测试用例;

  2)运行所有测试,新增加的测试无法通过;

  3)重构代码,做尽量少的改动让测试通过;

  4)运行所有测试,保证所有测试都能通过;

  5)重构代码,消除重复设计;

  6)回到1)直到写完系统所有的功能测试。

  2、UI测试

  在移动互联网时代 ,用户体验是软件的重中之重,为了保证用户体验的完美必须对软件UI进行严格测试,ui 测试主要分为可用性测试和功能性测试两方面。对于可用性测试,是用来测试软件的用户界面是否符合用户的使用习惯和使用心理,是对用户体验的归纳和总结。用户体验的好坏取决于用户界面是否简单、直观和实用,良好的用户界面可以大大减少可用性测试的成本。对于功能性测试,通过外部UI的内容和展示用来测试软件的内部逻辑正确性。

  2.1 自动化测试

  根据测试是否需要引入人工干预,软件测试可以分为手工测试和自动化测试两大类。手工测试是指采用手动的方式输入软件测试的数据,然后观察测试的结果,并对测试结果进行分析。相对于自动化测试,手工测试是一种原始的测试方法。自动化测试是指通过编写测试脚本,对软件进行测试,整个过程不需要人工进行干预。手工测试能够根据软件测试的进度,及时的调整测试的策略,改变软件测试的方法。手工测试能够细致的观察到软件运行和输出的结果,当需要对测试结果进行主观判断时,手工测试具有明显的优点。但是,手工测试也存在着自身的不足。相对于自动化测试,手工测试的效率较低,不确定的因素较多。当软件测试需要测试大量的数据时,手工测试的局限性较为明显。完成采用手工测试对软件进行测试,无法满足现代化的软件测试需求。因此,采用手动测试加自动化测试相结合的方式对软件进行测试,可以有效的提高测试效率,缩短测试时间,提高测试的准确性。

  自动化测试相对于手工测试,主要有以下几点优势:

  1)提高测试效率

  手工测试是一个劳动密集型的工作,并且容易出错。引入自动化测试能够用有效、可重复的自动测试环境代替繁琐的手工测试活动,而且能够在更少的时间内完成更多的测试工作,从而提高了测试工程师的工作效率。

  2)降低对软件新版本进行回归测试的开销

  对于现代软件的迭代增量开发,每一个新版本大部分功能和界面都和上一个版本相似或完全相同,这时要对新版本再次进行已有的测试,这部分工作多为重复工作,特别适合使用自动化测试来完成,从而减小回归测试的开销。

  3)完成手工测试不能或难以完成的测试

  对于一些非功能型方面的测试,如压力测试、并发测试、大数据量测试、崩溃性测试等,这些测试用手工测试是很难,甚至是不可能完成的。但自动化测试则能方便的执行这些测试,比如并发测试,使用自动化测试工具就可以模拟来自多方的并发操作了。

  4)具有一致性和重复性

  每次自动化测试运行的脚本是相同的,所以可以进行重复的测试,使得每次的测试具有一致性,手工测试则很难做到这点。

  5)更好地利用资源

  将繁琐的测试任务自动化,可以使测试人员解脱出来,将精力更多地到测试案例的设计和必要的手工测试当中。并且理想的自动化测试能够按计划完全自动地运行,使得完全可以利用周末和晚上的时间执行自动化测试,每日构建技术日渐普遍。   6)降低风险,增加软件信任度

  自动化测试能通过较少的开销获得更彻底的测试效果,从而更好地提高了软件产品地质量。

  2.2 自动化测试方法与工具

  现在存在着各种各样的UI自动化测试框架,例如SilkTest和UIAutomation,这类软件和软件的开发环境相对独立,一般有自己专用的脚本语言和测试用例描述方法,适合于传统开发模式下的先开发后测试,不符合测试驱动开发的原则。本文用开源框架KIF展示了UI自动化测试在测试驱动开发中的应用。

  3、适用于测试驱动开发的UI自动化测试框架

  3.1 测试驱动开发对UI测试需求根据测试驱动的开发过程和UI自动化测试的技术的介绍,可以总结出对于适用于测试驱动的UI测试的要求:

  1)可视化:普通的单元测试对UI部分功能进行测试,但是只能证明功能的逻辑正确性,却无法看到该功能对UI的影响,通常需要再编译一遍程序,手动来测试UI的正确性。所以,UI测试应用在测试驱动开发时,要求其必须在测试过程中可视化。

  2)自动化:即能够模拟用户对界面的操作,如点击、滑动、捏合等手势,这些操作可通过各平台的accessibility功能实现。

  语言一致性:由于测试驱动开发遵循“测试先行”的策略,对于测试脚本的通用性要求不高,所以,采用与软件开发一致的语言既能减少开发人员的学习成本,又能充分利用各平台的accessibility功能。

  3)集成扩展性:由于现今的开发环境大都紧密集成成熟的单元测试框架,在该框架的基础上集成对UI控件的访问、操作功能,不仅能满足UI测试的需求,还能保证测试框架功能的完备性。同时,由于UI操作方式的多种多样,要求框架必须具备灵活性,要有一定的扩展能力。

  3.2 测试框架结构

  UI自动化测试框架的基础为成熟的单元测试框架上,并对单元测试进行扩展,另外添加了模拟用户操作的模拟、以及对用户操作对象UI控件的扩展(图1)。

  3.3 框架工作流程

  根据UI测试框架架构图,可以清晰的看到其工作流程:

  1)加载并解析测试用例(假如存在单独的测试用例描述文件);

  2)按照测试脚本所描述的操作操作方法对界面进行输入、点击、滑动等操作;

  3)通过界面控件的属性与期望结果对比,判断是否执行成功;

  4)输出测试结果。

  3.4 UI自动化测试驱动程序开发步骤

  根据测试驱动的开发步骤,联合以UI为测试核心的需求,总结出基于UI自动化测试的测试驱动开发步骤:

  1)根据界面的功能以及用户对界面的操作快速添加相应的测试用例;

  2)运行所有测试,新增加的测试无法通过;

  3)修改用户界面以及对界面的交互代码,做尽量少的改动让测试通过;

  4)运行所有测试,保证所有测试都能通过;

  5)重构代码,消除重复设计;

  6)回到1)直到写完系统所有的功能测试。

  4、测试驱动开发实例

  本文通过一个简单的IOS系统的登录界面的实例来展示UI测试驱动开发方法。

  4.1 UI界面描述

  4.1.1 界面功能描述

  登录界面有两个文本框,一个登录按钮。文本框分别用来输入用户名和密码,登录按钮用来确认并提交登录信息。

  4.1.2 用户操作要求

  1)用户名字符数在3-6之间;

  2)密码字符数在6-8之间;

  3)用户输入超过上限则只显示前8位;

  4)用户输入低于下限则让文本框获得焦点并显示键盘,等待用户继续输入;

  5)点击确认按钮,若用户信息不符合要求则让让不符合要求的文本框获取焦点,若符合要求则提交验证;

  6)点击界面空白处取消焦点。

  4.2 UI自动化测试驱动的开发过程实例

  在界面上添加用户控件两个文本

框和相应的说明标签,一个按钮,并设置其访问属性,此为程序的初始状态。

  4.2.1 用户名输入测试

  1)根据用户操作要求,书写用户输入上限的测试代码如下:

  代码解释,输入xukaitian超出了上限,所以文本框中应该显示期望值xukait。

  2)运行测试,此时测试失败,查看测试日志,提示与预期结果不符:

  3)修改界面控制器的代码,给文本框添加输入变化控制代码如下:

  4)再次运行测试,此时测试成功:

  5)重复上述步骤,分别对用户名输入下限测试以及其他限制条件进行测试开发。

  5、结语

  测试驱动开发在各项目上的成功运用激励了越来越多的开发者采用者这种开发方式,与此同时,用户对用户体验的追求也促使开发者将越来越多的注意力放在UI界面上,本文针对这两种现象,提出了UI测试在测试驱动开发中的应用,重点阐述了适用于测试驱动开发的UI自动化测试框架应具有的性质和其架构,并以IOS平台的KIF为例展示了其实践应用。在本文提出的架构中,对测试用例的描述解析考虑较少,这是下一步工作的重点。

  【参考文献】

  [1]蔡长霞.刘建平 基于敏捷测试的自动化技术分析与实践[J].工业控制计算机,2011,24(10).

  [2]何浩,程春玲.基于SilkTesst和XML的通用高效的用户界面测试方法[J].计算机应用,2013,33(1):258-261.

  [3]科恩.Scrum 敏捷软件开发[M].廖靖斌,吕梁岳,陈争云,等,译.北京:清华大学出版社,2012.

  [4]Kniberg,Henrik.Scrum and XP from the Trenches,Lulu[Z].com,2007.

  [5]杨怡君,黄大庆.Android 手机自动化性能测试工具的研究与开发[J].计算机应用,2012,32(2):554-556.

  [6]Freeman Harries. Software testing.IEEE.Vol5[Z].Sep, 2002:48-50.

相关文章

初中地理学生识图用图绘图习惯培养初探【通用3篇】

在初中地理教学中,地图作为学生不可缺少的学习工具。在多年的初中地理教学实践中,笔者认为正确认识地图、有效阅读地图、认真分析图表和绘制图表,是学习地理的非常好的习惯和有效方法,更是地理中的基本能力要...
论文2011-02-02
初中地理学生识图用图绘图习惯培养初探【通用3篇】

国贸实习报告【通用6篇】

在生活中,报告不再是罕见的东西,报告中提到的所有信息应该是准确无误的。在写之前,可以先参考范文,下面是小编帮大家整理的国贸实习报告,供大家参考借鉴,希望可以帮助到有需要的朋友。国贸实习报告1这几天我们...
论文2016-09-06
国贸实习报告【通用6篇】

试论池田大作科技伦理思想及其现代意义(精选3篇)

论文关键词:池田大作 科技伦理 现代意义 论文摘要:池田大作对现代科技对人类社会带来的负面影响有深刻的认识,其科技伦理思想建立在生命的世纪和整体方法论基础之上。他认为发展科学技术要以人为本,自然科学的...
论文2019-01-01
试论池田大作科技伦理思想及其现代意义(精选3篇)

加强数学应用教学的论文【优选3篇】

摘要:新课程改革注重知识的发生、过程,培养学生用数学的观点观察社会、思考问题,增强应用数学的意识,重视联系实际和数学应用意识,教师应加强数学应用教学,多让学生自主学习,重视课外实践,促进学生逐步形成和...
论文2015-08-09
加强数学应用教学的论文【优选3篇】

教师师德论文(精选3篇)

论文常用来指进行各个学术领域的研究和描述学术研究成果的文章,它既是探讨问题进行学术研究的一种手段,又是描述学术研究成果进行学术交流的一种工具。论文一般由题名、作者、摘要、关键词、正文、参考文献和附录等...
论文2014-01-03
教师师德论文(精选3篇)

地理毕业论文【推荐3篇】

摘要:在教学实践中,笔者了解到学生的地理思维能力欠缺是制约学生学习地理的一大障碍。因此,笔者从分析学生地理思维能力欠缺的角度,尝试探讨了如何更好的发展提高学生的地理思维能力。关键词:地理思维;欠缺地理...
论文2015-08-04
地理毕业论文【推荐3篇】