lsekfe 发表于 2021-10-11 14:38:50

自动化测试框架的好处,看了就会爱上!

自动化测试因其节约成本、提高效率、减少手动干预等优势已经日渐成为测试人员的“潮流”,从业人员日益清楚地明白实现自动化框架是软件自动化项目成功的关键因素之一。本篇文章将从什么是真正的自动化测试框架、自动化脚本如何工作以及自动化测试框架会如何在测试过程中为你提供竞争优势三个方面进行阐述,让您通过这一篇文章,踏入自动化测试框架的领域。

  自动化测试的优势
  自动化测试的流行和诸多优势并不意味着它是灵丹妙药,定制型项目、周期短、测试易用性等情况并不适合自动化测试。但不可否认的是,如果认真计划和执行自动化测试框架,确实会为软件开发和测试公司带来以下好处:

  最短时间-最大收益
  构建任何可行的自动化测试框架和自动化脚本都可以最大程度地减少编写和运行测试所花费的时间,从而可以在短时间内获得最大的输出。另外,拥有优秀的自动化测试框架后,人力就可以从诸如同步、错误管理、本地配置,报告生成、解释等这些常见问题中解脱出来。
  可重复使用和可读的自动化代码
  当你使用现有组件库中提到的代码时,大可以放心,它在以后的时间内仍然是可读和可重复使用的,并且所有相关任务(如报告、同步和故障排除)都将变得更易访问。

  资源优化
  一些公司没有如设想的一般从自动化实施中受益,因为从自动化测试中获得的效益取决于采用它的灵活性。 如果自动化系统是灵活的,并且与从事各个组件的不同团队兼容,那么在资源优化和知识共享方面可以提供巨大的收益。
  自动化测试框架的定义
  在其他很多行业中,“自动化”指的是通过智能算法自动处理流程,流程运行是很少或完全不需要人工干预。而在软件行业中,自动化测试指的是通过自动化工具(授权版本或开源版本皆可)对软件应用程序进行各种测试。从技术角度来说,自动化测试框架是一组定制的、可以用来执行脚本化测试和全面报告测试结果的交互式组件。
  要成功地构建自动化测试框架,需要考虑到软件质量保障专家的建议,他们可以帮助观察并帮助控制整个测试过程,提高测试结果的准确性。经过精心设计的自动化测试框架能让测试人员以一种实用、简化的方式执行自动化测试。

  自动化测试框架的类型
  以工具为中心的框架
  不管是商业自动化工具和开源自动化工具,都有有助于在测试环境中生成报告、测试套件和分布式测试执行的系统基础设施。比如Selenium 自动化框架,该框架具有主要组件WebDriver——基于Web浏览器的插件,用于控制和操作 Web 浏览器中的应用程序的 DOM 模型。Selenium 测试自动化框架还拥有实用的编码库和记录回放工具。
  另外一个专用于工具的重要框架是 Serenity,它是围绕 Selenium Web 驱动程序构建的加速器。 在这种情况下,为加快测试自动化实施过程的速度,社区将特定组件组合在一个公共实体中。
  诸如 TestComplete,Ranorex HP QTP 这些工具专用框架时,就很难做出明确的判断,因为它们都是由带有动作模拟器、报告和脚本 IDE 的已部署基础架构预先构建的。

  以应用为中心的框架
  这种类型的框架是为实现某个特定应用程序项目自动化而定制的。以应用为中心的框架支持某个指定目标的应用程序实现测试自动化的需求,由从开源库构建的组件驱动。这种框架可以围绕SUT创建友好的测试环境来运行一些基本功能,包括部署开发的应用程序、运行应用程序、测试用例执行、直接测试结果报告和便于编码的包装器控件。以应用为中心的框架还会有一个组件来支持在不同操作系统和浏览器上跨各种云环境的测试运行。

  关键字驱动框架
  关键字驱动框架主要可以吸引缺乏编码经验的新手开发和测试人员,它既可以是以工具为中心的框架,也可以是以项目为中心的框架。关键字驱动框架可以让编码不熟练的员工参与编写、理解自动化脚本。用于编码的关键字集(如 Login、NavigateToPage、Click、TypeText)作为关键字存储库安装在代码库里,根据提供的关键字引用编写脚本的电子表格将被传递到关键字解释器来执行测试。

  理想的自动化测试框架的主要组件
  如果要实现功能强大且性能卓越的测试自动化框架(无论是开源还是商业的),就必须把包括构成其核心的某些组件考虑在内。 有些框架可能包括所有组件,也有些框架只包括其中几个,所以不必在每个框架中都涉及到下面提到的所有组件。

  1. 测试基础组件
  a)单元测试
  单元测试基础组件可以作为任何自动化测试框架的基本部分。它可以用于以下情况:
  ● 通过@test 或等特定的形式来定义正在使用的测试方法
  ● 执行影响自动化测试最终结果的断言
  ●运行简单明了的测试
  无论是从命令行、IDE、专用工具还是 CI(持续集成)系统运行测试,为了确保单元测试以简单的方式运行,单元测试库都提供了测试运行器。
  单元测试库支持几乎所有编程语言,比如以下这些:Java 的 JUnit 和 TestNG,.NET 的 NUnit 和 MSTest,Python 的 unittest(前身为 PyUnit)。

  b)集成和端到端测试
  在执行集成和端到端测试自动化的同时,也非常合适去实践现有测试库提供的功能。由应用程序UI驱动的API级测试需要有消除不必要的编码负担的组件,这样能让与被测应用程序的交互变得更容易。因而,测试人员就不会受到连接到应用程序、发送请求、接收结果响应这些编码工作的困扰。
  这种类型的几个重要测试组件有:Selenium(可用于主要语言)、protractor(特定于 JavaScript)、Karate DSL(Java 特定的 API 级集成测试)。

  c)行为驱动开发(BDD)
  专门用于BDD的组件以行为规范为目标,以可执行代码的形式创建可执行规范。在这部分,测试人员可以将预测行为的不同特性和场景转化为代码。尽管不像其他测试工具哪有直接跟被测应用程序交互,但可以作为BDD过程的支持,创建与自动化测试的范围和意图相一致的活动文档。BDD组件的典型例子有:cucumber(支持主要语言)、Jasmine (JavaScript)、SpecFlow (for .NET)。

  2、测试数据管理
  在软件测试自动化和测试创建过程中,最大的困难是如何利用测试数据管理系统。随着自动化测试数量的增加,始终存在这样一个问题:确保执行特定测试所需的某些测试数据在执行测试时可用或可创建。目前对这种情况并没有一个万无一失的解决方案,这就要求采用可靠的测试数据管理方法来让自动化工作成功运转。
  因此所采用的自动化测试框架需要配置充分,以便能提供基本的补救措施来进入或创建、清除要执行的测试数据。解决这一问题的方法是使用适当的模拟工具,使数据更加简化、更加清晰、更易于理解。

  3、mock、stubs和虚拟资产
  在对自动化测试进行实践和探索的历程中,可能会出现以下情况:
  ●希望将模块与在单元测试中有经验的已连接组件隔离
  ●处理在现代应用程序的集成,或端到端测试中常见的繁琐而关键的依赖关系
  在这些情况里,就会觉得创建mock、stubs和虚拟资产来反映连接组件的行为模式是非常必要的,还可能会发现处理 mock 和 stub 是一项大范围、大体量的任务。无论如何,测试人员都会意识到,在开发自动化测试框架期间选择有用的虚拟化工具是件十分重要的事。

  实现模式的通用机制
  除了以上提及自动化框架组件,还有一些有用的机制可以帮助创建、使用和维护自动化测试,例如:
  包装器方法(Wrapper methods):使用 Selenium WebDriver 组件时,创建自定义包装器会让人更轻松地处理错误。 创建了用于 Selenium API 调用的自定义包装后,就可以更好地处理超时、异常处理和故障报告。 这之后,创建了自动化测试的人员可以重新使用,这样就可以避开复杂流程的关注点,专注于进行有价值的测试。
  抽象方法(Abstraction methods):抽象机制意味着可读性的提高和冗余细节的掩盖。例如,在创建 Selenium WebDriver 测试时使用页面对象的目的是在网页上公开用户输入操作,包括输入凭据或单击页面上的某处,目标是通过超越或绕过探索页面特定元素的需求来实现高级测试方法。 此方法适用于许多类似的应用程序和自动化测试。

  测试结果报告
  在选择将测试结果报告到自动化框架中的库或机制时,需要将查看这份报告的目标受众考虑在内。在这方面,需遵循以下几个注意事项:
  ●诸如 Junit 和 TestNG 之类的单元测试框架生成的报告主要针对如 CI(持续集成)服务器之类的接收系统,这些系统最终会对其进行解释并以其他软件可使用的 XML 格式进行呈现。
  ●当寻求使用大多数人都能理解的语言作为进行报告的工具时,你可能需要考虑使用与单元测试框架兼容的商业工具,比如用于 Junit、NUnit 和 TestNG 的 UFT-Pro。
  ●另一种选择是利用诸如 ExtentReports 之类的第三方库,该库以易于理解的格式创建测试结果报告,包括通过饼形图、图形或图像进行可视化解释。

ascdms 发表于 2022-4-8 12:15:49

图形或图像进行可视化解释。
页: [1]
查看完整版本: 自动化测试框架的好处,看了就会爱上!