title: 测试驱动开发学习笔记(UTDD)

date: 2020-08-01 23:59:17

tags: [2020, 学习一门技能, TDD, DevOps]


What

TDD(Test-Driven Development)是敏捷开发中的一项核心实践和技术、是一种方法论。思路是通过测试来推进整个开发的进行。表现为测试代码优先于业务代码。UTDD呢,其实U就是unit,一般习惯直接叫成TDD。

从长远角度来看,他加快了组织价值流输出的质量、速度、稳定性,所以我想他理应纳入DevOps技能范凑。

Why

为什么要用到他呢?为什么说他加快了组织价值流输出呢?这就要说说他的优点了:

  1. 自解性:测试代码即文档,新接触代码的开发人员通过阅读测试代码即可充分了解业务。
  2. 健壮性:业务建立在一个个单元测试的保护之下,规避了大批bug。
  3. 正确性:修改已有代码不再烫手,测试带来了正确性保护,这将在重构或者维护时体现。
  4. 改进API:测试自然的让开发人员变得从客户端角度编写可测试的OO代码,驱动了API的设计。

以上的优点都在一定程度上提升组织的单位价值输出。

另外,他的引入也是有代价和风险的:

  1. 开发成本:开发人员需要编写测试代码。
  2. 维护成本:开发人员需要维护测试代码。
  3. 环境搭建:测试环境的建立成本。

所以,对于组织来说它的引入则是一把双刃剑,要看用在什么场景以及用到什么程度。成本大于收益那就不要采用了。

How

一、学TDD前该知道的

  • 单元测试

    单元测试应该是面向业务的,而不是面向代码的,编写单元测试时应该将一个业务场景当做一个被测试的单元。单元测试应遵循FIRST原则,即快(不依赖外部)、可重复、隔离(独立性)、清晰的成功或失败、频繁且小规模。测试方法命名采用ruby命名法should_xxx_xxx(),内容应用Given-When-Then模式,When时注意运用CQS命令查询分离原则。框架上,主要有做测试的Junit,做验证的AssertJ,做模拟的Mockito。

  • 面向对象

    业务代码编写遵守SOLID六大原则,单一职责原则、开闭原则.....等。简单来说要记住迪米特法则,即不要和陌生人说话,以及信息专家模式,以减少外部的数据访问权,然后就是注意组合优先,无差异无继承。

  • 重构

    重构即在保证原有代码功能的前提下,去除代码坏味道,进行的一种代码的优化操作。Kent Beck简单设计原则能很好的指导重构:

    1. 通过所有测试
    2. 减少重复代码
    3. 表达程序员的意图
    4. 尽可能减少方法的数量

    重构的运用需要注意重构策略的选择和考虑引入Code Review。另外,重构可以且需要随时进行。

二、TDD

TDD核心可看做一个闭环:RED -> GREEN -> REFACTOR,即运行一个失败的测试 -> 让测试通过 -> 及时重构代码。

TDD还包括以下知识:

  1. 需求分析

    TDD遵循简单设计,而这个简单设计不是不设计或少设计,而是清晰的设计。在进行单元测试编写之前,开发人员要用足够的时间去弄清需求,然后再做任务分解子任务分解。任务分解是对用户故事的拆解,子任务分解是对任务的进一步细分拆解,最终任务和子任务能达到:

    1. 任何子任务均可通过测试来验收
    2. 所有任务的集合恰好等价于原问题域
    3. 子任务之间无交集

    任务之间保持递进原则。

  2. TDD的三大支柱

    1. 一次只写一个刚好失败的测试
    2. 不写任何产品代码,除非他刚好能让失败的测试通过
    3. 只在测试全部通过的前提下重构或开始新的功能
  3. 编写测试上,涵盖单元测试需要注重的点,比如FIRST原则等。

Last

最后,感谢测试驱动开发训练营张逸老师的倾囊相授!

