Joinclass Inc  
软件开发 软件配置 项目管理 软件工程
公告
  • 本人联系方式: E-mail: tilanmaster@gmail.com msm: J.joy@msn.com
日历
统计
  • 随笔 - 53
  • 文章 - 52
  • 评论 - 67
  • 引用 - 0

导航

常用链接

留言簿(1)

随笔分类(53)

随笔档案(53)

文章分类(61)

相册

JAVA学习链接

搜索

  •  

积分与排名

  • 积分 - 88546
  • 排名 - 77

最新评论

阅读排行榜

评论排行榜

 

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 发送给开发组成员。

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

让编译和测试过程自动化

利用 Ant JUnit 进行增量开发

每日创建之自动测试

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

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

1) 环境配置之<mail>

“让编译和测试过程自动化”一文的作者 Erik Hatcher 也是 Ant 的开发者之一。但此文有些早了,文中所提到的 Ant 的<mimemail> 已经合并到<mail> 中,<mimemail> 已经废置不用了。<mail> 任务依赖于 JavaMail JAF ,如果没有用过的话,请到 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;

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

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

如果项目组在白天用的是 JBuilder ,其中集成了 JUnit Ant 。(建议下载单独的 Ant JUnit )但当晚上 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 不太熟练的朋友分享了少量经验。

 

posted on 2007-01-16 11:18 Joinclass Inc 阅读(1490) 评论(2)  编辑 收藏 引用 所属分类: 技术专题
评论:
  • # re: 每日构建+单元测试  企划方案 Posted @ 2007-01-16 19:52
    博主写的很好,学到很多东西。。。  回复  更多评论   

  • # re: 每日构建+单元测试  笑话 Posted @ 2007-08-06 15:17
    很不错的文章。值得大家学习呀。  回复  更多评论   

只有注册用户登录后才能发表评论。
 
Copyright © Joinclass Inc Powered by: 博客园 模板提供:沪江博客