写点什么

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

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

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

关注

评论

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

Python生成成绩报告单:从理论到实践

不在线第一只蜗牛

Python

mac项目流程管理工具OmniPlan Pro 4中文版

小玖_苹果Mac软件

TikTok小店带货直播为什么要选TikTok直播专线

Ogcloud

海外直播专线 直播专线 tiktok直播专线 tiktok直播网络 tiktok直播带货

被低估的数据即服务(DaaS):下一代数据管理的突破口

tapdata

数据管理 实时数据 DaaS 数据即服务 什么是DaaS

崖州湾之旅:看见海与智能,联想到了未来

脑极体

AI

利用商业智能增强业财融合,提高企业盈利能力

智达方通

商业智能 业财融合 盈利能力

开放下载|Aloudata《主动元数据,DataOps 建设新支点》白皮书出炉

Aloudata

元数据 DataOps 数据血缘

好用的文件对比工具Beyond Compare 5 for Mac

小玖_苹果Mac软件

(犀牛8)三维建模软件Rhinoceros 8 for Mac中文激活版

小玖_苹果Mac软件

好用的代码编辑器Visual Studio Code mac中文版

小玖_苹果Mac软件

Cisco ACI Simulator 6.1(1f)F - ACI 模拟器

sysin

ACI

Set A Light 3D Studio Mac 三维模拟影棚布光软件

小玖_苹果Mac软件

专业PDF编辑软件Acrobat Pro DC 2023 mac中文版

小玖_苹果Mac软件

专业矢量绘图设计软件 Sketch for mac中文版

小玖_苹果Mac软件

全新升级!Sermant 2.2.0 Release版本正式发布

华为云开源

开源 微服务治理

代码编辑器sublime text mac中文注册版

小玖_苹果Mac软件

东南亚SD-WAN海外网络专线有哪些作用?

Ogcloud

国际网络专线 海外网络专线 跨国网络专线 东南亚网络专线

IoTDB 常见问题 Q&A 第四期

Apache IoTDB

AI商品计划管理系统:时尚品牌数字化转型的秘密武器

第七在线

BetterTouchTool For Mac 鼠标触控板增强软件

小玖_苹果Mac软件

Keka for mac 好用mac压缩解压软件

小玖_苹果Mac软件

利用唯品会商品数据API接口实现高效商品详情关键词搜索

代码忍者

唯品会API接口

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