InfoQ

文章

图书摘录:持续集成意味着持续测试

作者 Paul Duvall, Steve Matyas, Andrew Glover译者 李剑 发布于 2007年11月8日 上午1时57分

社区
Agile
主题
敏捷技术,
质量交付
标签
TestNG,
持续集成,
Selenium,
DbUnit,
Fit/Fitnesse,
测试驱动开发,
测试,
JUnit

持续集成(Continuous Integration,CI)是一个基本的极限编程(XP)实践,就算是永远不会考虑实施XP的团队也一样在用持续集成。Martin Fowler曾经指出过,从这一点上来看,它已经变成了任何一个出色的软件开发活动中的基础组件。Paul Duvall,Steve Matyas和Andrew Glover是“持续集成:改善软件质量并降低风险(Continuous Integration: Improving Software Quality and Reducing Risk)” 一书的作者,他们希望通过这本书能够帮助开发团队把“持续集成”这项重要的开发实践变成项目中的“non event”,也就是自然而然的日常发生的事情。如果成功地实施了持续集成,那么就可以保证每个开发人员自己的工作和共享的项目状态之间只有几个小时之间的距离,并且可以在数分钟之内同步。InfoQ提供了“持续集成”这本书中的“第六章:持续测试”的免费下载(pdf版本,共14MB),在该章节中介绍了编写不同种类测试以保证系统质量的策略。

测试是改善持续集成的关键环节,因为应用程序的构建时间大部分都是用来执行测试的。结构混乱的测试栈会导致构建陷入困境,而开发团队就不得不扔掉先前已经达成共识的持续集成实践,来换取用于编码的时间。这种所谓的捷径就又会使得“红色(表示失败)”构建频繁,进一步演化成为“门窗全毁”的场景,从而导致“红色”构建比正常构建的频率要高的多,以至于无法判断代码质量。而出现严重的产品问题的风险也会随之提高,最后开发人员就不得不进行长期的预发布测试,延长了部署时间。

在本章中,作者描述了以下种种主题及其之间的关系:

  • 自动化单元测试
    将单元测试自动化,特别是可以使用NUnit或JUnit这样的单元测试框架。单元测试不应该依赖于文件系统或者是数据库这样的外界条件。
  • 自动化组件测试
    使用JUnit,NUnit这样的单元测试框架来将组件测试自动化,如果你在使用数据库的话,还可以使用DbUnit或是NDbUnit。这些测试会包括更多的对象,也通常要比单元测试花费更多的时间。
  • 自动化系统测试
    系统测试比组件测试要花更长的时间运行,通常会有多个组件参与其中。
  • 自动化功能测试
    我们可以通过Selenium(用于Web应用程序)和Abbot(用于GUI应用程序)来完成自动化功能测试。功能测试是从用户的角度来执行的,基本上算是自动化测试栈中所需时间最长的测试。
  • 将开发者的测试进行分类
    把测试按照种类划分开来,就可以让速度慢的测试(比如组件测试)和速度快的测试(比如单元测试)按照不同的时间间隔来运行。
  • 首先运行较快的测试
    单元测试要先于组件、系统和功能测试运行,通过按种类划分测试就可以做到这一点。
  • 为缺陷编写测试
    基于新的缺陷来编写测试,保证该缺陷不会再一次为团队带来痛苦,测试代码的覆盖率也会相应提高。
  • 让组件测试可重复执行
    使用数据库测试框架来保证测试数据一直处于“已知的状态下”,这可以帮助组件测试做到可重复执行。

本章以一系列的问题作为收尾,开发团队可以用这些问题来评估自己的CI测试过程:

你是否把自动化测试进行了分类,例如单元测试,组件测试,系统测试和功能测试?

你是否对CI系统做过配置,以使它可以在不同的构建阶段来运行不同种类的测试?

你是否在为每一个缺陷编写自动化单元测试?

你的测试用例中有多少断言?你是否限制每一个测试只有一个断言?

你的测试是可以自动化运行的么?你的项目是否会把提交过的自动化测试代码放到版本控制仓库中?

在这一章里,作者还以各种测试框架中的例子进行了翔实说明,这些测试框架包括TestNG,Ruby,DbUnit,StrutsTest,Selenium和JUnit等。

敬请阅读InfoQ为您独家奉上的章节摘录:“第六章:持续测试”,同时您还可以在O'Reilly Safari上看到完整的目录,从而对全书所讲述的其他主题有大致的了解。

查看英文原文:Book Excerpt: Continuous Integration means Continuous Testing

没有回复

回复

独家内容

程立谈架构、敏捷和SOA实践

支付宝首席架构师程立在本文分享了支付宝技术架构的发展,对架构的认识,成功架构的特点,如何避免架构设计的失败,以及在敏捷和SOA方面的实践等。

Emmanuel Bernard谈Bean验证规范

InfoQ有幸采访到了Emmanuel Bernard,向其了解Bean验证框架及专家组正在寻求的社区参与的更多相关信息。

通过索引器简化C#类型信息访问

作为一个有别于Java、Ruby等语言的一个特性,C#可以用索引器(Indexer)将类型本身以对象数组的形式供外部使用。同时,把索引器和LINQ结合使用倒是一个非常不错的组合,索引器做接口、LINQ完成内部检索逻辑,客户程序在无需记住具体方法名称的前提下,按照键值检索即可,索引器内部则依托LINQ to系列的基础,提供对各种异构数据源的访问。

产品负责人成功之道

Scrum中,产品负责人这个角色具有很大的影响力,能够带来很高的价值。但要想运用得当,可没那么轻而易举。如果做得好,就可以在客户和开发者之间建立更为融洽的关系,并能够增加组织的竞争优势。

硝烟中的Scrum和XP

在本书中,作者Henrik Kniberg讲述了他在一年的时间里,带领40人的团队实施Scrum的过程。他们试过了多种团队尺寸(3~12人)、sprint长度(2~6星期),定义“完成”的不同方式,不同的backlog格式,各种测试策略,在多个Scrum团队之间进行同步的多种方式。他们还尝试过XP实践——持续集成、结对编程、测试驱动开发等等,还试过了把XP跟Scrum组合。

软件开发中的准时化生产

准时化生产(Just In Time)是精益生产(Lean Production)和丰田生产系统(Toyota Production System)中的概念,敏捷开发与准时化生产中的很多观点和实践是一致的,精益思想作为精益生产背后的指导思想也正在积极地影响着软件开发领域,向其中不断注入创新与活力。

Tapestry for Nonbelievers

I. Drobiazko和R. Zubairov合作撰写了一篇文章,详细介绍Apache Tapestry 版本5——一个面向组件web框架。文章向读者展示了创建组件方法,并谈到了Tapestry中的IoC以及Ajax的相关特性。

ESB拓扑方案

在本文中,Adrien Louis讨论了两种基于ESB的SOA拓扑方案的优缺点:单个公司级ESB vs. 彼此互联的“部门级”ESB系统。Adrien讨论了每种方案对管理、业务监测、治理、可靠性和编配等问题的影响。