如何创建自动化功能测试的基本原则

介绍

  每个实行持续交付的项目,都有生产流水线的元素,如持续集成和自动化测试。这些测试是在不同层面进行的,从单元测试到冒烟测试再到功能测试。自动化功能测试的优点之一是可重复性和可预测的执行时间。出于这个原因,它应该作为软件质量的每一个构建之后的指标。功能测试自动化往往会成为一个瓶颈,所以你应该熟悉一下如何创建这样的测试的基本原则。

  首先设计你的测试

  测试集合可以比作盆景树。

  最初的时候,我们照顾树根和树干。我们选择会成长的主要分支,我们每天都细心照料这棵树并等待它长出健康的叶子。

  我们可以以类似的方式继续测试。

  我们建一个将负责应用程序主要功能(例如:开启)的基类。

  根据说明,我们先明确将被测试覆盖的应用程序的主要功能,然后每天我们在执行测试的时候都添加更多平行测试。

  每一个支持测试(例如创建一个新的用户)的方法都需要与测试分离——让我们在单独的类里面来实现。

  你应该在包括了应用程序主要功能的目录里保持类。

  去建一个规定很多功能共有方法的抽象类是很好的做法。

  如果你正在测试Web应用程序,就用页面对象设计模式。该模式里,一个类及其方法对应了单个页面的功能或一个大型网页里单个页面上的一个元素。

  无需事事自动化

  自动化花费很多,所以你应该主要测试应用程序的主要功能。

  某些测试可以快速轻松地手动完成,且潜在脚本可能难以实现。

  值得用到自动化的是那些繁琐的需要被重复很多次的,和那些需要大量数据验证的测试工作

  写短测试

  在一个或多个测试失败的情况下,开发团队的任何成员都应该能够轻松地找到错误的原因。

  出于这个原因,每个测试方法里应该最多有5个断言,并且每个方法都必须提供的测试操作的完整记录。

  明智的做法是使用BDD(行为驱动开发)技术,但是当你没有用一个特定的测试框架时,你应该把接下来的测试步骤放在comments //given //when //then下。

  创建独立测试

  在测试类中的每个方法应该是一个独立的实体,而不是依赖于其他测试。我们应该能够在任何时间运行单个测试。否则,这样的测试用例集将来维护起来就会很贵——必须定期跟踪和更新测试之间的联系。

  很多时候,测试需要一定的前提条件来满足。这些条件不应该用外部方法,应该在试验开始时运行。如果这些条件和测试类的所有方法一样,它们就可以被放在一开始进行的方法里(例如:在JUnit中被标记为@ BeforeClass)。

  关注可读性

  源代码应该是自我记录的,而写下以下几行代码的每个利益相关者应该明白测试在做什么,为什么它被这么写。尽量避免在源代码注释,因为它也必须被更新。这值得花比平常多一点的时间来命名方法,从而使你的代码更易读。

  再看看行为驱动开发技术,每个测试方法都应以单词“应该”开始,而不是“测试”。

  根据这一惯例,我们马上就可以明白一个特定的方法测试什么内容了,它在分析测试报告时特别有用。

测试必须要快

  正如在本文开头所提到的,自动化功能测试应该是应用程序质量的一个指标。连续传递过程中的每一步都应指明最长持续时间;并且根据这个概念,开发团队应该尽快获得有关软件质量的反馈。自动化功能测试的持续时间应不超过几分钟。

  对一个非常全面的测试集来说,有必要并行运行测试(经常在不同的机器上)。虚拟化在这里可能是非常有帮助的。

  创建抗变测

  最常提及自动化功能测试的缺点是其对应用程序中变化的低抵抗性,尤其是在GUI中。

  在Web应用程序中,测试应该能抵抗网站的内容的变化。测试应该只验证功能,这就使得它可以在不同的位置运行测试。这并不意味着我们不应该编写自动化测试来检查网页的内容。

  如果你已经想创建这样的测试,你应该遵循DDT(数据驱动测试)技术。这意味着,检查内容是与源代码分离开的。

  Web应用程序的页面布局变化非常频繁,这已经影响到了用户界面。

  当你设计一个界面时,每个区段和每个页面你都应该有一个你可以用来测试的唯一标识符,即使一个网站的层次结构发生了变化。

  自动化测试无法取代人类

  功能自动化测试可以是项目中的主要测试技术,但绝不是唯一的一个。

  自动化测试是可重复再生的,他们的覆盖范围总是相同的。

  另一方面,虽然探索性测试是低再生的,但是它们能够覆盖自动化测试未触及的区域。

  你还应该记住,自动化测试的“绿色”状态并不意味着你的应用程序是没有错误的。

  这种情况往往会让测试员分心,而且有可能会影响测试的准确性。

最新内容请见作者的GitHub页:http://qaseven.github.io/

时间: 2024-10-08 03:23:32

如何创建自动化功能测试的基本原则的相关文章

自动化功能测试的基本原则

介绍 每个实行持续交付的项目,都有生产流水线的元素,如持续集成和自动化测试.这些测试是在不同层面进行的,从单元测试到冒烟测试再到功能测试.自动化功能测试的优点之一是可重复性和可预测的执行时间.出于这个原因,它应该作为软件质量的每一个构建之后的指标.功能测试自动化往往会成为一个瓶颈,所以你应该熟悉一下如何创建这样的测试的基本原则. 首先设计你的测试 测试集合可以比作盆景树. 最初的时候,我们照顾树根和树干.我们选择会成长的主要分支,我们每天都细心照料这棵树并等待它长出健康的叶子. 我们可以以类似的

