9月7日-8日,相约 2023 腾讯全球数字生态大会!聚焦产业未来发展新趋势! 了解详情
写点什么

Bob Martin:逆变测试

  • 2017-10-16
  • 本文字数:832 字

    阅读完需:约 3 分钟

Bob Martin 是敏捷宣言的制定者之一。他发表了一篇博文,概述编写协变结构的测试和代码存在的陷阱。本质上,他强调的是,在设计测试结构时应该采用逆变方式,将其从生产代码中解耦,从而得到一个健壮性更好、重构更容易的代码库。

人们在开始使用 TDD 时,经常遇到的一个问题是测试脆弱性问题。Martins 解释说,当测试代码与生产代码紧密耦合时,如果不重新编写测试,那么任何重构几乎都是不可能的。他强调:

测试的结构不必反映生产代码的结构,因为过度耦合让系统脆弱,而且妨碍重构。相反,测试结构必须独立设计,从而最小化与生产代码的耦合。

为了进一步说明这个测试脆弱性问题,Martin 指出,这经常是不理解什么是重构导致的:“重构被定义为一个包含一系列小变更的序列,可以保证测试总是可以通过”。将测试耦合到生产代码,而不注重测试其行为,重构就变成不可能了。

Martin 写道,这种协变结构还源自对 TDD 的误解。人们通常认为,每个类都应该有一个测试类,然而,实际上,它们应该有自己的结构。毕竟,我们测试的是应用程序行为,而不是代码结构。

Martin 解释说,虽然开始的时候类和测试之间可能存在直接的对应关系,但随着开发进行会自然分开。他举的第一个例子是,将公有方法中的代码提取到私有方法中。应用程序行为测试的覆盖率不会变,但引入了没有直接测试的方法。如果这些代码被提取到类中,该规则同样适用;不需要创建新的测试类,因为所有的行为都是通过原来的测试进行测试。

Martin 写道,久而久之,随着开发进行,越来越多的测试加入进来,每个测试都测试一种具体的应用程序行为。随着完整规范的建立,为了容纳所有必要的行为,应用程序代码自然变得越来越泛化。换句话说,生产代码应该总是越来越泛化,而测试代码应该越来越具体。这就促进了解耦,这样就是逆变:

随着测试变得越来越具体,生产代码变得越来越泛化。两个代码流沿着泛化轴向着相反的方向演化,直到没有新的沉降试验可以编写。

要阅读完整的博文,请点击这里

查看英文原文 Bob Martin: Test Contra-Variance

活动推荐:

2023年9月3-5日,「QCon全球软件开发大会·北京站」 将在北京•富力万丽酒店举办。此次大会以「启航·AIGC软件工程变革」为主题,策划了大前端融合提效、大模型应用落地、面向 AI 的存储、AIGC 浪潮下的研发效能提升、LLMOps、异构算力、微服务架构治理、业务安全技术、构建未来软件的编程语言、FinOps 等近30个精彩专题。咨询购票可联系票务经理 18514549229(微信同手机号)。

2017-10-16 19:001137
用户头像

发布了 1008 篇内容, 共 361.9 次阅读, 收获喜欢 334 次。

关注

评论

发布
暂无评论
发现更多内容

AI重塑千行百业 华为云发布盘古大模型3.0和昇腾AI云服务

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 7 月 PK 榜

iOS打包IPA教程

雪奈椰子

软件测试/测试开发丨Pytest学习笔记

测试人

Python 程序员 软件测试 pytest

🎉号外号外!OpenTiny 将在HDC华为开发者大会正式发布!

Kagol

开源 前端 OpenTiny UI组件库

给大模型持久记忆!GitHub 2万星向量数据库云服务升级,国内云产品下周上线

Zilliz

云服务 Zilliz 向量数据库 zillizcloud

GeaFlow图计算快速上手之PageRank算法

TuGraph-Analytics(GeaFlow)

PageRank 图算法 图计算 图论 GeaFlow

跨功能需求(CFR)/ 非功能性需求(NFR)的目标设定

码猿外

技术管理 非功能性需求 跨功能需求

阿里云通义大模型家族迎来新成员,通义万相已开启定向邀测~

新云力量

AI 2023人工智能大会 科技改变生活

软件测试 | 如何分析性能测试

测吧(北京)科技有限公司

测试

2023-07-07:给出两个字符串 str1 和 str2。 返回同时以 str1 和 str2 作为子序列的最短字符串。 如果答案不止一个,则可以返回满足条件的任意一个答案。 输入:str1 =

福大大架构师每日一题

Go 算法 rust 福大大架构师每日一题

开源:老朋友,新棋局

树上有只程序猿

低代码开发,改变数字化游戏规则

伤感汤姆布利柏

引领AI浪潮:低代码开发平台点燃数智时代,释放人工智能的巨大潜力!

快乐非自愿限量之名

人工智能 低代码 AI赋能

C++实现读写ini配置文件

向阳逐梦

千万级规模微服务稳定性技术揭秘:隔离策略

中原银行

微服务 云原生 稳定性治理

软件测试 | 性能分析的基本原则

测吧(北京)科技有限公司

测试

软件测试 | 如何看Analysis分析图

测吧(北京)科技有限公司

测试

华为云Astro出品《低代码开发者101问》电子书上线

华为云PaaS服务小智

云计算 低代码 华为云

数智之潮下的移动生态: AI与低代码平台的完美交融!

不在线第一只蜗牛

移动应用 低代码 数智化 AI赋能

一文囊括Ceph所有利器(工具)

hs_wu

云计算 分布式存储 Ceph

OpsGPT 智能运维大语言模型业界首发

乘云 DataBuff

APM 可观测性 AIOPS Dynatrace Datadog

阿里云AI绘画创作大模型通义万相亮相,已开启定向邀测!

新云力量

AI 2023人工智能大会 科技改变生活

国际开源软件圈著名专家、ASF 基金会董事 Christofer Dutz 全职加入天谋科技!

Apache IoTDB

开源 IoTDB

软件测试 | Analysis使用基础

测吧(北京)科技有限公司

测试

测试技术的重要性与应用:现状、方法和未来展望

天翼云开发者社区

软件测试 数据测试

做大模型不要沉迷有趣,要解决企业问题

新云力量

AI 2023人工智能大会 科技改变生活

代码随想录Day10 - 栈与队列(上)

jjn0703

以科技创新驱动高质量发展,天翼云操作系统获国资委权威认证!

天翼云开发者社区

云计算

天谋科技物联网原生时序数据库管理系统 IoTDB 获“可信数据库”双份权威认可!

Apache IoTDB

IoTDB Apache IoTDB 可信数据库大会

华为云CodeArts Build-云端化的编译构建平台

华为云PaaS服务小智

华为云 华为开发者大会2023

数智时代的算力革命:低代码开发平台引领技术风潮

EquatorCoco

人工智能 数据 低代码 数智未来

  • 扫码添加小助手
    领取最新资料包
Bob Martin:逆变测试_语言 & 开发_Andrew Morgan_InfoQ精选文章