TDD——测试驱动开发

文章目录

概要

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

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

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

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

实战方式

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

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

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

小结

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

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

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

相关推荐
编程圈子7 小时前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法
智者知已应修善业8 小时前
【 LM358AD方波】2024-12-31
驱动开发·经验分享·笔记·硬件架构·硬件工程
枳实-叶8 小时前
【Linux驱动开发】第23天:spi_driver 的 probe / remove 函数实现规范
linux·驱动开发·c#
枳实-叶9 小时前
【Linux驱动开发】第24天:SPI 数据收发机制
linux·运维·驱动开发
幽络源小助理1 天前
Windows11下的Cheat Engine+驱动源码编译并开启DBVM模式-幽络源技术
驱动开发·ce
枳实-叶1 天前
【Linux驱动开发】第22天:SPI 设备树 + spi_driver
linux·运维·驱动开发
麦哲思科技任甲林1 天前
MASE:一套会自我进化的 AI 软件工程方法论
ai编程·tdd·openspec·superpower·ai软件工程框架
世微 如初18 天前
AP5125大功率LED恒流驱动实战:地摊灯项目从原理图到调试笔记
驱动开发·芯片·led电源驱动·降压恒流ic
ScilogyHunter18 天前
Zephyr串口驱动开发及构建完全指南
驱动开发·uart·zephyr
_Emma_18 天前
【DRM&Graphic】Linux图形与显示框架
linux·驱动开发·图形渲染·显示器