测试驱动开发(TDD)的理论基础

article/2025/10/11 18:35:41

在开始理论介绍之前,先思考一个问题:软件开发中最重要的是什么?

  • 可能有的小伙伴就会说:良好的数据库设计,一个健壮可扩展的架构,规范的编码风格,设计文档等。
  • 没错这些在开发中都很重要,但是其实做这些工作都是为了保证软件的质量,所以说质量才是最重要的。

那么质量存在于软件生命周期中的哪一个阶段呢?
在这里插入图片描述
我们大概可以将软件的开发周期分为这样的四个阶段,当然我们作为开发人员,我们需要在编码阶段保证软件的质量。在我们明确了目标(提供高质量的代码)之后,简单介绍一下TDD。

什么是TDD
  • Test-Driven Development,测试驱动开发。
    • 这是我们最常见的对TDD的理解,以测试用例入手,先写好测试用例,然后再去写实现。
  • Task-Driven Development,任务驱动开发,要对问题进行分析并进行任务分解。
    • 将大任务分解成为小任务,针对不同的小的任务去做TDD。
  • Test-Driven Design,测试驱动设计
    • 让我们的代码更具可测性,方便设计和重构。
为什么使用TDD
  • 成本最低方式提高产品质量,因为不需要借助外部人员参与,只需要开发人员一边写测试用例,一边业务代码来推动项目前进。
  • 快速反馈,因为有丰富的测试用例来覆盖业务代码,一旦业务代码出错,就可以及时发现问题并修正。
  • 提前澄清需求,写测试用例的前提一定是弄懂需求之后才去做。
  • 活文档,每一个测试用例其实都是对应的一种业务场景。
  • 安全网,大量丰富的测试用例能够大面积的覆盖业务代码,尽管在重构的时候也不必担心写错代码。
我知道TDD好,可是我不想TDD

的确,TDD还是比较有难度,而且对成员的要求也比较高,在团队中很难推广起来。因为有一些成员会有下面的想法:

  • 没有写测试用例的习惯。
  • 觉得写测试用例既加大了工作量又浪费时间,因为写测试用例一般都是写业务代码的双倍或者更多的时间。
  • 自己对写测试用例掌握的不是很熟练,比如Mock。
  • 认为这是测试人员做的工作,开发人员只是负责写好业务代码。
TDD流程

在这里插入图片描述
画了个图可以一目了然的看清TDD的流程,其实也可以简单的总结为一下五个步骤:

  • 写一个新的测试用例。
  • 运行下新加的测试用例,看到它失败(因为你还没写功能代码)。
  • 编写业务代码,对开发代码做很小的修改,目的就是让新加的测试通过。
  • 运行所有的测试用例,然后看到所有测试都通过了。
  • 移掉重复的代码,对代码进行重构。
TDD的三条规则
  • 除非为了使一个失败的单元测试通过,否则不允许编写任何业务代码。
  • 在一个单元测试中,只允许写一个刚好导致失败的内容。
  • 只允许编写刚好能够使一个失败的单元测试通过的业务代码。
小技巧

每次在做TDD的时候,首先要分析好业务,心里清楚明白自己做的是什么,然后列一个TODO List,每写完一个就划掉,这样子会提高效率,也不会导致自己忘了做了什么没做什么。

总结

通过半篇文章对TDD(测试驱动开发)有了基本的理解,对TDD的带来的优点有了初步的认识,接下来的工作和学习中,我会转变思想,以“测试先行”的原则来开发稳定高质量的代码。


http://chatgpt.dhexx.cn/article/0gJFmxei.shtml

相关文章

什么时候应该编写单元测试?什么是TDD?

一、传统方法与TDD方法 1、有人认为软件编码完成后编写单元测试(传统方法),流程如下: 缺点:编写完功能代码再写单元测试会导致单元测试“粒度”比较粗。对同样的功能代码,如果采用TDD方案,结果…

前端做自动化测试 —— 用TDD的思想做组件测试

Test-Driven Development(测试驱动开发,以下简述TDD)是一种设计方法论, 原理是在开发功能代码之前, 先编写单元测试用例代码, 通过测试来推动整个开发的进行. 本文详细描述了在创作 react-stillness-component, 组件的过程中, 是如何学习 TDD 的思想来完成功能开发以及测试的 一…

深度解读 - TDD(测试驱动开发)

