什么是TDD
TDD --Test-Driven Development(测试驱动开发)
是什么
一种不同于传统软件开发的新型方法,通过在编写功能代码之前先编写测试代码,然后只编写测试通过的功能代码,通过测试来推动开发的进行。有助于编写简洁可用高质量的的代码,并加速开发过程。出自于极限编程十三个核心方法中的个人开发实践
- TDD实现内容
1.分解任务,分离关注点
2.用实例化求解,澄清需求细节
3.写测试,只关注需求,程序的输入输出,不关心中间过程
4.写实现,不考虑别的需求,只用最简单的方法实现当前的需求
5.重构,用手法消除代码里的坏味道
6.写完手动测试,补充用例
7.转测试,小问题,补用例
8.代码整洁,信心满满得提交
为什么要用TDD
TDD 需要写大量超过功能代码的测试代码,会不会造成代码的极大浪费呢
好处:
1.效率:
- 提前确认需求,减少开发过程的终端等待
- 小步快走,节省调试时间(每写完一段代码,就可以很快的测试代码的正确性)
2.质量
- 高测试覆盖率:功能分支基本都被覆盖到
- 自动测试回归:保证原有功能未被破坏的同时快速添加新的功能
如何做TDD
- 做设计
tasking图---->小步快走实现
步骤:
1.快速新增一个测试
2.运行所有的测试
3.对实现代码作出一些改动,让测试程序运行,适当的时候可以使用不合情理的方法
4.运行所有的测试,并且全部通过
5.重构代码,消除代码中不合情理的部分
- 不做设计
演进式的,先通过实现最基本的需求,通过将其他需求一个个向上添加的方式实现最后的工能。
如何学习TDD
- tasking 搞清楚程序的输入输出,以及大概实现的设想
有效的单元测试 - obvious implement
fake--先实现一个简单的测试,类似于测试分解
triangle--不知道怎么实现,先用fake,再增加用例实现,前后对比实现最后的要求 - Clean Code--代码整洁之道
Smell
手法
TDD问题 FAQ
- 明明知道测试会失败,为什么还要运行?
A:防止出现低级错误 - 小步快走很好,但是真的要小步到这种程度吗?
A:练习程序,使用小步方式。实际开发过程采用大步,遇到问题转换为小步 - 测试覆盖率需要多少合适?
A:刚开始学习的时候追求100%覆盖率,从而学会写测试