在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

TDD/BDD 会导致不完整的单元测试吗?

  • 2008-02-24
  • 本文字数:1370 字

    阅读完需:约 4 分钟

Peter Ritchie 最近开始担心他认为很不妙的趋势,即开发者为了坚持 TDD BDD 而无法写好单元测试。特别地,他认为对“交互测试”的顶礼膜拜,最终带来的后果是不完整的单元测试;测试无法证明某个单元(对象)能在它有可能工作的任何环境下正常工作。首先,Peter 的想法中,最有趣的部分可能就是 TDD 与 BDD 之间不同核心目的的冲突。

Peter 利用“类是真实世界概念的自然抽象”这一理念作为自己观点的基础。他认为良好的单元测试 应该能够验证这些自然抽象出来的类,但可能在未来的某个时刻开始,TDD 和 BDD 将导致人们不去遵守这一原则:

我发现测试驱动开发(TDD)和行为驱动开发(BDD)这两种方法结合在一起后存在一个问题,那就是实践者只把系统各部分间的交互放在了最核心的位置,其实并没有做任何“单元测试”。他们只为了追随 TDD 和 BDD 的魔咒,最后却只见树木、不见森林,而成为盲目测试。单元测试的目标是独立的单元、应用程序中最小的可测试的部分。

Peter 引用了 Wikipedia’s BDD entry 中的一个例子来证明他的观点:

详细的测试仅测了 4,294,967,296 种可能性中的 13 种。这些测试可能很好地测试了一个系统预期的行为,但是并没有真正把 EratosthenesPrimesCalculator 当作一个单元来测试。如果系统只允许这样的行为,那么这些测试可以证明系统是正常的。但是,如果 EratosthenesPrimesCalculator 超出了这 13 种行为而被使用的话(这也正是将代码封装成类的目的:重用),那么它就算不是上已测试好的啦。

这个例子在很大程度上依赖于这样一个观点——一个单元的有效性 / 正确性完全是基于其名字所暗示的在现实世界中它所固有的特性。很多 TDD 的实践者会向这一点发起挑战,他们认为:一个单元的有效性只能在使用它的环境(系统)上下文中才能定义。JMock 的作者之一 Steve Freeman 说道:

测试先行的交互测试的思想是理清一个对象与它的环境之间的关系。例如,你正在模拟一个 DAO,但是 DAO 不是应用领域中一部分,它是实现领域的一部分。

而另一方面,很多做 TDD 培训的人会不认同这一点,他们认为:先行编写单元测试的主要作用在于它是一个单元模块该做什么、不该做什么的显式规约。下面文字源自于 Mario Gleichmann 的“ TDD 与按契约设计的对比”:

单元测试作为测试驱动开发(TDD)的一个重要组成部分,其作用并不在于能在多大程度上验证实现的正确性,而是有助于澄清单元模块行为的规约。事实上,驱动开发的东西应该是规约,而不是验证。你可以在行为驱动开发(BDD)的崛起中看到这种思想的回归。BDD 其实就是要寻找一个充分的词汇表并用一种很自然的方式编写规约(当然,这也是可以被自动化测试的),以便将注意力重新放到“组件在特定条件下应具有哪种行为”这个问题上来。

从“单元模块是由其上下文定义的”这种观点中引申出来的一个推论经常被引用,这个推论就是:按照单元测试的定义,它并不能反映出整体系统的质量和有效性,相反,要想做到这一点,就要在开发阶段中增加各种级别的验收测试 JS Greenwood 写道:

虽然集成测试少得可怜,但所有事情都被独立测试过了——每一个组成部分都很干净、独立、被良好测试并且可以信任其正确性,(这也是单元测试的极限了)。但是如何保证所有组件都能协同工作呢?这是一个灰色(甚至黑色)区域,除非能充分地结合单元测试和集成测试。

查看英文原文 TDD/BDD Leading To Incomplete Unit Tests?

2008-02-24 06:172846
用户头像

发布了 53 篇内容, 共 16.9 次阅读, 收获喜欢 2 次。

关注

评论

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

