50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

测试微服务之建立测试文化

  • 2017-10-29
  • 本文字数:1712 字

    阅读完需:约 6 分钟

这是由来自 AWS 的工程师 Nathan Peck 发布的“测试微服务”系列文章的第一篇,介绍了测试金字塔模型以及如何建立测试文化。以下内容翻译自 Nathan 的博客。

自动化测试是一个软件公司取得成功的关键因素之一。经过严格测试的代码容易获得客户的信赖,而没有经过测试或缺乏严密测试的软件系统容易出现故障,让客户感到失望。

尽管在测试单体系统方面已经有很多最佳实践,但在测试分布式系统(比如微服务)时仍然面临很多挑战。开发者不但要确保每个组件的内部行为是一致的,也要确保组件之间能够良好地集成。分布式系统需要额外的故障测试,比如针对网络故障进行测试。有些分布式系统太过庞大,进行完整的端到端测试不太现实,所以开发人员需要制定一些策略,对整体架构的局部进行单独测试,同时还能保证组件之间的互操作性。

这篇文章介绍了一些测试分布式系统的基础概念,并讨论了如何在开发流程中加入这些概念,确保它们可以有效地落地。

金字塔模型

为了构建一个全面的测试框架,我们需要先了解“测试金字塔”概念。这一概念是由 Mike Cohn 提出的,当时的大部分软件测试还是通过用户界面进行的。测试工程师直接手动操作用户界面,或者编写自动化宏脚本来操作界面。这种方式通常无法检测出代码内部的问题。此时,测试金字塔的概念就变得十分重要,因为它让我们明白,用户界面测试应该处于金字塔的顶端。

使用多种测试类型可以帮助我们检测出不同类型的问题,不同的测试类型集中在系统的不同层面上。一个分布式系统的端到端测试可以被分为以下几个层次。

单元测试

单元测试用于验证服务内部的类方法或函数的行为。它们执行代码文件里的类方法或函数,提供不同的输入,并验证与每一个输入相对应的输出。

集成测试

集成测试用于验证服务的外部行为。测试框架会启动服务的一个实例,并调用服务的外部接口来执行业务逻辑。

端到端测试

端到端测试用于验证多个服务之间的交互行为。在一个独立的环境里启动多个服务的实例,让服务实例间发生交互,以便完成测试。端到端测试需要发起网络请求,比如 REST 请求,然后被调用的服务返回的响应进行验证。

用户界面测试

用户界面测试用于验证整个平台的行为,不仅会测试客户端的逻辑,也会测试后端系统的逻辑,确保客户端和后端系统能够正常交互。

建立测试文化

只有把测试作为开发流程和发布管道不可或缺的组成部分,才能让它发挥应有的作用。如果代码有问题,就不应该把它发布出去。

  • 无法通过测试的代码不应该被合并到代码仓库里。

  • 无法通过测试的代码不应该被发布出去。

金字塔模型里的每个测试层级都建立在下一个层级之上:

工程师们需要对测试抱有正确的态度,他们不仅要开发功能,也要负责编写测试代码,所以他们在很大程度上决定着测试的质量和效率。如果没有认真对待测试,就无法测出很多边界情况,又或者为了提高“覆盖率”而走捷径,但其实什么都没有测到。

我们不能为了测试而测试,测试的真正目的是为了交付高质量的软件给用户。测试人员要保证软件质量高起高走,在加入新特性或更改已有特性时仍能保证质量。

这就要求我们要严肃对待故障测试,我们不能为了让测试能够通过而去修改它们。有些测试时而通过时而失败,它们都是假性的测试,需要引起我们的注意。如果生产环境出现了缺陷,说明测试没有到位。如果发现了测试没能覆盖到的地方,需要给工程师足够的时间和资源去修复缺陷。

我们不能仅仅依赖工程师来建立良好的测试文化。产品经理也需要了解测试流程,并参与其中。如果他们对开发人员作出过分的要求,要求开发新功能的速度超过了开发人员能够对新功能作出全面测试的速度,那么软件质量就会受到影响,问题会一路跟着进入到测试管道,到达用户那里,影响用户满意度。

结论

为分布式系统创建完备的测试框架要求使用多个层级的测试。基于客户端 UI 的测试无法捕捉到各种类型的错误。软件工程师们必须建立起一种测试文化,把自动化测试融入到开发和发布管道的各个阶段,包括单元测试、集成测试、端到端测试和 UI 测试。