本文结构: 什么是 TDD为什么要 TDD怎么 TDDFAQ学习路径延伸阅读 什么是 TDD TDD 有广义和狭义之分,常说的是狭义的 TDD,也就是 UTDD(Unit Test Driven Development)。广义的 TDD 是 ATDD(Acceptance Tes…

【TDD】测试驱动开发

欢迎关注微信公众号“Python小灶,和我一起每天学习Python新知识”,还可添加博主Vx:yf03064131,方便一起交流学习。 或者B站搜索 有只小新 原视频地址链接:点击这里 代码地址:点击这里 本文为大致翻译以及…

测试驱动开发(TDD)的学习使用

测试驱动开发TDD 是一种不同于传统软件开发流程的新型开发方式 特点: 先编写测试代码 – 实现主要逻辑 再写功能代码 – 实现细节 通过测试来推动整个开发的进行。 有助于编写简洁可用和高质量的代码,并加速开发过程呢。 比如写一个Person类,…

从 TDD 到测试策略

“ 前端没法 TDD / 前端不容易做 TDD / 前端 TDD 收益不大 ” 这是进公司后无数人给我判的“死刑”。 事实上好像的确如此? 在这个崇尚敏捷的组织里,我们有毕业生的入职前培训,入职后培训,有 TwU,有无数定期不定期的…

使用ddt执行数据驱动测试

所谓数据驱动测试,简单的理解为数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。通过使用数据驱动测试的方法,可以在需要验证多组数据测试场景中,使用外部数据源实现对输入输出与期望值的参数化,避免在测…

先测试再开发?TDD测试驱动开发了解一下?

1、什么是TDD 我第一次接触TDD这个概念&#xff0c;是在<<代码整洁之道>>中&#xff0c;作者鲍勃大叔在书中&#xff0c;写了一些关于测试代码的代码规范&#xff0c;其实就提到了有关TDD三定律: - 定律一&#xff1a; 在编写不能通过的单元测试前&#xff0c;不…

测试驱动开发(TDD)前端篇

当你在写生产代码时&#xff0c;你处在高认知的状态&#xff08;obvious&#xff09;&#xff0c;你的研发流程和你的工程实践&#xff0c;有助于你一步一步的提升你的认知能力&#xff0c;把你的问题进行一个降解&#xff08;分解&#xff09;&#xff0c;只要你做到同样的事情…

TDD 开发测试

测试驱动开发(Test-Driven Development)。是敏捷开发中的一项核心实践和技术。 TDD是在开发功能代码之前&#xff0c;先编写单元测试用例代码&#xff0c;测试代码确定需要编写什么产品代码。 变红 ——> 变绿 ——> 重构 在进行 TDD 案例编写的时候&#xff0c;看一…

TDD测试驱动开发

TDD测试驱动开发 什么是测试驱动开发测试驱动开发该怎么做&#xff1f;需求一&#xff1a;输入一个非元音字符&#xff0c;并预期返回字符本身 (输入"h" 返回“h”)需求二&#xff1a;输入一个元音&#xff08;a,e,i,o,u&#xff09;&#xff0c;返回 mommy (输入&qu…

TDD测试驱动学习

gtest 和 gmock 安装 //如果不知道对应库名字可以执行这个命令查找对应库,如果没找到要去跟新对应的源sudo apt update sudo apt-cache search gtest sudo apt-cache search gmock 测试例子 #include <string> using std::string;// 定义 Soundex 类 class Soundex {pub…

TDD (test driver development)测试驱动开发

##为什么需要测试驱动/或者说需要单元测试 我们工作接触的软件项目&#xff0c;不是学生时代&#xff0c;玩一玩就不管了&#xff0c;工作的项目&#xff0c;需要长期维护&#xff0c;并且随着时间的推移需要增加新的需求&#xff0c;进行修改&#xff0c;优化。此时已经距离你…

tdd(测试驱动开发)的概述

最近的工作的项目&#xff0c;使用了tdd&#xff08;test-driven development测试驱动开发&#xff09;的开发模式。 这两几年大概听说了无数种xxx-dd, ddd, tdd, atdd, bdd, fdd, udd各种名词眼花缭乱&#xff0c;当然很多dd其实也有相互借鉴&#xff08;抄袭&#xff09;的部…

测试驱动开发(TDD)实践与技巧

文章目录 引言Google Mock测试用例结构断言经典式断言Hamcrest 断言 测试驱动开发&#xff1a;第一个示例开场白开始吧去掉不干净的代码增量性fixture 设置思索与测试驱动开发测试驱动与测试 测试驱动开发基础与单元测试单元测试的组织结构测试驱动开发周期&#xff1a;红-绿-重…

opencv配置相关的截图参考

opencv配置相关的截图参考&#xff0c;如下&#xff1a;

Anaconda3安装及opencv配置

一、Anaconda安装 1.直接百度搜anaconda&#xff0c;进入官网即可&#xff08;anaconda网站链接&#xff09; 2.点击图片上黑框&#xff08;Get Started&#xff09;即可进入下一步&#xff0c;选择下图中第四个 3.选择适合电脑类型的anaconda安装器&#xff0c;注意选好64位…

linux安装配置opencv

刚开始学习ubuntu&#xff0c;有些项目需要用到opencv&#xff0c;当我用下面的命令安装包的时候&#xff0c;总是出现“E&#xff1a;无法定位软件包 opencv”的错误。然后开始着手解决&#xff0c;网上搜集了很多的教程&#xff0c;大部分都是说要更换源&#xff0c;我也照做…

opencv安装配置测试

前面安装了pcl和qt&#xff0c;以及qt中的vtk&#xff0c;这里配置下opencv4.3 将cv复制到D盘下。 安装完成之后&#xff0c;添加环境变量&#xff0c;[计算机]->右键 [属性]->[高级系统设置]->[环境变量]->[系统环境变量]->编辑 [Path]&#xff0c;添加“D:…

Qt中配置OpenCV

Qt中配置OpenCV 1. 环境下载2. 进行编译和安装2.1 新建opencv-build文件夹&#xff0c;用于opencv的 编译和安装&#xff08;直接在opencv下新建即可&#xff09;2.2 CMake设置2.3 命令行进行编译安装 3. Qt测试4. 其它问题4.1 若电脑上安装有PyQt4.2 电脑无法访问wai网 1. 环境…