ModelArts Versatile -AI原生应用引擎,聚焦企业级Agent平台,最新核心能力一文速览

华为云开发者联盟

决策树训练速度提升99%的新方法

qife122

机器学习 特征选择

硅空位中心实现量子网络化的新突破

qife122

量子技术 硅空位中心

AI Compass趣味AI应用分享:Quin-AI塔罗占卜、FateTellAI命理分析、爱宠信箱宠物情绪陪伴应用

汀丶人工智能

浙大“卓越中心”发布两项成果突破,为航空航天科学计算注入新动能

极客天地

LAS平台Vibe Data Processing:AI驱动的数据处理新范式

字节跳动数据平台

大数据 数据处理 多模态数据湖

Apache Flink:从实时数据分析到实时AI

Apache Flink

flink AI 实时计算

深入底层:如何优雅部署 SeaTunnel 分离集群到 Kubernetes

白鲸开源

大数据 开源 Kubernetes 部署 Apache SeaTunnel

程序员专属秋日养生指南(Coding版),文内有秋天第一杯奶茶

Comate编码助手

程序员 文心快码 秋天的第一杯奶茶 程序员养生

第十八章 获得大量免费流量的核心:关键词

溪抱鱼

人工智能、

ROT混淆技术入门指南

qife122

安全开发 编码混淆

03.接口vs抽象类比较

杨充

日均处理 PB 级数据,基于 DolphinScheduler 的离线数据治理平台实现精准血缘追踪

白鲸开源

大数据 开源 数据治理 Apache DolphinScheduler 血缘分析

星云低代码:低代码不再是平台,而是“中间件”

星云低代码中间件

低代码 中间件 企业应用 可视化开发

从《中国开源年度报告》看中国开源力量的十年变迁中,Apache SeaTunnel 的跃迁

白鲸开源

大数据 开源 Apache SeaTunnel Apache软件基金会 OpenRank

文生绘动 Agent:从词语到动态影像,言出即成,你的AI动画创作伙伴

汀丶人工智能

LazyLLM教程 | 第3讲:大模型怎么玩:用LazyLLM带你理解调用逻辑与Prompt魔法!

商汤万象开发者

使用 Apache DolphinScheduler 构建和部署大数据平台,将任务提交至 AWS 的实践经验

白鲸开源

云计算 AWS Apache DolphinScheduler 思科 EKS

三天接入,零重构:低代码中间件的快速集成机制全解析

星云低代码中间件

ide 低代码 企业应用 可视化编程

管家级教程:在 Windows 上配置 WSL2、CUDA 及 VLLM,开源音频克隆项目

溪抱鱼

人工智能 前端 语音

Apache DolphinScheduler DataX 数据集成:新手入门全攻略

白鲸开源

大数据 Apache DolphinScheduler 数据集成 DataX 数据调度

教师如何规划教学与科研协同发展|北京理工大学医工交叉教学实践分享(5)

ModelWhale

AI教育 科研 北京理工大学

NineData 新增支持 AWS ElastiCache 复制链路

NineData

AWS 数据库迁移 NineData 无停机数据库迁移 ElastiCache

天猫商品详情API响应数据解析

tbapi

天猫商品详情接口 天猫API 天猫数据采集 天猫商品详情api

如何结构化日志记录增强网络安全性?

运维有小邓

网络安全 日志分析 日志管理 日志审计

第十八章 获得大量免费流量的核心:关键词

溪抱鱼

SEO

从数据感知到精准决策:舆情监测的全流程价值解析

沃观Wovision

舆情监测 沃观Wovision 舆情监测系统

镜舟科技受邀出席开源赋能金融创新论坛,共同推动金融行业开源技术规范发展

镜舟科技

金融创新 分析型数据库 开源治理 镜舟科技 MPP 架构

数据治理平台如何选?深度解析国产化全栈方案与行业落地实践

百分点科技技术团队

AI口语APP开发的技术框架

北京木奇移动技术有限公司

AI教育 软件外包公司 AI口语

TDD/BDD会导致不完整的单元测试吗?_研发效能_Mike Bria_InfoQ精选文章