实施自动化功能测试的解决方案

摘要 当今的企业需要掌控其关键业务应用的所有功能测试,以确保所有业务流程工作符合预期.通过实施自动化的功能测试,企业可以极大提高测试速度和精度,从挼间项目中得到更高的投资回报并且显著地降低风险. 本文简要描述了自动化功能测试的优势和挑战,帮助企业考虑实施最佳测试自动化的方法. 1.介绍 毫无疑问,严格的功能测试是成功开发应用的关键.开发人员,测试小组和管理人员所面临的挑战是,如何加速测试流程和提高测试的精确性和完备性,同时还不能增加已然很紧张的预算. 通过将功能测试的关键环节自动化,可以满足有挑

如何使用MFC和类型库创建自动化项目

摘要 本文详细介绍了如何自动化像Microsoft Office这样支持COM的应用程序. 更多信息 下面部分介绍了如何创建MFC项目.采用Microsoft Excel举例,你可以将前8个步骤用于 任何项目,修改9-15步用于不同的应用程序. 创建自动化项目 1. 在Microsoft Developer Studio中,创建"MFC AppWizard(exe) "项目,命名为"AutoProject." 2. 在第1步的MFC应用程序向导中,选择"D

基于IBM Rational Robot的自动化功能测试框架

简介: 本文介绍了构建在 IBM Rational Robot 基础之上的自动化功能测试框架,来帮助组织更好的 进行自动化的功能测试. 1. 前言 测试本身就是一项异常艰苦的工作,而成功的进行自动化的功能测试,对很多软件开发组织来讲,更 是困难重重.本文介绍了构建在IBM Rational Robot基础之上的自动化功能测试框架,来帮助组织更好的 进行自动化的功能测试. 2. 现实的挑战 2.1 自动化测试的迫切需求 随着业务的变化,软件产品的种类越来越多,软件产品的升级越来越快,在很多的软件开

自动化功能测试的逻辑

持续交付涉及到软件开发从需求到上线.运维全生命周期的各个活动.其中很重要的一个活动就是测试.如果没有自动化测试,整个交付的节奏就会慢下来.接下来我们来聊一聊这背后的逻辑和如何才能把它做好. 软件开发中的自动化测试可以粗略的分为自动化单元测试和自动化功能测试.二者有很多的相似之处,但同样也有很多不同的关注点.本文主要关注的是 自动化功能测试 . 为什么要做自动化测试 如果你的软件是Web形态的,则用户可以通过浏览器来使用你的软件:如果你的软件是手机游戏,则用户需要有一台手机才能使用你的软件.而 功

使用QTP进行silverlight的自动化功能测试

问题描述 我使用的是qtp11来进行silverlight自动化功能测试的,一些控件都能识别,但是遇到一些覆盖类型(在一个控件上叠加一个控件)的就识别不出来了,我用对象探测器来探,根本就探不到外面那层的,只能识别到最里面的那层!在录制的时候我看到脚本里好像识别出来了.特别是silverlight里面有一些控件识别不了,比如自己制作的按钮就识别不了,录制的时候是使用坐标来进行点击的.求解决方案啊! 解决方案 解决方案二:自己先顶下,希望能帮我解决,我只想在公司立足啊!解决方案三:该回复于2011-

Rational Functional Tester一款Jazz协作平台自动化功能测试工具

Rational Team Concert(RTC)是 Jazz 协作平台上的一款 Rational 产品.结合 Jazz 平台高透明性和清晰度的特点,RTC 的优势也很明显地表现出来: 非常适合团队的协同合作,能够极大的提高产品的开发效率. 在一个产品的开发周期中,为团队协作开发提供很好的扩展功能. 使软件的开发更有效率,更智能,更灵活多样. 项目的更新,会实时地反馈到团队以及与项目相关的的每一个成员,使整个项目的进度变得清晰明了(该特点正是本文下面将要 重点讲解的内容). 另外 RTC 还支

使用SWTBot为您的eclipse应用创建自动化GUI测试用例

简介:基于 eclipse 的应用非常广泛,当然也就带来了对其进行 GUI 自动化 测试的需要.SWTBot 提供了比较完善的 SWT 和 eclipse 富客户端应用(RCP) 的测试功能,本文详细的介绍了 SWT 的设计结构和一些特性,并通过一个实例来 说明,如何为您的 eclipse 应用创建和执行基于 SWTBot 的测试用例. SWTBot 是一个年轻的开源项目,致力于简化 SWT 和基于 eclipse 的富客户 端应用的 GUI 测试,平台独立,功能强大.该项目已经被接纳到 ecl

GUI功能测试自动化模式

对于某个特定程序,为其开发自动化功能测试解决方案的过程,与创建该程序的过程,二者相较并没有很悬殊的差别.自动化测试是一个非常年轻的领域,它正在不断经历大量的进步.提升和标准化进程.在这个领域中,涌现了许多与"被测系统"(SUT,System Under Test)互动的新工具. 现在,软件开发方面有大量可供选择的方法论和途径,例如:面向对象编程.函数式编程.领域驱动设计.测试驱动设计.行为驱动设计等等.它们拥有明确的声明性概念和理论,并简化了对初始系统架构的定义过程.对系统的理解以及开