- 浏览: 355275 次
- 性别:
- 来自: 北京
-
最新评论
-
wind35:
楼主分析的挺好,我自己也通常会给自己的懒惰一个冠冕堂皇的理由
天道酬勤? -
zx848:
乔布斯....
答复: 面试遇到 “怪题”你如何应付? -
ggsjy:
同意二楼,本篇貌似理性,却隐约看出楼主对底层生活的疏远,不拿软 ...
Re: 父母逼着我买房子,怎么办? -
adamed:
高考与前身科举类似正面意义是给了广大底层人民‘可能’走上来的途 ...
应试教育的精髓所在 -
zjf_1103:
楼主说的是实在话
天道酬勤?
需求:反转一个句子
我可能会写出以下的测试——写一个测试,然后写代码让测试通过,然后再写下一个测试。
自己看吧。
这样理解也说得过去,kent beck可不是这么说得。
test-driven development书中例子里还是强调了测试的complete。
gigix的需求应该细化,对空句子,最长多长的句子,要达到的性能指标。
是不是说,用来驱动实现的test case,包含了设计过程,关注实现细节,但用来描述需求的test case,是不包括设计过程的,不关注实现细节,这两种test case,要明确区分?
其实可以这样说,你看一段代码肯定首先想知道他是做啥的。这个时候你会发现,阅读有些test case只能让你云里雾里,而阅读有些则让你马上就知道这段代码的用途。其实找并不是这些test case写的有水平差别,而往往是有针对问题角度的差别。而进一步,你会发现阅读这些test case如果按照一定顺序,就会从最初的动机到最终的实现细节都有一个清晰的理解,而如果我们能够在写这些test case的时候就标注出这个理解顺序,将是十分核算的。而实际上很多时候我们书写的顺序就是最终我们适于阅读理解的顺序。
是不是说,用来驱动实现的test case,包含了设计过程,关注实现细节,但用来描述需求的test case,是不包括设计过程的,不关注实现细节,这两种test case,要明确区分?
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
如果从需求驱动的角度,没必要写testShouldSplitSentenceIntoWords这个测试,因为不同的实现方法,也许就不需要先把句子切分成单词。
所以我们说“TDD”。测试驱动开发,开发中的每“一步”都有测试来驱动。至于测试写到什么粒度,取决于你认为怎样的“一步”对于你来说是合适的。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
如果从需求驱动的角度,没必要写testShouldSplitSentenceIntoWords这个测试,因为不同的实现方法,也许就不需要先把句子切分成单词。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
这个测试就是所谓的“设计过程”
实际上照我真实的想法,我是不想写这个测试的,因为这个需求实在太简单了
不过为了说明这里确实有“设计”的存在……
我把一个大的问题分解成两个小的问题,先用测试驱动解决第一个,再用测试驱动解决第二个
就是这样
其实这里就引出一个问题,也就是TDD也有粒度问题,并且很多时候这个粒度问题并不比需求中粒度问题简单,需要我们小心控制。虽说XP要求我们小步快跑,但是这个小步也是有粒度要求的。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
这个测试就是所谓的“设计过程”
实际上照我真实的想法,我是不想写这个测试的,因为这个需求实在太简单了
不过为了说明这里确实有“设计”的存在……
我把一个大的问题分解成两个小的问题,先用测试驱动解决第一个,再用测试驱动解决第二个
就是这样
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
上边一共三句话,前两句是赞同的。 其实测试驱动还是需求驱动,story-->test-->code, 而我们说的普通的test是这样形成的,story-->design-->code--->test。
第三句不赞成,gigix的做法不是tdd,taowen的才是tdd,第三句的做法是“友情驱动”
非也,第三句才是我说的重点。
实际上这里确实存在一些模糊的问题。比如如果这个字符串为空如何,为单一词汇又如何,又如果是为一个超过1k长度的字符串如何,超过1m又如何,。。。。。。。
实际上这里的问题你说完全是基于功能的还是基于程序结构的呢?
不过一般情况下客户会给你个比较清楚的解释,不过也有模糊的地方。比如客户说我干嘛要输入一个空字符呢,于是你可以认为这个其实是一种客户误操作的结果,大概应该算在测试范畴。而如果是单一词汇,客户可能会说,这个我有时候也可能会做,或者是我随手按了回车,这个时候这大概算是功能范畴的了。而显然客户对边界的问题并不敏感,这个时候则基本属于测试范畴。
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
上边一共三句话,前两句是赞同的。 其实测试驱动还是需求驱动,story-->test-->code, 而我们说的普通的test是这样形成的,story-->design-->code--->test。
第三句不赞成,gigix的做法不是tdd,taowen的才是tdd,第三句的做法是“友情驱动”
还是o6z这话说的透啊,我还真费了不少时间才意识到这点,开始的时候总是想把单元测试写完整些,生怕遗漏了些甚么
用gigix的直到有问题,再加测试。
PS:程序员写的东西不能代替测试员的存在。
我可能会写出以下的测试——写一个测试,然后写代码让测试通过,然后再写下一个测试。
自己看吧。
public class StringReverseTest { # Test 1 public void testShouldSplitSentenceIntoWords(){ StringReverser sr=new StringReverser(); String str = "This is a sentence"; Assert.assertEquals(4, sr.split(str).size()); Assert.assertEquals("sentence", sr.split(str).get(0)); Assert.assertEquals("a", sr.split(str).get(1)); Assert.assertEquals("is", sr.split(str).get(2)); Assert.assertEquals("This", sr.split(str).get(3)); } # Test 2 public void testShouldReverseSentence(){ StringReverser sr=new StringReverser(); String str = "Tdd is a software devolopment technology"; Assert.assertEquals("technology devolopment software a is Tdd",sr.reverse(str)); } # Test 3 public void testShouldAlwaysReverseSentences(){ StringReverser sr=new StringReverser(); String str = "This is Yet Another sentence"; Assert.assertEquals("sentence Another Yet is This",sr.reverse(str)); } }
评论
17 楼
Godlikeme
2007-09-20
ozzzzzz 写道
测试是测试,测试驱动是测试驱动,别把两个东西搞混了。说白了测试驱动还是需求驱动,而测试则需要考虑更多的东西。gigix的做法在tdd看来很棒,但是在测试角度看则很不完整。
这样理解也说得过去,kent beck可不是这么说得。
test-driven development书中例子里还是强调了测试的complete。
gigix的需求应该细化,对空句子,最长多长的句子,要达到的性能指标。
16 楼
hlxiong
2007-09-20
我不太明白的是,Test2和Test3有什么不同?是不是它们的实现代码不同?
15 楼
ozzzzzz
2007-09-19
balaschen 写道
ozzzzzz 写道
其实这里又有一个问题。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
是不是说,用来驱动实现的test case,包含了设计过程,关注实现细节,但用来描述需求的test case,是不包括设计过程的,不关注实现细节,这两种test case,要明确区分?
其实可以这样说,你看一段代码肯定首先想知道他是做啥的。这个时候你会发现,阅读有些test case只能让你云里雾里,而阅读有些则让你马上就知道这段代码的用途。其实找并不是这些test case写的有水平差别,而往往是有针对问题角度的差别。而进一步,你会发现阅读这些test case如果按照一定顺序,就会从最初的动机到最终的实现细节都有一个清晰的理解,而如果我们能够在写这些test case的时候就标注出这个理解顺序,将是十分核算的。而实际上很多时候我们书写的顺序就是最终我们适于阅读理解的顺序。
14 楼
balaschen
2007-09-19
ozzzzzz 写道
其实这里又有一个问题。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
是不是说,用来驱动实现的test case,包含了设计过程,关注实现细节,但用来描述需求的test case,是不包括设计过程的,不关注实现细节,这两种test case,要明确区分?
13 楼
ozzzzzz
2007-09-19
其实这里又有一个问题。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
那就是如果是采取TDD的方式来说明问题,那么如果把test case作为一种说明需求的工具,那么我们就需要将真正的用于测试的test case和其分开标注。
12 楼
gigix
2007-09-19
balaschen 写道
hostler 写道
ozzzzzz 写道
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
如果从需求驱动的角度,没必要写testShouldSplitSentenceIntoWords这个测试,因为不同的实现方法,也许就不需要先把句子切分成单词。
所以我们说“TDD”。测试驱动开发,开发中的每“一步”都有测试来驱动。至于测试写到什么粒度,取决于你认为怎样的“一步”对于你来说是合适的。
11 楼
balaschen
2007-09-19
hostler 写道
ozzzzzz 写道
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
如果从需求驱动的角度,没必要写testShouldSplitSentenceIntoWords这个测试,因为不同的实现方法,也许就不需要先把句子切分成单词。
10 楼
ozzzzzz
2007-09-19
gigix 写道
hostler 写道
ozzzzzz 写道
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
这个测试就是所谓的“设计过程”
实际上照我真实的想法,我是不想写这个测试的,因为这个需求实在太简单了
不过为了说明这里确实有“设计”的存在……
我把一个大的问题分解成两个小的问题,先用测试驱动解决第一个,再用测试驱动解决第二个
就是这样
其实这里就引出一个问题,也就是TDD也有粒度问题,并且很多时候这个粒度问题并不比需求中粒度问题简单,需要我们小心控制。虽说XP要求我们小步快跑,但是这个小步也是有粒度要求的。
9 楼
gigix
2007-09-19
hostler 写道
ozzzzzz 写道
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
这个测试就是所谓的“设计过程”
实际上照我真实的想法,我是不想写这个测试的,因为这个需求实在太简单了
不过为了说明这里确实有“设计”的存在……
我把一个大的问题分解成两个小的问题,先用测试驱动解决第一个,再用测试驱动解决第二个
就是这样
8 楼
hostler
2007-09-19
ozzzzzz 写道
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
那ozzzzzz怎么看gigix 关于testShouldSplitSentenceIntoWords这个测试?
7 楼
ozzzzzz
2007-09-19
hostler 写道
ozzzzzz 写道
测试是测试,测试驱动是测试驱动,别把两个东西搞混了。说白了测试驱动还是需求驱动,而测试则需要考虑更多的东西。gigix的做法在tdd看来很棒,但是在测试角度看则很不完整。
上边一共三句话,前两句是赞同的。 其实测试驱动还是需求驱动,story-->test-->code, 而我们说的普通的test是这样形成的,story-->design-->code--->test。
第三句不赞成,gigix的做法不是tdd,taowen的才是tdd,第三句的做法是“友情驱动”

非也,第三句才是我说的重点。
实际上这里确实存在一些模糊的问题。比如如果这个字符串为空如何,为单一词汇又如何,又如果是为一个超过1k长度的字符串如何,超过1m又如何,。。。。。。。
实际上这里的问题你说完全是基于功能的还是基于程序结构的呢?
不过一般情况下客户会给你个比较清楚的解释,不过也有模糊的地方。比如客户说我干嘛要输入一个空字符呢,于是你可以认为这个其实是一种客户误操作的结果,大概应该算在测试范畴。而如果是单一词汇,客户可能会说,这个我有时候也可能会做,或者是我随手按了回车,这个时候这大概算是功能范畴的了。而显然客户对边界的问题并不敏感,这个时候则基本属于测试范畴。
TDD的做法并不是要你在最早就准备好一个完整的测试系统,而是要你通过写准对需求的测试,也就是针对功能的测试,来因对性的完成你的代码。这是一个由需求,转换为针对测试,在因对的代码的过程。
6 楼
hostler
2007-09-19
ozzzzzz 写道
测试是测试,测试驱动是测试驱动,别把两个东西搞混了。说白了测试驱动还是需求驱动,而测试则需要考虑更多的东西。gigix的做法在tdd看来很棒,但是在测试角度看则很不完整。
上边一共三句话,前两句是赞同的。 其实测试驱动还是需求驱动,story-->test-->code, 而我们说的普通的test是这样形成的,story-->design-->code--->test。
第三句不赞成,gigix的做法不是tdd,taowen的才是tdd,第三句的做法是“友情驱动”

5 楼
无明
2007-09-19
ozzzzzz 写道
说白了测试驱动还是需求驱动,而测试则需要考虑更多的东西
还是o6z这话说的透啊,我还真费了不少时间才意识到这点,开始的时候总是想把单元测试写完整些,生怕遗漏了些甚么
4 楼
ozzzzzz
2007-09-19
测试是测试,测试驱动是测试驱动,别把两个东西搞混了。说白了测试驱动还是需求驱动,而测试则需要考虑更多的东西。gigix的做法在tdd看来很棒,但是在测试角度看则很不完整。
3 楼
抛出异常的爱
2007-09-19
无明 写道
有意思,gigix和taowen的帖子正好显示了测试完整度的问题。一个测试要写到甚么程度才足够?
TDD的好处就不用说了,我感到最难把握的就是测试完整度。像gigix的测试就是只覆盖到自己要实现的功能就好——只测常见情况。而taowen的测试则是把所有可能出现的情况都测试到了。
测试当然是越详细越好,但是代价就是代码量也迅速增多,而且更重要的是写测试的时间长了,必须精心构造测试数据和条件,我觉得会把我的注意力从实现程序功能上转到如何让测试更完备上来。
所以我是觉得在开发阶段还是不要太花时间在测试的完整度上,只保证基本功能的测到了就好。
TDD的好处就不用说了,我感到最难把握的就是测试完整度。像gigix的测试就是只覆盖到自己要实现的功能就好——只测常见情况。而taowen的测试则是把所有可能出现的情况都测试到了。
测试当然是越详细越好,但是代价就是代码量也迅速增多,而且更重要的是写测试的时间长了,必须精心构造测试数据和条件,我觉得会把我的注意力从实现程序功能上转到如何让测试更完备上来。
所以我是觉得在开发阶段还是不要太花时间在测试的完整度上,只保证基本功能的测到了就好。
用gigix的直到有问题,再加测试。
PS:程序员写的东西不能代替测试员的存在。
2 楼
无明
2007-09-19
有意思,gigix和taowen的帖子正好显示了测试完整度的问题。一个测试要写到甚么程度才足够?
TDD的好处就不用说了,我感到最难把握的就是测试完整度。像gigix的测试就是只覆盖到自己要实现的功能就好——只测常见情况。而taowen的测试则是把所有可能出现的情况都测试到了。
测试当然是越详细越好,但是代价就是代码量也迅速增多,而且更重要的是写测试的时间长了,必须精心构造测试数据和条件,我觉得会把我的注意力从实现程序功能上转到如何让测试更完备上来。
所以我是觉得在开发阶段还是不要太花时间在测试的完整度上,只保证基本功能的测到了就好。
TDD的好处就不用说了,我感到最难把握的就是测试完整度。像gigix的测试就是只覆盖到自己要实现的功能就好——只测常见情况。而taowen的测试则是把所有可能出现的情况都测试到了。
测试当然是越详细越好,但是代价就是代码量也迅速增多,而且更重要的是写测试的时间长了,必须精心构造测试数据和条件,我觉得会把我的注意力从实现程序功能上转到如何让测试更完备上来。
所以我是觉得在开发阶段还是不要太花时间在测试的完整度上,只保证基本功能的测到了就好。
1 楼
taowen
2007-09-19
reverse(null),
reverse(""),
reverse(" "),
reverse("\t"),
reverse("\r\n"),
reverse("a"),
reverse("a "),
reverse(" a"),
reverse("a b"),
reverse("Tdd is a software development technology")
reverse(""),
reverse(" "),
reverse("\t"),
reverse("\r\n"),
reverse("a"),
reverse("a "),
reverse(" a"),
reverse("a b"),
reverse("Tdd is a software development technology")
发表评论
-
Announcement: Fluorida 0.0.1
2008-03-06 19:59 2300I'm glad to announce ... -
对遗留系统组织重构项目
2008-02-28 10:26 4293http://blog.csdn.net/gigix/arch ... -
Announce Stomperl 0.0.2: Message Queuing And Transaction
2007-12-20 17:34 2433Dear all, I'm glad to announce ... -
Announcement: Stomperl 0.0.1
2007-12-12 18:37 1931Dear all, Stomperl 0.0.1 (the ... -
把Module搞得像Class
2007-11-09 22:59 2565http://www.clickcaster.com/item ... -
[链接]JRuby:集Java和RoR之所长
2007-08-24 09:34 2613http://news.csdn.net/n/20070731 ... -
Re: 如何用unit test测试私有方法
2007-08-12 22:44 2810重点在于,你不应该有任何方法是从一开始设计出来就是privat ... -
Re: 持续集成上铁道——CruiseControl.rb简介
2007-07-12 13:22 2148hideto 写道装了mongrel,也按照daemon/cr ... -
Ruby的报表工具
2007-03-09 08:59 3856aardvark 写道但是,RoR上面没有什么很强的报表,如果 ... -
好书推荐:Everyday Scripting with Ruby
2007-02-06 22:16 6697http://www.pragmaticprogrammer. ... -
两个pair两月工作之后的rake stats
2007-02-02 14:12 11226ThoughtWorks中国的一个Rails项目,两个pair ... -
don't use join table
2006-12-01 21:30 5633有“播放室”和“用户”两个模型。一个播放室可以有多个用户在里面 ... -
Re: rails 1.2 rc1 出来了
2006-11-25 15:22 2106http://weblog.rubyonrails.org/2 ... -
Ruby消息两则
2006-10-24 04:20 4073RubyCLR Creator to Join Microso ... -
Selenium 0.8发布,InfoQ报道并介绍新特性
2006-09-26 18:27 3811InfoQ Press: Catching up with S ... -
Re: 用 Selenium 自动化验收测试
2006-09-19 11:13 1910ajoo 写道我一个同事就说他就从来都用ruby script ... -
Re: 关于RoR无法成为企业应用开发的主流的讨论
2006-09-18 21:09 1946fyol 写道gigix 写道 答案 ... -
Adventure From Java To Ruby——我猜Robbin有类似的感受
2006-09-18 20:06 5277摘录自《From Java to Ruby》,第一章 Bruc ...
相关推荐
测试驱动开发(Test-Driven Development,简称TDD)是一种敏捷软件开发的技术,以测试作为开发过程的中心环节。它倡导在编写产品代码之前先编写测试代码,确保产品代码能够通过这些测试。这种方法与传统的开发方式...
《测试驱动开发》是Kent Beck的经典著作,这本书深入探讨了测试驱动开发(TDD)这一软件开发实践。TDD是一种编程方法论,它强调在编写实际功能代码之前,先编写测试用例,以此来指导软件设计和编码过程。通过这种...
测试驱动开发实践介绍 测试驱动开发(Test-Driven Development,TDD)是一种软件开发过程,它强调在编写实际代码之前先编写自动化测试。这种方法可以帮助开发者编写更好的代码,提高代码质量和可维护性。 在测试...
要使测试驱动开发在软件行业中得以繁荣兴盛,需要一些条件,《C#测试驱动开发》从讨论这些条件开始。软件开发发展到今天,有其历史和特定的条件,理解这些很重要。避免重复过去的错误也很重要。在自己当前的开发实践...
### 测试驱动开发(TDD)概述 测试驱动开发(Test-Driven Development, TDD)是一种现代软件工程实践,它改变了传统的开发流程,强调测试在软件开发中的核心地位。TDD的核心理念是在编写任何功能代码之前先编写测试代码...
### 测试驱动开发(TDD)概述 测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法论,它要求在编写实际功能代码之前先编写测试用例。这种方法有助于确保代码的质量,并使得代码更加健壮、易于维护...
测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,它的核心思想是先编写测试用例,再编写满足这些测试用例的代码。这种方法强调在编码之前,先明确需求并创建能够验证功能是否正确的测试。TDD...
花井志生*的《C现代编程(集成开发环境设计模 式*限编程测试驱动开发重构持续集成)》从使用C语 言进行嵌入式开发的特点入手,主要讲解了如何将集 成开发环境、设计模式、*限编程、测试驱动开发、 重构、持续集成这些...
测试驱动开发(TDD)是极限编程的重要特点,它以不断的测试推动代码的开发,既简化了代码,又保证了软件质量。本文从开发人员使用的角度,介绍了 TDD 优势、原理、过程、原则、测试技术、Tips 等方面。 背景 一个...
测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,由Kent Beck在其著作《测试驱动开发:通过实例》中提出并详尽阐述。这种方法主张先编写自动化测试用例,然后再编写满足这些测试的代码,从而...
测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,由Kent Beck在其同名著作《测试驱动开发》中提出。这种方法主张先编写测试用例,再编写实现功能的代码,以此来驱动开发过程,确保代码的质量...
测试驱动开发(Test Driven Development,简称TDD)是一种软件开发方法,强调在编写实际的生产代码之前,先编写能够失败的单元测试。TDD的核心理念是“先测试,后编码”,通过测试来驱动设计,确保软件的质量和可...
测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,强调在编写实际代码之前,先编写单元测试。这种做法有助于确保代码的质量,减少缺陷,并提高开发效率。以下是一些关于测试驱动开发的关键知识...
### Python测试驱动开发 #### 知识点概览 1. **测试驱动开发(TDD)的概念** - 定义与原则 - TDD在软件开发生命周期中的作用 - 实施TDD的好处与挑战 2. **Python与测试驱动开发** - Python作为TDD的理想语言 -...
《Python测试驱动开发:使用Django、Selenium和JavaScript进行Web编程(第2版)》是一本详尽探讨如何在Web开发中应用测试驱动开发(TDD)技术的专业书籍。这本书不仅涵盖了Python语言的基础,还深入讲解了Django框架...
测试驱动开发(Test-Driven Development, 简称TDD)是一种软件开发实践,强调在编写实际代码之前先编写测试用例。这种方法的核心理念是通过编写能够失败的测试来定义需求,然后编写足够的代码使测试通过,最后重构...
测试驱动开发(TDD)是一种敏捷软件开发技术,它要求开发者在编写功能代码之前先编写测试代码。这种方法提倡先写失败的单元测试,然后编写刚好足够使测试通过的代码,最后通过重构来提高代码的质量。王晓毅所著的...