测试驱动开发学习笔记(UTDD)的更多相关文章

  1. TDD(测试驱动开发)学习一:初识TDD

    首先说一下名词解释,TDD,英文名称Test-Driven Development,中文名称测试驱动开发,简单的断下句“测试/驱动/开发”,简单的理解一下,就是测试驱动着开发,大白话就是说用一边测试一 ...

  2. TDD(测试驱动开发)学习二:创建第一个TDD程序

    本节我们将学习一些测试驱动开发环境的搭建,测试驱动开发概念和流程.所涉及的内容全部会以截图的形式贴出来,如果你也感兴趣,可以一步一步的跟着来做,如果你有任何问题,可以进行留言,我也会很高兴的为你答疑. ...

  3. 测试驱动开发(TDD)及测试框架Mocha.js入门学习

    组里马上要转变开发模式,由传统的开发模式(Developer开发,QA测试),转变为尝试TDD(Test-driven development,测试驱动开发)的开发模型.由此将不存在QA的角色,或者仅 ...

  4. Hibernate 马士兵 学习笔记 (转)

    目录(?)[+] 第2课 Hibernate UML图 第3课 风格 第4课 资源 第5课 环境准备 第6课 第一个示例Hibernate HelloWorld 第7课 建立Annotation版本的 ...

  5. (转)Python学习笔记(1)__name__变量

    Python使用缩进对齐组织代码的执行,所有没有缩进的代码,都会在载入时自动执行.每个文件(模块)都可以任意写一些没有缩进的代码,并在载入时自动执行.为了区分 主执行代码和被调用文件,Python引入 ...

  6. NGUI学习笔记(一)UILabel介绍

    来个前言: 作为一个U3D程序员,自然要写一写U3D相关的内容了.想来想去还是从UI开始搞起,可能这也是最直观同时也最重要的部分之一了.U3D自带的UI系统,也许略坑,也没有太多介绍的价值,那么从今天 ...

  7. PyQt4入门学习笔记(一)

    PyQt4入门学习笔记(一) 一直没有找到什么好的pyqt4的教程,偶然在google上搜到一篇不错的入门文档,翻译过来,留以后再复习. 原始链接如下: http://zetcode.com/gui/ ...

  8. TDD学习笔记【一】----序言

    提到TDD大多数程序员的疑问: 为什么我要写两份程序? 为什么我要写程序来验证我已经知道的结果? 我又不是SA,可能也不懂domain,怎么产生一开始的test case? 最后的感想就变成是: 1. ...

  9. WeX5学习笔记

    目录 WeX5学习笔记... 1 1.轻松看透WeX5产品能力和技术... 1 2.WeX5可以怎么玩?... 3 一.纯本地App. 3 二.关联一个网站,希望默认就打开某页... 4 三.UI设计 ...

随机推荐

  1. django模板中变更数据库信息后,如何把变更后的信息同步更新到数据库

    我们在基于django开发项目的过程中,经常会遇到数据库表字段增加,删除,或者修改的情况,以及字段属性更改的情况,因为django基于ORM模式来操作数据库的, 传统上如果django项目中的数据库m ...

  2. 选课系统<基于面向过程\对象>

    2020-04-15 00:09:28 程序目录: import os BASE_PATH=os.path.dirname(os.path.dirname(__file__)) DB_PATH=os. ...

  3. ant design pro 当中改变ant design 组件的样式和 数据管理

    ant design pro 简介 官网简介 链接 https://pro.ant.design/docs/getting-started-cn 项目结构 https://github.com/ant ...

  4. 数据可视化之分析篇(一)使用Power BI进行动态帕累托分析

    https://zhuanlan.zhihu.com/p/57763423 通过简单的点击交互,就能进行动态分析发现见解,才是我们需要的,恰好这也是 PowerBI 所擅长的. 就帕累托分析来说,能从 ...

  5. C# 接口与抽象类的区别? 情景下使用接口,什么情景下使用抽象类?

    接口与抽象类的区别: 接口支持多继承:抽象类不能实现多继承. 接口可以用于支持回调:抽象类不能实现回调,因为继承不支持. 接口只包含方法.属性.索引器.事件的签名,但不能定义字段和包含实现的方法:抽象 ...

  6. The Prices

    题目描述 你要购买\(m\)种物品各一件,一共有\(n\)家商店,你到第\(i\)家商店的路费为\(d[i]\),在第家商店购买第\(j\)种物品的费用为\(c[i][j]\),求最小总费用. 输入格 ...

  7. IDEA 格式化代码快捷键

    一般都是:Ctrl+Alt+L 如果未格式化的话,可能与以下软件的快捷键冲突了: QQ 网易云 也可能是其他的快捷键组合,具体可查看工具栏Code->Reformat Code: 也可重新设置i ...

  8. PyQt5绘图

    QPainter 功能:QPainter实现在QWidget上画图功能 说明:绘图必须在paintEvent中完成,且要在bengin和end之间作图 接口: 方法 描述 begin 开始画图 end ...

  9. 设计模式:decade模式

    目的:为系统中的一组联动接口提供一个高层次的接口,从而降低系统的复杂性 优点:使用窗口模式可以使得接口变少 继承关系图: 例子: class Subsystem1 { public: void Ope ...

  10. [jvm] -- 类文件结构篇

    类文件结构 结构图  魔数 头四个字节,作用是确定这个文件是否为一个能被虚拟机接收的 Class 文件. Class 文件版本 第五和第六是次版本号,第七和第八是主版本号. 高版本的 Java 虚拟机 ...