TDD——测试驱动开发

文章目录

概要

TDD 是 测试驱动开发 (Test-Driven Development) 的缩写。它不像传统开发那样"先写代码,再补测试",而是完全反过来的------先写测试,再写代码。

诀窍------红、绿、重构

  • 红阶段:明确定义期望的行为
    • 在写任何功能代码前,先为你想添加的新功能写一个测试用例
    • 这时由于功能还没实现,测试一定会失败。在IDE里,失败通常显示为红色
    • 这一步的关键是从"使用者"的角度去定义什么是完成
  • 绿阶段:编写最简单的实现代码
    • 写刚好足够让测试由红转绿的代码
    • 不需要考虑代码是否优雅,是否有重复,甚至可以用很直接的方式
    • 原则:最重要的是让测试变绿
  • 重构阶段:优化代码结构与设计
    • 现在测试已经通过(有安全网了),可以大胆地优化代码结构:消除重复、改善命名、拆分长函数等。
    • 关键:重构过程中测试必须使用保持绿色,一旦变红,就说明改错了,需要立即撤销

三者以红阶段------>绿阶段------>重构阶段------>红阶段的方式循环往复

实战方式

单元测试位于金字塔底部,是最基础也最丰富的测试层。它们运行速度快、隔离性好、问题定位精确、维护成本相对较低。TDD通常被呈现为一种以单元测试为核心的方法论。

AI时代下:如果prd是确定的话(一般是需要反复修改的),用TDD的方式去进行开发,开发出的软件效果实际上是十分优异的,这得益于AI自身能够迅速生成测试用例。

另外,不是所有的代码都适合使用TDD的,如果说一个需求中包含大量的分支时,这个时候使用TDD就可以了,如果仅仅只是一个方法调用,TDD的作用就没那么大了。

小结

TDD的方式在非AI时代一定不是一个很好的开发方式,因为你提前写测试,再进行开发,所需要花费的时间一定是十分长的。因此,大部分程序员还是使用先写代码,再做测试的方式。

但是AI时代,可以一次性用AI把测试用例写出来,再通过红------>绿------>重构的方式,这样的方式可以让AI生成的代码更加的健壮,避免后期的返工。

但是实际的大型企业级项目中,prd是会不断迭代变化的,可能你白天写出来的代码,到了下午就发生了变化,这个时候前期写的大量的测试用例将会作废,反而会浪费大量的token。

相关推荐
暮云星影5 小时前
全志开发环境搭建及编译构建
linux·arm开发·驱动开发
编程圈子7 小时前
电机驱动开发学习3. 驱动原理与相关电路
驱动开发·学习
编程圈子1 天前
电机驱动开发学习2. 直流无刷电机工作原理
驱动开发·学习
智者知已应修善业1 天前
【用74LS151的实现(16序列信号发生器)】2024-6-1
驱动开发·经验分享·笔记·硬件架构·硬件工程
道一云黑板报1 天前
告别提示词工程:为什么“循环工程”才是 AI 编程的未来?
人工智能·驱动开发·软件工程·ai编程
天南散修2 天前
MT7916 BA流程
网络·驱动开发·wifi·802.11
Soari2 天前
EtherCAT Master Stack —— 面向工业实时控制的开源 EtherCAT 主站协议栈
驱动开发
天南散修2 天前
MT7916驱动中802.11转换为802.3
linux·网络·驱动开发·wifi·802.11
A.说学逗唱的Coke3 天前
【AI·Coding】TDD × SDD × AI Coding:从“测试驱动“到“规范驱动“的智能协作实践
人工智能·驱动开发·tdd