InfoQ

InfoQ

新闻

我的书签

登录注册 以永久保存书签。

该内容已经被标记书签!

标记书签错误,请重试!

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

作者 Mike Bria 译者 张龙 发布于 2008年11月29日

领域
语言 & 开发,
过程 & 实践
主题
单元测试 ,
质量交付 ,
Java ,
敏捷 ,
.NET
标签
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"

译者 张龙 热衷于编程,乐于分享,对新技术有强烈的探索欲,对Java轻量级框架有一定研究。

软件工程就是从技巧向技能的转变 发表人 Li bouzouki 发表于
翻译得不太好 发表人 Shan Yang 发表于
Re: 翻译得不太好 发表人 张 龙 发表于
不要在OO和TDD的路上走太远,忘记了编程的本质 发表人 Huang Andy 发表于
过犹不及 发表人 Shao Tony 发表于
  1. 返回顶部

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

    发表人 Li bouzouki

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

  2. 返回顶部

    翻译得不太好

    发表人 Shan Yang

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

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

  3. 返回顶部

    Re: 翻译得不太好

    发表人 张 龙

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

  4. 返回顶部

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

    发表人 Huang Andy

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

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

  5. 返回顶部

    过犹不及

    发表人 Shao Tony

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

深度内容

大规模视频网站的计费与流量管理

本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011

专访Jeffrey Richter:Windows 8是微软的重中之重

Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。

应用云平台的可用性——从新浪SAE看云平台设计

云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。

JVM定制改进 @ 淘宝

淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011

"伤得起"的云计算应用——对云端应用之架构的思考

2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。

让交付的速度跟上思考的速度

12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011

架构之路——穿行在产品和业务之间

篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011

特性注入:成功三部曲

本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。