测试驱动开发TDD基础知识


测试驱动开发(TDD)基础知识

1. 测试驱动开发(Test-Driven Development):是敏捷开发中的一项核心实践和技术,也是一种设计方法论。是极限编程的一个重要组成部分,它的基本思想就是在开发功能代码之前,先编写测试代码。

2. TDD的原理:在开发功能代码之前,先编写单元测试用例代码,测试代码确定需要编写什么产品代理。

3. TDD基本思路:通过测试来推动整个开发的进行,但测试驱动开发并不只是单纯的测试工作,而是把 需求分析,设计,质量控制量化的过程。

4. TDD的重要目的:不仅仅是测试软件,测试工作保证代码质量仅仅是其中一部分,而且是在开发过程中帮助客户和程序员出去模棱两可的需求。TDD首先考虑使用需求(对象、功能、过程、接口等),主要是变成测试用例框架对功能的过程和接口进行设计,而测试框架可以持续验证。

5. TDD优缺点:
a.优点:(在任意一个开发点都可以拿出一个可以使用,含少量bug并具有一定功能的产品。)
  『充满吸引力的优点』
①完工时完工。表明我可以很清楚的看到自己的这段工作已经结束了,而传统的方式很难知道什么时候编码工作结束了。
②全面正确的认识代码和利用代码,而传统的方式没有这个机会。
③为利用你成果的人提供Sample,无论它是要利用你的源代码,还是直接重用你提供的组件。
④开发小组间降低了交流成本,提高了相互信赖程度。
⑤避免了过渡设计。
⑥系统可以与详尽的测试集一起发布,从而对程序的将来版本的修改和扩展提供方便。
⑦TDD给了我们自信,让我们今天的问题今天解决,明天的问题明天解决,今天不能解决明天的问题,因为明天的问题还没有出现(没有TestCase),除非有TestCase否则我决不写任何代码;明天也不必担心今天的问题,只要我亮了绿灯。
『不显而易见的优点』
①逃避了设计角色。对于一个敏捷的开发小组,每个人都在做设计。
②大部分时间代码处在高质量状态,100%的时间里成果是可见的。
是由于可以保证编写测试和编写代码的是相同的程序员,降低了理解代码所花费的成本。
③为减少文档和代码之间存在的细微的差别和由这种差别所引入的Bug作出杰出贡献。
④在预先设计和紧急设计之间建立一种平衡点,为你区分哪些设计该事先做、哪些设计该迭代时做提供了一个可靠的判断依据。
『有争议的优点』
①事实上提高了开发效率。每一个正在使用TDD并相信TDD的人都会相信这一点,但观望者则不同,不相信TDD的人甚至坚决反对这一点,这很正常,世界总是这样。
②发现比传统测试方式更多的Bug。
③使IDE的调试功能失去意义,或者应该说,避免了令人头痛的调试和节约了调试的时间。
④总是处在要么编程要么重构的状态下,不会使人抓狂。(两顶帽子)
⑤单元测试非常有趣。
b.缺点:增加代码量。测试代码是系统代码的两倍或更多。

6. 测试驱动开发的效果:以可执行的形式文档化你的需求,迫使你分清职责隔离依赖以驱动你的设计,编织安全网以便将Bug扼杀在摇篮的状态,防止其逃逸。

7. 测试人员在新的特性还没开发完成之前做什么?
除了提前编写测试用例,而需要测试人员一起参加一项重要的活动,就是参与特性验收条件的制定。

8. 测试驱动开发的基本过程a. 快速新增一个测试用例 新的TestCase
b. 编译所有代码,刚刚写的那个测试很可能编译不通过 原始的TODO List
c. 做尽可能少的改动,让编译通过 Interface
d. 运行所有的测试,发现最新的测试不能编译通过 -(Red Bar)
e .做尽可能少的改动,让测试通过 Implementation
f. 运行所有的测试,保证每个都能通过 -(Green Bar)
g. 重构代码,以消除重复设计 Clean Code That Works

