TDD 学习笔记

什么是TDD

TDD --Test-Driven Development(测试驱动开发)

  • 是什么
    一种不同于传统软件开发的新型方法,通过在编写功能代码之前先编写测试代码,然后只编写测试通过的功能代码,通过测试来推动开发的进行。有助于编写简洁可用高质量的的代码,并加速开发过程。

  • 出自于极限编程十三个核心方法中的个人开发实践

屏幕快照 2017-08-14 下午8.02.11.png
  • TDD实现内容
    1.分解任务,分离关注点
    2.用实例化求解,澄清需求细节
    3.写测试,只关注需求,程序的输入输出,不关心中间过程
    4.写实现,不考虑别的需求,只用最简单的方法实现当前的需求
    5.重构,用手法消除代码里的坏味道
    6.写完手动测试,补充用例
    7.转测试,小问题,补用例
    8.代码整洁,信心满满得提交
为什么要用TDD

TDD 需要写大量超过功能代码的测试代码,会不会造成代码的极大浪费呢

好处:
1.效率:

  • 提前确认需求,减少开发过程的终端等待
  • 小步快走,节省调试时间(每写完一段代码,就可以很快的测试代码的正确性)

2.质量

  • 高测试覆盖率:功能分支基本都被覆盖到
  • 自动测试回归:保证原有功能未被破坏的同时快速添加新的功能
如何做TDD
  • 做设计
    tasking图---->小步快走实现
红绿-重构.png
步骤:

1.快速新增一个测试
2.运行所有的测试
3.对实现代码作出一些改动,让测试程序运行,适当的时候可以使用不合情理的方法
4.运行所有的测试,并且全部通过
5.重构代码,消除代码中不合情理的部分

  • 不做设计
    演进式的,先通过实现最基本的需求,通过将其他需求一个个向上添加的方式实现最后的工能。
如何学习TDD
  1. tasking 搞清楚程序的输入输出,以及大概实现的设想
    有效的单元测试
  2. obvious implement
    fake--先实现一个简单的测试,类似于测试分解
    triangle--不知道怎么实现,先用fake,再增加用例实现,前后对比实现最后的要求
  3. Clean Code--代码整洁之道
    Smell
    手法
TDD学习方法.png
TDD问题 FAQ
  • 明明知道测试会失败,为什么还要运行?
    A:防止出现低级错误
  • 小步快走很好,但是真的要小步到这种程度吗?
    A:练习程序,使用小步方式。实际开发过程采用大步,遇到问题转换为小步
  • 测试覆盖率需要多少合适?
    A:刚开始学习的时候追求100%覆盖率,从而学会写测试
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,314评论 25 709
  • Test-Driven Development By Example TDD 所追求的目标:代码整洁可用(clea...
    贾尼阅读 1,464评论 0 2
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    Mr希灵阅读 22,063评论 7 278
  • 消化内镜检查前的胃肠道准备 作者 中山大学附属第六医院肛肠外科 彭慧 微信号drpenghui 胃肠镜检查是消化道...
    drpenghui阅读 1,875评论 0 0
  • 题目借用水木丁老师的书名。 昨天就范雨素走红网络,谈了一点自己的想法。 今天看到几个意见领袖的观点后,不由地想再谈...
    金泽香阅读 180评论 0 0