查看英文原文: Microservice Testing: Introduction


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-10-29 19:002824
用户头像

发布了 322 篇内容, 共 156.7 次阅读, 收获喜欢 148 次。

关注

评论

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

医疗公有云市场第一!

天翼云开发者社区

公有云 天翼云

斩获双项第一,天翼云问鼎中国医学影像云解决方案市场!

天翼云开发者社区

云服务 医疗云

新手该如何选择AI编程工具?文心快码Comate全方位体验

Comate编码助手

AI编程 文心快码 AI编程助手

StarRocks 数据分析加速:ETL 如何实现实时同步与高效查询

谷云科技RestCloud

数据处理 数据同步 ETL 数据集成 StarRocks

【数组与链表】数组的基本演绎法与排序“大乱斗”

华为云开发者联盟

c++ 数据结构 数组 华为开发者空间

企业发展的刚需:零碳园区如何为入园企业创造价值?

西格电力

绿色能源转型 碳中和碳达峰 零碳园区 能源可再生 智能化技术

AI不再“卖梦想”,Anthropic教行业用CFO的语言讲价值

Alter

AI

火山引擎Data Agent再拓新场景,重磅推出用户研究Agent

字节跳动数据平台

夜莺监控设计思考(二)边缘机房架构思考

巴辉特

Nightingale 监控告警 夜莺监控 开源监控

智能制造 柔性制造经验总结(5)

万里无云万里天

工业 智能制造 柔性制造

高达 30% 合作收益,TDengine 合作伙伴计划重磅发布

TDengine

tdengine 时序数据库

行业热点丨仿真驱动设计:兼顾性能、可持续性与效益

Altair RapidMiner

汽车 制造业 仿真 CAE hyperworks

焱融科技携手哈工大(深圳)共启AI推理存储研究,推进AI基础设施创新

焱融科技

AI推理 焱融存储 KVCache 哈尔滨工业大学(深圳)

怎么避免无意义劳动?奇富科技摈弃分库分表后,代码改造成本节省90%

老纪的技术唠嗑局

数据库 TiDB #OceanBase

工业设计 自控设计经验总结(12)

万里无云万里天

设计师 工业 工厂运维

微擎:让每个创意都能开花的小程序生态引擎

微擎应用市场

云栖实录|MaxCompute全新升级:AI时代的原生数据仓库

阿里云大数据AI技术

阿里云 数据仓库 MaxCompute

【数组与链表】循环链表实战 - 约瑟夫问题求解

华为云开发者联盟

c++ 数据结构 华为开发者空间

面向软件厂商的低代码解决方案:如何无需重构现有系统即可满足客户定制化需求?

星云低代码中间件

低代码 数字化 业务系统

作为测试工程师,我们该如何应用AI?

思码逸研发效能

AI 自动化测试 API测试 AI编程 思码逸

破壁者万里眼,点亮示波器的东方之眼

脑极体

AI

自动化运维新时代:智能调度与监控让集成更简单

谷云科技RestCloud

数据传输 数据同步 ETL 数据监控 数据集成工具

云栖实录 | 通义实验室基于MaxCompute进行大模型数据管理及处理

阿里云大数据AI技术

阿里云 数据处理 大模型 MaxCompute 通义实验室

Nginx的ngx_thread_pool模块解析:提升性能与可伸缩性

天翼云开发者社区

nginx CDN

动态加速中优化失败路径反馈的方法

天翼云开发者社区

CDN 全站加速

Sight AI 入门:5分钟实现OpenAI兼容的多模型AI调用

SightAI

MaaS 大模型 API 工具 开源‘

低代码新建表单实操:纯表单 / 列表表单配置 + 表名避坑

引迈信息

🔥 2025 OCP 峰会大爆点抢先看

GPU算力

复盘:如何用Coze+Kimi,搭建一个能自动分析财报的“金融助理”?

测试人

Sight AI 入门:5分钟实现OpenAI兼容的多模型AI调用

SightAI

MaaS 大模型 API 工具 开源‘

Sight AI 入门:5分钟实现OpenAI兼容的多模型AI调用

SightAI

MaaS 大模型 API 工具 开源‘

测试微服务之建立测试文化_语言 & 开发_Nathan Peck_InfoQ精选文章