AICon 上海站|日程100%上线,解锁Al未来! 了解详情
写点什么

忘掉调试器吧,来使用“Saff Squeeze”

  • 2008-11-29
  • 本文字数:959 字

    阅读完需:约 3 分钟

XP、TDD 及 JUnit 的联合创始人 Kent Beck 谈到了他通过单元测试而不是调试器来跟踪到 JUnit 的新特性 JUnitMax 中一个缺陷。他使用了当前 JUnit 的主开发者 David Saff 向其展示的一个方法,该方法首先创建一个高层的单元测试,然后不断回归直至缺陷的根源处,这时的测试就会变得非常简洁明了。

Beck 通过一个比喻介绍了这个他称之为“ Saff Squeeze ”的方法,该比喻来自美式橄榄球中出现的“三明治”,在这里面带球的人会同时被两个人所击中,一个人击打其“高位”(肩膀附近),另一个人击打其“低位”(腰部或腿部)。他说“Saff Squeeze”与此类似,因为这种方法首先会编写一个失败的高层单元测试(“高位”),然后不断回归,用更加具体的单元测试进行替换(“低位”)直到某个单元测试能直接找出有问题的代码(也就是直到能“揪出”缺陷)。

Beck 对该方法的总结如下:

Saff Squeeze 是这样运作的:首先我们需要编写一个失败的测试,然后逐渐向底层深入直到无法再进行下去为止,这时你就会发现缺陷的本源了。下面是循环的过程: 1. 在测试中内联一个出错的方法。
2. 将一个(失败的)断言放到测试中已有的断言前。
3. 移除测试中新断言到原断言之间的部分。
4. 重复上述过程。

在一篇简短的文章中,Beck 讲解了上述过程,展示了不同阶段的测试代码,最后展示了一个“精简的”测试,该测试揭示出了实际的缺陷。

他将这种方式与传统的通过调试器来跟踪代码的方式进行了对比,总结如下:

这两种方式的一个主要差别在于进行调试后,我知道了缺陷在什么地方,但是在精简后,我还有一个针对该缺陷的最小单元测试。这个精简的测试是随着整个过程的进行自然而然产生出来的。

Beck 说他并没有将这种方式看作是对新代码 TDD 开发周期的一个补充或是改变,而是进行缺陷处理的一个工具:

它将成为识别并修复缺陷的方法的核心: 1. 通过一个系统级测试来重现缺陷。
2. Squeeze。
3. 让这两个测试都能通过。
4. 分析并排除缺陷的根源。

请阅读这篇文章来看看在一个实际的例子中这会是什么样子的,同时更多的了解Beck 对这种技术能力的看法并掌握Eclipse 的内联功能。

你觉得这种方式会将你从调试器中解脱出来么?你认为这种方法有风险么?你用什么办法来处理类似的事情呢,或者同时还采取不同的方式?如果有的话,欢迎大家的讨论。

查看英文原文: Forget Your Debugger, Use The “Saff Squeeze”

2008-11-29 22:54565
用户头像

发布了 88 篇内容, 共 266.9 次阅读, 收获喜欢 8 次。

关注

评论

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

架构训练营模块2作业

唐江

产品经理训练营 Week4 学习心得

Mai

6种常见的地标识别算法整理和总结

华为云开发者联盟

KNN CNN 地标识别 GLDv2 地标识别算法

架构学习模块二作业

架构实战营

架构训练营-模块二作业

Neil43

架构训练营

后端服务太多,且涉及多种语言,如何进行高效管理?

我爱娃哈哈😍

架构 架构设计 架构场景实战

产品经理训练营 Week3 学习心得

Mai

这三年被分布式坑惨了,曝光十大坑

悟空聊架构

朋友圈高性能复杂度

Simon

架构实战营

架构实战营模块 2 作业

Lukefang

微信朋友圈高性能复杂度分析

thewangzl

架构实战营 模块二作业

Dylan

架构实战营

架构实战营模块2作业

林子钧

作业 架构实战营 模块二

微信朋友圈高性能架构

chenmin

架构0期作业2

sjj

华仔架构-模块

大师兄

产品经理训练营Week14学习心得

Mai

架构实战营第二模块作业

DZ

图算法系列之无向图的数据结构

Silently9527

Java 数据结构和算法 图算法 无向图

模块二课后作业

Damon

模块二作业-架构训练营

架构训练营

架构实战营-作业2

大肚皮狒狒

作业

一文带你更方便的控制 goroutine

万俊峰Kevin

线程 并发 Go 语言 goroutine

带你入门目标检测算法

华为云开发者联盟

网络 数据集 目标检测 yolo two-stage

关于 Spring 中 getBean 的全流程源码解析

小傅哥

Java spring 源码分析 小傅哥 getBean流程

模块2—分析一下微信朋友圈的高性能复杂度

sandy

架构实战营

模块二:课后作业

iHai

架构实战营

Spark任务等待与运行策略

小舰

4月日更

架构实战营模块 2 学习总结

林子钧

总结 架构实战营 模块二

甲方日常 94

句子

工作 随笔杂谈 日常

使用gradle插件发布项目到nexus中央仓库

程序那些事

Java maven Gradle 程序那些事

忘掉调试器吧,来使用“Saff Squeeze”_Java_Mike Bria_InfoQ精选文章