InfoQ

新闻

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

作者 Mike Bria译者 张龙 发布于 2008年11月29日 下午10时54分

社区
.NET,
Agile,
Java
主题
单元测试,
质量交付
标签
JUnit,
调试器,
测试驱动开发

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"

5 条回复

回复

软件工程就是从技巧向技能的转变 发表人 bouzouki Li 发表于 2008年11月30日 上午2时42分
翻译得不太好 发表人 Yang Shan 发表于 2008年11月30日 下午10时55分
Re: 翻译得不太好 发表人 long zhang 发表于 2008年12月1日 上午2时11分
不要在OO和TDD的路上走太远,忘记了编程的本质 发表人 Andy Huang 发表于 2008年12月1日 下午8时40分
过犹不及 发表人 Tony Shao 发表于 2008年12月3日 上午4时31分
  1. 返回顶部

    软件工程就是从技巧向技能的转变

    2008年11月30日 上午2时42分 发表人 bouzouki Li

    技巧不仅是对工程的阻碍,事实上也是对开发者的束缚,当越来越多的技巧转化成技能,开发者就能释放出更多的创造力。

  2. 返回顶部

    翻译得不太好

    2008年11月30日 下午10时55分 发表人 Yang Shan

    Inline a non-working method in the test.
    在测试中内联一个出错的方法

    Prune away parts of the test that are no longer relevant.
    这个实际上就是移除新断言到原断言之间的部分

  3. 返回顶部

    Re: 翻译得不太好

    2008年12月1日 上午2时11分 发表人 long zhang

    你好,谢谢你的指正,这篇新闻是我翻译的,刚才又仔细对照原文进行了检查,确实如你所说,这两个地方翻译的有问题,已经修正,再一次感谢你的指正 :-)

  4. 返回顶部

    不要在OO和TDD的路上走太远,忘记了编程的本质

    2008年12月1日 下午8时40分 发表人 Andy Huang

    JUnit虽然好,但是不是万能的膏药。这些技术偏执狂,有时候过分的偏激和钻牛角尖了。

    对于简单的bug,这种方法是可行的,但很多复杂的程序,用这种方法,怎么也找不到bug的,调试器有时候是必不可少的。

  5. 返回顶部

    过犹不及

    2008年12月3日 上午4时31分 发表人 Tony Shao

    请问有效率和效果的评估吗?

深度内容

Flex与JSON及XML的互操作

平台需要互操作性。在这篇文章中,作者仔细研究了Flex和JSON及XML的互操作性。文章也包含了使用E4X库来将XML映射到图表和表格组件的内容,还演示了如何使用as3core库来解码JSON消息。

用Qi4j进行面向组合编程

本文将简要介绍面向组合编程(COP,Composite Oriented Programming)的概念,展示它如何规避OOP存在的一些问题,并重新点燃使用可重用部件组装领域模型(Domain Model)的希望。

系统开发——新学科,新教育

一门新的计算机学科——“系统开发”,强调人性化、匠艺、设计、创意、创新和新事物的涌现,并建议用被称为“bottega”的工作室替代乏善可陈的教室。

图书聚焦:Visual Studio 2008 揭秘

Mike Snell和Lars Powers用他们最近由Sams出版的新书《Visual Studio 2008揭秘》,试图帮助大家提高开发人员的生产力。本文包括一个下载样章——第10章调试。

BPEL为何不是BPM的圣杯?

Pierre Vigneras在本文中讨论了作为标准之一的BPEL所存在的问题。Pierre先给我们大致介绍了一个简单的并行流程,接着讨论了从业者在试图以一个结构化模型为基础表达非结构化流程时遇到的一系列问题。

基于范型的多语言编程

你是否仔细思考过,为什么人们总在讨论“要正确的语言做恰当的事情”?在这篇文章中,Sadek Drobi向你解释了为什么应该在系统内部混合使用多种语言。

采访与书摘《Pro Web 2.0 Application Development with GWT》

Jeff Dwyer就关于他的新书(《Pro Web 2.0 Application Development with GWT》)、GWT1.5以及创建可搜索的Ajax应用谈了一些他的见解。

时刻准备着,迎接IT业的春天

我们需要设身处地地为客户及客户的业务本身着想,与客户同舟共济。更多创新的思路、产品和模式也同样将为IT业带来新的出路。IT业并不需要坐以待毙,在春天到来之后,市场将会更加繁荣!