Frank's Home

天道酬勤
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

每日构建+单元测试 (转载)

Posted on 2005-06-13 19:43  Frank  阅读(656)  评论(0编辑  收藏  举报

1.每日构建(Daily Build

在项目中使用每日构建(Daily Build)是为了实现“持续集成”。传统构建只发生在项目发布前夕很短的一段时间,压力和风险不小。每日构建一定程度上缓解了这种压力,削平了曲线。好东西!但每日构建也需项目组的投入,学习和使用Ant(或Nant)就是一个不错的办法。

 

2.单元测试(Unit Test

在项目中使用单元测试(Unit Test)和每日构建在思想上有相似之处,在实践中又交相呼应。单元测试可以确保每个软件项目最小逻辑部件的正确性。在耦合始终存在的情况下,单元测试的作用其实也被放大了,对某个逻辑部件的测试自然也包括了对所引用其他部件的测试(虽然这并不是单元测试的初衷)。单元测试不是最重要的,但的确是非常重要的和必须的。单元测试也需要项目组的投入,编写单元测试用例是起码的,学习和使用JUnit(或Nunit)能帮上不小的忙。

 

3.结合起来(Do Them All

单元测试的最佳实施者是每个开发人员自己,也可以采用同行测试(Buddy Test)。他们阅读设计文档,编写单元测试用例、编写逻辑部件,然后把逻辑部件放到测试用例中测试,测试通过就继续往前走。单元测试的发起者是项目组中单个的开发者时,会使得单元测试此起彼伏,但问题是有些单元测试有很多都是无效的。原因很简单,因为不同开发者编写的逻辑部件之间的耦合只要存在,这样的单元测试就是无效的。参考《软件配置管理模式》一书中关于“活动开发线”模式的讲述:当在项目的一条码线(Code Line)上,测试与开发在时间上同存时,测试都是无效的,单元测试也不例外。

也许在开发者自行单元测试的同时,我们还应该定时的让所有的开发者都停下来,提交他们的代码,然后一起来进行单元测试。其实这不难,每天下班的时候他们都会自动的停下来,如果项目的配置管理还算可以的话,他们也都会在下班前提交代码,然后让我们来运行单元测试吧。

我们用Ant来进行每日构建。同样,我们也可以让Ant+JUnit帮助我们进行每日单元测试(Daily Test?)。每次听微软的讲师讲MSF,都要讲他们的开发是深夜12:00开始的,也就是“自动构建+自动测试”,第二天早上,开发组的人拿到自动生成的报告,该code的就code,该debug的就debug。(其实,这也就是一种测试驱动开发:Test-Driven Development,又一个很多人争议的软件方法。)这不难,是看公司要不要这么做。

 

4.实践(Practice

关于使用Ant实现每日构建的请看陋文:“一个轻巧的每日构建解决方案”。

在此基础上,在Ant的“build.xml”中加入单元测试任务即可,同时也可以生成单元测试报告。甚至可以将单元测试结果报告通过email发送给开发组成员。

先请出国内外的几篇好文:

让编译和测试过程自动化

利用AntJUnit进行增量开发

每日创建之自动测试

到今天(2004-08-20)为止,在Google上面以“ant+junit”可以搜出127000条记录,大家都做得很好。但上面3篇的确已经足够帮助还未实作的人快速的实现“每日构建+单元测试”了。

关于实践他们都说得很清楚,我也是在看了这些文档后完成实践的。我在自己的Blog上加点自己的东西吧,也就是在实现“每日构建+单元测试”时的小贴士。

1)环境配置之<mail>

“让编译和测试过程自动化”一文的作者Erik Hatcher也是Ant的开发者之一。但此文有些早了,文中所提到的Ant的<mimemail>已经合并到<mail>中,<mimemail>已经废置不用了。<mail>任务依赖于JavaMailJAF,如果没有用过的话,请到SUN公司的网站上下载,并在下载后完成以下配置(以我的目录结构为例):

CLASSPATH

C:\javamail-1.3.2ea\mail.jar;

C:\javamail-1.3.2ea\lib\mailapi.jar;

C:\javamail-1.3.2ea\lib\pop3.jar;

C:\javamail-1.3.2ea\lib\smtp.jar;

C:\jaf-1.0.2\activation.jar;

这样才能保证Antemail发送构建和测试报告时的正确。

2)环境配置之<junit><junitreport>

如果项目组在白天用的是JBuilder,其中集成了JUnitAnt。(建议下载单独的AntJUnit)但当晚上Ant调用JUnit执行测试任务时,必须保证,<junit><junitreport>能被Ant所识别。所以,你要将JUnit所属的3*.jar文件:src.jar ,junit.jar,junitmail.jar拷贝到Ant的库所在目录(以我的目录结构为例):

C:\ant\lib

这样才能保证,Ant+JUnit会为你生成漂亮的html格式的测试报告,并发送到你指定的email中。

 

5.总结(Summary)

讨论了每日构建和单元测试的作用和结合起来使用的理由。配合软件开发配置管理模式提出了供参考的结合方法,并通过实践验证该方案的可行性和简单性。最后和java不太熟练的朋友分享了少量经验。