测试驱动开发(TDD)全解析
1. 测试驱动开发的优势
测试驱动开发(TDD)是一种软件开发方法,先编写测试套件和文档,再编写代码。这种方式除了能持续对代码进行测试外,还能极大提升软件设计的质量。通过先测试,代码的模块化会迅速成型,因为是为一小段与其他代码(无论现有还是待写)无明显关联的代码编写测试。
编写测试用例也是定义代码“黑盒”特性的过程。要正确编写单元测试,必须做到以下几点:
- 定义输入和预期输出 :测试用例成为通过示例的规范,虽不是完整规范,但能有效传达对代码意图的理解。
- 测试代码的副作用 :测试代码可能产生的副作用,以及可能导致代码抛出异常或出现异常行为的情况、输入或外部资源。
- 定义外部资源 :在实际编写代码之前,定义被测试代码所需的外部资源。
确定输入、输出和外部资源,以及定义代码的行为,能在不写一行代码的情况下有效设置代码的接口、需求和契约。TDD 以接口为中心,关注类的外观和功能,而非实现方式。在编写代码时,类或方法的大部分框架已经定义好,只需填补空白直到测试通过。
2. 缩小需求范围
仅列出项目需求是不够的,大多数需求文档既未列出客户期望的所有需求,也未详细到能以最高效方式开发和设计应用程序的程度。在使用 TDD 时,为当前编写的代码获取最详细的需求尤为重要,因为要进行自上而下的开发,就需要充分理解要创建的内容。
缩小需求范围就是不断提问,确保要编写的代码范围与客户、项目经理或分析师确定的最小需求完全匹配。由于先编写测试,这项任务比后编写测试更容
超级会员免费看
订阅专栏 解锁全文
1568

被折叠的 条评论
为什么被折叠?



