写点什么

测试驱动开发?还是测试驱动需求?

  • 2007-11-21
  • 本文字数:753 字

    阅读完需:约 2 分钟

从哪开始练习测试驱动开发?和需求一起,还是设计?或者是另一种方式,自顶向下或向底向上?当你不用代码写第一个测试时,这个测试应该怎么表现出来呢?在敏捷社区中,这两种方法都被实践过,但在如何提供更大的价值这一点上没有达成一致。

Kinderman 和一些 rails 开发者交谈中,问他们使用什么样的方法,是自底向上的 TDD 呢,还是自顶向下的 TDD ?他期望每个人都从自顶向下——也就是说,从需求开始,为需求写测试,然后构建一个系统来满足且仅满足这些需求(这也就是行为驱动开发(BDD))。但令他惊讶的是,他发现几乎所有人都采用从底向上的方式。

“自底向上”这种方式存在的问题是:直到实现了调用者(clients)后,才知道这个调用者真正需要什么组件。而为了实现这些调用者,开发人员还要想这些使用者是如何被它们的调用者所使用的。这使我们会一直追溯到设计的顶点!真希望开发者深思熟虑以后,他们能写出一套完整的测试,来测试那个能够直接解决调用者需求的组件。但是,根据我的经验,这是非常罕见的。事实上,对于它的调用者来说,这些低层组件实现的功能很难用,要么太多,要么太少,要么太笨拙,要么太复杂。

正如 Ryan 所述,这似乎是要么都做,要么都不做。可是,另外一些人写功能测试(或自动化验收测试)也有很长时间了,而且是先写测试。这种方式有时被叫作故事驱动开发测试驱动需求(TDR), 或行为驱动开发(BDD)。那些使用测试驱动开发(有自底向上的,也有自顶向下的)来实践这种方式的人发现,这样不仅提高质量,而且有助于在客户、开发人员和测试人员之间建立社会性文化。
那么,你怎么做 TDD 呢?你用自顶向下方式,还是自底向上?你的团队用 TDR 吗?你用哪种方式呢?还是两种都用?最重要的一点,你这么做的目标是什么?

查看英文原文: Test Driven Development or Test Driven Requirements?

2007-11-21 00:351894
用户头像

发布了 100 篇内容, 共 25.9 次阅读, 收获喜欢 5 次。

关注

评论

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

打卡智能中国(一):看守隧道的老人

脑极体

隧道 智能中国

成为海上霸总,全靠5G?

白洞计划

5G

基于SLO告警(Part 3):开源项目 sloth 使用

Grafana 爱好者

云原生 可观测性 Prometheus SRE SLO

js事件循环与macro&micro任务队列-前端面试进阶

loveX001

JavaScript

手写一个Redux,深入理解其原理-面试进阶

beifeng1996

React

校招前端二面常考react面试题总结

beifeng1996

React

如何在 C# 项目中链接一个文件夹下的所有文件

newbe36524

面试必问:说一下 Java 虚拟机的内存布局?

王磊

java面试

你是如何使用React高阶组件的?

beifeng1996

React

面试官:vue2和vue3的区别有哪些?

bb_xiaxia1998

Vue

说说你对Vue的keep-alive的理解

bb_xiaxia1998

Vue

科技呵护女性健康,中国航天携手倍舒特成立“中国航天女性呵护研发中心”

科技大数据

滚动前行的轮子 — Flutter 交错动画应用实例

岛上码农

flutter ios 前端 安卓 跨平台开发

Java高手速成 | 使用TCP进行手机文件传输

TiAmo

Java TCP

理解「业务」与「技术」概念

架构 技术 业务

滴滴前端一面必会vue面试题(附答案)

bb_xiaxia1998

Vue

前端vue面试题

bb_xiaxia1998

Vue

2 理解商业模式和业务模式

涛哥 数字产品和业务架构

商业模式 业务模型

Okhttp 如何构建一个 Get 的 URL

HoneyMoose

js异步编程面试题你能答上来几道

loveX001

JavaScript

2023最新前端面试总结

loveX001

JavaScript

如何整理自己的前端面试题库

loveX001

JavaScript

阿里前端一面必会react面试题总结

beifeng1996

React

测试驱动开发?还是测试驱动需求?_研发效能_Amr Elssamadisy_InfoQ精选文章