`
gigix
  • 浏览: 351721 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

测试如何驱动开发

阅读更多
需求:反转一个句子
我可能会写出以下的测试——写一个测试,然后写代码让测试通过,然后再写下一个测试。
自己看吧。
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和其分开标注。

是不是说,用来驱动实现的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和其分开标注。

是不是说,用来驱动实现的test case,包含了设计过程,关注实现细节,但用来描述需求的test case,是不包括设计过程的,不关注实现细节,这两种test case,要明确区分?
13 楼 ozzzzzz 2007-09-19  
其实这里又有一个问题。
那就是如果是采取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的测试则是把所有可能出现的情况都测试到了。

测试当然是越详细越好,但是代价就是代码量也迅速增多,而且更重要的是写测试的时间长了,必须精心构造测试数据和条件,我觉得会把我的注意力从实现程序功能上转到如何让测试更完备上来。

所以我是觉得在开发阶段还是不要太花时间在测试的完整度上,只保证基本功能的测到了就好。

用gigix的直到有问题,再加测试。
PS:程序员写的东西不能代替测试员的存在。
2 楼 无明 2007-09-19  
有意思,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")

相关推荐

    测试驱动开发及开发实践.pdf

    ### 测试驱动开发及开发实践 #### 极限编程与测试驱动开发 极限编程(Extreme Programming,简称XP)是一种适用于小型至中型团队在面对需求不确定或者快速变化时进行软件开发的方法学。作为一种轻量级的开发方法,...

    测试驱动开发.pdf测试驱动开发.pdf

    测试驱动开发(Test-Driven Development,简称TDD)是一种敏捷软件开发的技术,以测试作为开发过程的中心环节。它倡导在编写产品代码之前先编写测试代码,确保产品代码能够通过这些测试。这种方法与传统的开发方式...

    测试驱动开发的艺术 epub电子书

    极限编程反其道而行之,主张采用测试驱动开发(TDD)的方法,即通过测试定义所要开发的功能的接口,然后实现功能的开发过程。TDD通过不断地测试推动代码的开发,既简化了代码,又保证了软件质量。本书采用“手把手”...

    C#测试驱动开发

    要使测试驱动开发在软件行业中得以繁荣兴盛,需要一些条件,《C#测试驱动开发》从讨论这些条件开始。软件开发发展到今天,有其历史和特定的条件,理解这些很重要。避免重复过去的错误也很重要。在自己当前的开发实践...

    测试驱动开发.pdf

    测试驱动开发(TDD)以测试作为开发过程的中心,它要求在编写任何产晶代码之前, 首先编写用于定义产品代码行为的测试,而编写的产品代码又要以使测试通过为目标。测试驱 动开发要求测试可以完全自动化地运行,在对...

    java测试驱动开发教程+代码实例

    《Java测试驱动开发》介绍如何将各种TDDzui佳实践应用于Java开发,主要内容包括:用Java语言进行TDD会用到的各种工具和框架,所需环境搭建;通过实际应用程序,展示TDD优点及开发中应注意的主要问题;TDD是如何通过...

    测试驱动开发Kent Beck

    《测试驱动开发》是Kent Beck的经典著作,这本书深入探讨了测试驱动开发(TDD)这一软件开发实践。TDD是一种编程方法论,它强调在编写实际功能代码之前,先编写测试用例,以此来指导软件设计和编码过程。通过这种...

    测试驱动开发-实例1

    ### 测试驱动开发(TDD)概述 测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法论,它要求在编写实际功能代码之前先编写测试用例。这种方法有助于确保代码的质量,并使得代码更加健壮、易于维护...

    TDD 测试驱动开发 文档 详细

    测试驱动开发(Test-Driven Development, 简称TDD)是一种软件开发实践,强调在编写实际代码之前先编写测试用例。这种方法的核心理念是通过编写能够失败的测试来定义需求,然后编写足够的代码使测试通过,最后重构...

    测试驱动开发(TDD)入门讲解及代码实例

    测试驱动开发(TDD)是极限编程的重要特点,它以不断的测试推动代码的开发,既简化了代码,又保证了软件质量。本文从开发人员使用的角度,介绍了 TDD 优势、原理、过程、原则、测试技术、Tips 等方面。 背景 一个...

    C现代编程 集成开发环境、设计模式、极限编程、测试驱动开发、重构、持续集成(带详细书签).pdf

    花井志生*的《C现代编程(集成开发环境设计模 式*限编程测试驱动开发重构持续集成)》从使用C语 言进行嵌入式开发的特点入手,主要讲解了如何将集 成开发环境、设计模式、*限编程、测试驱动开发、 重构、持续集成这些...

    测试驱动开发-中文英文.zip

    测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,由Kent Beck在其著作《测试驱动开发:通过实例》中提出并详尽阐述。这种方法主张先编写自动化测试用例,然后再编写满足这些测试的代码,从而...

    测试驱动开发_中文

    测试驱动开发(Test-Driven Development,简称TDD)是一种软件开发方法,由Kent Beck在其同名著作《测试驱动开发》中提出。这种方法主张先编写测试用例,再编写实现功能的代码,以此来驱动开发过程,确保代码的质量...

    测试驱动开发TDD培训讲义

    测试驱动开发(Test Driven Development,简称TDD)是一种软件开发方法,强调在编写实际的生产代码之前,先编写能够失败的单元测试。TDD的核心理念是“先测试,后编码”,通过测试来驱动设计,确保软件的质量和可...

    TDD测试驱动开发.pptx

    "TDD测试驱动开发.pptx" TDD 测试驱动开发是一种软件开发方法,它强调通过编写自动化测试来驱动整个开发过程。TDD 是敏捷开发中的一个核心实践和技术,也是一种设计方法论。其主要包括两方面:测试先行和代码重构。...

    python测试驱动开发

    ### Python测试驱动开发 #### 知识点概览 1. **测试驱动开发(TDD)的概念** - 定义与原则 - TDD在软件开发生命周期中的作用 - 实施TDD的好处与挑战 2. **Python与测试驱动开发** - Python作为TDD的理想语言 -...

Global site tag (gtag.js) - Google Analytics