写点什么

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

  • 2007-11-08
  • 本文字数:1538 字

    阅读完需:约 5 分钟

持续集成(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

2007-11-08 01:571494
用户头像

发布了 197 篇内容, 共 52.5 次阅读, 收获喜欢 20 次。

关注

评论

发布
暂无评论
发现更多内容

如何提升企业在全面预算中管理组织水平?

用友BIP

全面预算

软件测试 | 性能测试的误区(一)

测吧(北京)科技有限公司

测试

四行代码开启流计算之旅

吴英骏

数据库 开源 流计算 云原生 存储

2023-06-19:讲一讲Redis分布式锁的实现?

福大大架构师每日一题

redis 福大大架构师每日一题

一文读懂火山引擎A/B测试的实验类型(2)——可视化实验

字节跳动数据平台

A/B 测试

软件测试—性能测试的专业术语2

测吧(北京)科技有限公司

4 个月、2 万颗星,1 个恒纪元

Zilliz

非结构化数据 Milvus 大模型时代 向量数据库 zillizcloud

Google Guava中 EventBus 导致线程阻塞

红袖添香

Java 多线程 EventBus

SCADA系统架构的类型

2D3D前端可视化开发

物联网 web组态 工业自动化 SCADA 工业组态

软件测试—性能测试的专业术语1

测吧(北京)科技有限公司

测试

社交泛娱乐全球化,看融云出海如何助力玩法创新催生长线黑马?

融云 RongCloud

音视频 融云 泛娱乐 出海 通讯

基于OpenHarmony开发的玻璃拟态天气应用(1)项目介绍及项目的初始搭建

路北路陈

前端 HarmonyOS OpenHarmony应用开发 6 月 优质更文活动

快速掌握 Axios 请求库的基本用法

Liam

程序员 开发 HTTP API axios

TRUNCATE 语句到底因何而慢?

爱可生开源社区

MySQL 源码 innodb TRUNCATE

软件测试 | 性能测试误区(二)

测吧(北京)科技有限公司

测试

JMeter笔记12 | JMeter集合点

测试 单元测试 Jmeter 性能测试 接口测试

OpenHarmony社区运营报告(2023年5月)

OpenHarmony开发者

OpenHarmony

低代码赋能数字化转型的5种方式

这我可不懂

低代码 数字化转型 JNPF

九科信息亮相第三届中国(深圳)天使投资峰会

九科Ninetech

数字底座的连接集成加速数智企业互联互通

用友BIP

数智底座 数字底座 连接集成

数智人力:如何通过搭建全球人才供应链帮助企业海外扩张?

用友BIP

人力资源 数智人力

沉浸式下载Niconico视频到手机相册,手残党们快快跟上!

frank

中国农发行的全面预算管理新举措

用友BIP

全面预算

霍格沃兹测试开发学社线下班开班啦!无offer返学费哦!

测吧(北京)科技有限公司

测试

软件测试 | 性能测试的种类有哪些?

测吧(北京)科技有限公司

测试

JMeter笔记11 | JMeter事务

测试 Jmeter 性能测试 自动化测试 接口测试

70+页实战经验分享,《研发效能红宝书》重磅发布 | 附下载

思码逸研发效能

研发效能

国外服务器助力你的网站实现全球业务拓展!

一只扑棱蛾子

国外服务器

合约交易所系统开发搭建流程

薇電13242772558

系统开发

KaiwuDB 受邀出席大型企业数字化转型峰会暨工赋山东济南峰会并发表演讲

KaiwuDB

KaiwuDB 数字化转型峰会

用好支付宝小程序云云开发,告别繁琐的小程序开发流程

TRaaS

小程序 支付宝小程序

图书摘录:持续集成意味着持续测试_研发效能_Andrew Glover_InfoQ精选文章