[翻译]Behavior-Driven Development (BDD)行为驱动开发(二)
测试驱动开发体现了开发人员对软件产品各部分运作方式的理解,而行为驱动开发则关注于开发人员对软件产品最终表现的行为的预期。
行为驱动开发
TDD更像是一种范式而不是一个过程。它描述了一种先编写测试,然后实现,并伴随可能的代码重构这样的一系列步骤。但其并没有关于以下的内容:
- 应该从哪里开始开发;
- 应该对什么进行测试;
- 测试应该怎样组织和命名。
测试驱动开发这个命名也让人疑惑,人怎么能够对不存在的东西进行测试呢。
Dan North对这些问题进行了研究,建议开发人员更应该考虑关注软件的特征行为而不是编写测试。
如果开发是行为驱动的,开发应该从对用户最重要的部分功能开始。可以看做放下开发者的帽子,而戴上用户的帽子,从用户的角度思考。实际上,分情况下,最难的部分也在此处,很多时候,你无法知道用户最关注的最重要的行为特性。但是,经过实践和多次的迭代,这一过程终将变得透明和有效。
那么接下来应该怎么表现行为了,一个基于Test::Unit的测试可能是这样的:
class UserTest < Test::Unit::TestCase
def test_name_set
user = User.new "Audrey"
assert_equal(user.name, "Audrey")
end
end
代码可以工作,但有一些缺陷:
- 代码中有多处Test,我们需要用具体的需求来替代;
- 语法难懂;
- 无法明白这段代码到底要测试什么内容。
在BDD中,行为应该随处可见,如下面的红色内容:
describe User do
it "lets me assign a name" do
user = User.new "Paul"
user.name.should == "Paul"
end
end
这段测试代码的价值在于:
- 关注点:针对于具体的行为进行测试和编码;
- 文档:通过读以上语句,你的同事可以直接理解行为的内容,甚至不需要读代码;
- 回归:当你之后运行所有的特性时,这就是回归测试。如果出现了问题,你很快就可以看到那个行为出错。
尽管测试语法对软件的功能行为特性做了描述,它需要一些工作来表明用户的意图。Dan North认为,可以通过定义一个模板通过自然语言来描述这些特性:
Story: Returns go to stock
In order to keep track of stock
As a store owner I want to add items back to stock when they're returned Scenario 1: Refunded items should be returned to stock
Given a customer previously bought a black sweater from me
And I currently have three black sweaters left in stock
When he returns the sweater for a refund
Then I should have four black sweaters in stock Scenario 2: Replaced items should be returned to stock
Given that a customer buys a blue garment
And I have two blue garments in stock
And three black garments in stock.
When he returns the garment for a replacement in black,
Then I should have three blue garments in stock
And two black garments in stock
每一个故事都有一个标题和简短的描述。描述的格式一般包括:
- 为了去实现……
- 对于你正在开发的……
- 我希望功能是这样的……
描述通过还附有一系列包含了给定步骤的场景,包含前置事件,用例行为,后置事件等。
由于BDD一直期望从用户最关注的行为开始,应该坚持以下准则:
- 找出最重要的特性;
- 在此基础上找出最重要的场景。
藉此,你可以一直站在用户需求的角度进行开发,并关注于真正有效的目标。
结论
很多人将BDD看做是“正确的TDD”,因为它包含了一系列以用户为中心的最佳开发实践,改变了以往技术方案为中心的方式,将用户意图当做首位。因此,将有助于创建更好的软件,实现用户的需求。
来源:http://blog.codeship.io/2013/04/22/from-tdd-to-bdd.html
[翻译]Behavior-Driven Development (BDD)行为驱动开发(二)的更多相关文章
- 【翻译稿】Behavior Driven Development (BDD)行为驱动开发
这是一篇翻译稿,方便给不知道BDD的同学扫盲.原文链接:What is BDD (Behavior Driven Development)? | Agile Alliance Definition定义 ...
- [翻译]Behavior-Driven Development (BDD)行为驱动开发(一)
简单而言,BDD是一系列基于TDD的工具和方法集发展而来的开发模式,一般不认为是一种新的开发模式,而是作为TDD的补充.因此,首先对TDD的概念进行进行. 测试驱动开发(TDD) TDD模式采取的是迭 ...
- Spring注解驱动开发(二)-----生命周期、属性赋值
bean的生命周期 bean的生命周期:bean创建---初始化----销毁的过程容器管理bean的生命周期:我们可以自定义初始化和销毁方法:容器在bean进行到当前生命周期的时候来调用我们自定义的初 ...
- 行为驱动开发iOS <收藏>
前段时间在design+code购买了一个学习iOS设计和编码在线课程,使用Sketch设计App,然后使用Swift语言实现Designer News客户端.作者Meng To已经开源到Github ...
- .NET里的行为驱动开发
BDD (Given - When - then) Ruby Cucumber, Java FitNesse , Python RoboFramework, C# specflow nspec .NE ...
- Linux 下wifi 驱动开发(三)—— SDIO接口WiFi驱动浅析
SDIO-Wifi模块是基于SDIO接口的符合wifi无线网络标准的嵌入式模块,内置无线网络协议IEEE802.11协议栈以及TCP/IP协议栈.可以实现用户主平台数据通过SDIO口到无线网络之间的转 ...
- 行为驱动开发BDD和Cucunber简介
测试驱动开发(TDD) 1.测试驱动开发,即Test-Driven Development(TDD),测试驱动开发是敏捷开发中的一项核心实践和技术,也是一种设计方法论.TDD的原理是在开发功能代码之前 ...
- 行为驱动开发BDD概要
BDD脱胎于TDD 行为驱动开发(Behavior-Driven Development,简称BDD),是在测试驱动开发(Test-Driven Development,TDD)基础上发展而来的一种软 ...
- Bug驱动开发(Bug-driven development)
说实话,作为一个Domino开发者,像測试驱动开发(Test-driven development).功能驱动开发(Feature-driven development)之类软件开发的高大上的方法论( ...
随机推荐
- URAL1118. Nontrivial Numbers
1118 优化 1.枚举到sqrt(n)2.区间有质数直接输出最大质数3.a=1 直接输出1 4.边+边与最小值比较 #include <iostream> #include<cst ...
- JSON 之 SuperObject(10): Merge、Clone、ForcePath
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...
- Android开发之PopupWindow
/* * Android开发之PopupWindow * * Created on: 2011-8-8 * Author: blueeagle * Email: liujiaxiang@g ...
- innodb锁之间的兼容性判断
检查锁与锁之间的兼容性 路径:/mysql-5.5.43/storage/innobase/lock/lock0lock.c 实现:见锁的强度比较 row 可理解为 lock 的锁模式 colum ...
- Linux删除文件后空间没有释放
.COMMAND默认以9个字符长度显示的命令名称.可使用+c参数指定显示的宽度,若+c后跟的参数为零,则显示命令的全名.PID:进程的ID号.PPID父进程的IP号,默认不显示,当使用-R参数可打开. ...
- 在VMware 虚拟机中配置 windows2003系统的NLB负载均衡;0x800706D5错误的解决方法;没有接口可用于安装新的群集
首先在VM里面 我装了3个2003的系统, 分别为 webservice01 ,webservice 02 , 以及 webview 这3台. 前面两台用于配置负载均衡,后面的webview就是 ...
- 旧书重温:0day2【3】 详细解读PEB法 查找kener32地址
题外话:上一篇文章中的 PEB法查找kerner32地址的方法 对TEB.PEB .PE结构 知识要求很高,确实在写汇编代码时候小编 感觉自己能力,信手啪啪一顿乱撸,结果一运行,非法访问了,没办法翻阅 ...
- Java 动态太极图 DynamicTaiChi (整理)
package demo; import java.awt.Color; import java.awt.Graphics; import javax.swing.JFrame; import jav ...
- Android源码分析--CircleImageView 源码详解
源码地址为 https://github.com/hdodenhof/CircleImageView 实际上就是一个圆形的imageview 的自定义控件.代码写的很优雅,实现效果也很好, 特此分析. ...
- 【转】使用ngrok快速地将本地Web服务映射到外网
为什么要使用ngrok? 作为一个Web开发者,我们有时候会需要临时地将一个本地的Web网站部署到外网,以供它人体验评价或协助调试等等,通常我们会这么做: 找到一台运行于外网的Web服务器 服务器上有 ...