书评 Pragmatic Unit Testing in Java with JUnit
看这本书时候正好在做一个java的项目,正好可以把书中的内容应用到项目中。这本书的作者是Andy Hunt和Dave Thomas。名著《The Pragmatic Programmer》正是出自他们之手。这本《pragmatic unit testing in java with junit》是The Pragmatic Starter Kit系列的第二本。按作者的说法,这个系列讲述了一些所有软件开发都必不可少的基本实践。这个系列的第一本是《pragmatic version control》,讲述版本控制,主要是介绍CVS,第二本主要讲单元测试,第三本主要讲自动化(还没有出版)。书写的很精炼,只有160多页,由于我之前已经看过了《junit in action》,所以这本书只是有选择性的看了一下。
我不知道别的程序员在写程序的时候有没有写单元测试,反正我看这本书之前是没有写过的,后果就是大量的时间都花在了调试上。写单元测试最大的感受有下面几点:1.对自己的代码很放心,睡觉也比以前安稳了;2.调试的时间很少,以我的亲身经历,我们的项目是一个小额支付的项目,我在项目中负责CMPP协议的解析,项目已进行了一个月,这个模块已基本完成,我调试的时间加起来不到24小时,特别是把Junit和log4j结合起来用,运行测试用例(testcase)的时候如果有错就看看log4j的输出,很快就能定位错误;3.编程的乐趣感大大加强,特别是应用测试驱动开发(test-driven development),这种方法以测试来驱动开发,要求先写测试用例,再根据测试用例来实现被测试的类,这种方法的好处是测试代码就是被测试对象的客户,所以写测试代码的时候就要求你思考应该如何定义被测试对象的接口,但是这种方法要求你的测试用例比较全面,而这需要经验。
再说说这本书,书共分为9章和4个附录。单元测试的必要性、方法和测试驱动等等都讲到了。第二章用一个简单的例子介绍了单元测试,第三章介绍了junit这个单元测试工具的使用,第四五六七章是本书的重点,第四章介绍应该测试哪些东西,第五章介绍了应该怎样测试边界条件,第六章介绍如何用mock objects进行测试。什么是mock objects?简单的说,就是一个仿造的对象,它和被模访的对象有着相同的接口。举个例子,我们要测试Class A,Class A要调用Class B的函数,但如果Class B现在还没有实现,那么我们可以从Class B的接口抽象出一个接口interfaceB,再构建一个类Class MockB来实现这个接口,一般MockB的实现非常简单,它的存在只是为了方便测试Class A。这里要注意的是我们要测试的是Class A,而不是Class MockB这个mock object。现在应用mock objects的一个很普遍的误区就是测试用例变成了测试mock objects。关于mock objects的使用,在《junit in action》中也有一章写的很精彩。
书的后面的部分都是一些介绍性的,第八章介绍了把单元测试应用到项目上时,测试代码和发布代码(production code)应该如何分布的问题。一般是把这两部分放在不同的目录中,但是保留同样的包(package)结构,如果你用IDE的话,一般缺省都是这样分布的,如我现在用的jbuilder。第九章讲了测试驱动的一些东东。
总的来说,这本书还是比较棒的,首先是比较薄,这样直切主题,没有很多理论性的东西(关于测试的理论专著有很多,不过大都很晦涩),使承受项目压力的程序员可以很快吸收知识。第二是比较基础,有一点java基础的程序员就可以阅读。不过由于书薄,很多深入的主题都没有谈到,如j2ee测试、concurrent测试等等。这些在《junit in action》中有一些介绍,另外junit的大本营www.junit.org上也有很多很好的文章。