9. TDD与AMDD(敏捷模型驱动开发)相比 ·TDD缩短了编程反馈周期,而AMDD缩短了建模反馈周期 ·TDD提供详细规范(测试),而AMDD提供一般规范(数据模型) ·TDD有助易于开发中编写搞质量代码,而AMDD有助于在项目中桶项目负责人和开发人员进行有效地沟通 ·TDD能对你开发的软件有一个具体形态描述,AMDD能让你的团队,包括项目负责人,向着一个共有的目标前进; ·TDD提供了具体的文档的具体反馈,而AMDD对具体文档的允许口头反馈(具体反馈需要程序员在代码中证明,而那样就是非敏捷模型的技术了) ·TDD可同构关注代码的调用和可测试来看你的设计是否整洁,而AMDD提供一个机会让你在写代码之前思考 ·TDD是非可视化的,而AMDD是可视化的 ·两种技术对传统开发人员来说都是新的,搞不好会让他们不爽 ·两种结束都支持螺旋式开发 10.TDD = TFD (Test First Development ) + 重构

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是设计模式一套被反复使用、多数人知晓的、经过分类编目的、代码 设计经验 的总结;使用设计模式是为了 可重用 代码、让代码 更容易 被他人理解、保证代码 可靠性;设计模式使代码编制  真正工程化;设计模式使软件工程的 基石脉络, 如同大厦的结构一样;并不直接用来完成代码的编写,而是 描述 在各种不同情况下,要怎么解决问题的一种方案;能使不稳定依赖于相对稳定、具体依赖于相对抽象,避免引
单一职责原则定义(Single Responsibility Principle,SRP)一个对象应该只包含 单一的职责,并且该职责被完整地封装在一个类中。Every  Object should have  a single responsibility, and that responsibility should be entirely encapsulated by t
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强烈推荐。原文截图*************************************************************************************************************************原文文本************
适配器模式将一个类的接口转换成客户期望的另一个接口,使得原本接口不兼容的类可以相互合作。
策略模式定义了一系列算法族,并封装在类中,它们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,它是针对软件开发中经常遇到的一些设计问题,总结出来的一套通用的解决方案。
模板方法模式在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中,使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。
迭代器模式提供了一种方法,用于遍历集合对象中的元素,而又不暴露其内部的细节。
外观模式又叫门面模式,它提供了一个统一的(高层)接口,用来访问子系统中的一群接口,使得子系统更容易使用。
单例模式(Singleton Design Pattern)保证一个类只能有一个实例,并提供一个全局访问点。
组合模式可以将对象组合成树形结构来表示“整体-部分”的层次结构,使得客户可以用一致的方式处理个别对象和对象组合。
装饰者模式能够更灵活的,动态的给对象添加其它功能,而不需要修改任何现有的底层代码。
观察者模式(Observer Design Pattern)定义了对象之间的一对多依赖,当对象状态改变的时候,所有依赖者都会自动收到通知。
代理模式为对象提供一个代理,来控制对该对象的访问。代理模式在不改变原始类代码的情况下,通过引入代理类来给原始类附加功能。
工厂模式(Factory Design Pattern)可细分为三种,分别是简单工厂,工厂方法和抽象工厂,它们都是为了更好的创建对象。
状态模式允许对象在内部状态改变时,改变它的行为,对象看起来好像改变了它的类。
命令模式将请求封装为对象,能够支持请求的排队执行、记录日志、撤销等功能。
备忘录模式(Memento Pattern)保存一个对象的某个状态,以便在适当的时候恢复对象。备忘录模式属于行为型模式。 基本介绍 **意图:**在不破坏封装性的前提下,捕获一个对象的内部状态,并在该
顾名思义,责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为
享元模式(Flyweight Pattern)(轻量级)(共享元素)主要用于减少创建对象的数量,以减少内存占用和提高性能。这种类型的设计模式属于结构型模式,它提供了减少对象数量从而改善应用所需的对象结