写点什么

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

  • 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:351519
用户头像

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

关注

评论

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

vue组件通信方式有哪些?

bb_xiaxia1998

Vue

细说React组件性能优化

xiaofeng

React

vue组件通信6种方式总结(常问知识点)

bb_xiaxia1998

Vue

高频js笔试题看这一篇就够了

helloworld1024fd

JavaScript

这可能是你需要的React实战技巧

夏天的味道123

React

详解React的Transition工作原理原理

夏天的味道123

React

chrome调试工具之Sources

格斗家不爱在外太空沉思

浏览器 浏览器测试 11月月更

技术分享 | 如何确保API 的稳定性与正确性?你只需要这一招

霍格沃兹测试开发学社

从零到一手写迷你版Vue

helloworld1024fd

JavaScript

说说前端经常考的手写题

helloworld1024fd

JavaScript

读懂React原理之调和与Fiber

xiaofeng

React

React源码分析3-render阶段(穿插scheduler和reconciler)

goClient1992

React

从纯函数讲起,一窥最深刻的函子 Monad

掘金安东尼

前端 11月月更

React源码解读之React Fiber

flyzz177

React

chrome调试工具之Elements

格斗家不爱在外太空沉思

浏览器 11月月更 elements

华为云从入门到实战 | 云速建站服务与企业主机安全服务

TiAmo

华为 华为云 11月月更

Istio Ambient Mesh七层服务治理图文详解

华为云开发者联盟

云原生 后端 华为云 企业号十月 PK 榜

决策树-泰坦尼克号幸存者预测

烧灯续昼2002

Python 机器学习 算法 sklearn 11月月更

计算机网络:数据链路层功能

timerring

计算机网络 11月月更 数据链路层

ReactDOM.render在react源码中执行之后发生了什么?

flyzz177

React

通俗易懂的React事件系统工作原理

夏天的味道123

React

React源码分析2-深入理解fiber

goClient1992

React

React Context源码是怎么实现的呢

flyzz177

React

Spring Boot 实现接口幂等性的 4 种方案

小小怪下士

Java spring springboot

chrome调试工具之Console

格斗家不爱在外太空沉思

浏览器 浏览器测试 11月月更

一步步实现React-Hooks核心原理

helloworld1024fd

JavaScript

React-Hook最佳实践

xiaofeng

React

知识蒸馏相关技术【模型蒸馏、数据蒸馏】以ERNIE-Tiny为例

汀丶人工智能

nlp 知识蒸馏 11月月更

ElasticSearch这些坑记得避开

Java 架构

一大波vue面试题及答案精心整理

bb_xiaxia1998

Vue

数据中台的最后一公里:数据服务

元年技术洞察

数据中台 中台 DaaS

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